@charset "UTF-8";

/* kv */
.kv_wrap{
  width: 100%;
}
.kv_wrap img{
  width: 100%;
}
.coupon_link{
  width: 100%;
}
.coupon_link img{
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .coupon_link img{
    max-width: 480px;
    margin: 0 auto;
  }
}
/* 目次 */
.index_list{
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  flex-wrap: wrap;
}
.index_list li{
  width: calc(50% - 10px);
}
.index_list li a{
  border-radius: 8px;
  border: 1px solid var(--green);
  width: 100%;
  display: flex;
  padding: 18px 24px 18px 20px;
  justify-content: space-between;
  align-items: center;
  color: var(--green);
  gap: 8px;
}
.index_wrap h2{
  text-align: center;
}
.index_wrap{
  display: flex;
  flex-flow: column;
  gap: 30px;
}
@media only screen and (max-width: 768px) {
  .index_list li{
    width:100%;
  }
  .index_list li a{
    padding: 14px 20px 14px 16px;
  }
}
/* こんな方におすすめ */
.recommend_wrap{
  border-radius: 16px;
  background: var(--greenbg);
  display: flex;
  padding: 36px;
  flex-direction: column;
  align-items: flex-start;
  gap: 32px;
  margin-bottom: 42px;
}
.recommend_desc{
  color: var(--black);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 170%;
  letter-spacing: 0.96px;
}
@media only screen and (max-width: 768px) {
  .recommend_wrap{
    padding: 24px;
    margin-bottom: 32px;
  }
}

/* 当院がおすすめ */
.treatment_inner{
  display: flex;
  flex-flow: column;
  gap: 30px;
}
.wrap.visible{
  overflow: visible;
}
.treatment_container .wrap{
  overflow: visible;
}
.treatment_list{
    display: flex;
    align-items: center;
    gap: 42px;
    padding: 36px;
    border-radius: 20px;
    background: var(--white);
}
.treatment_list_img{
    width: 320px;
}
.treatment_list_contents{
    width: calc(100% - 362px);
}
.treatment_list_title{
    margin-bottom: 20px;
}
.treatment_list_contents .en{
    color: var(--green);
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
    text-transform: uppercase;
    margin-bottom: 10px;
}
@media only screen and (max-width: 768px) {
  .treatment_list{
    flex-flow: column;
    padding: 20px;
    gap: 20px;
  }
}
.doctor_wrap{
  padding: 56px 56px 0;
  gap: 42px;
  border-radius: 20px;
  background: var(--white);
}
.doctor_wrap2{
  padding:0 24px 0 56px;
  gap: 42px;
  border-radius: 20px;
  background: var(--white);
}
.doctor_wrap_graph{
  width: 100%;
}
.doctor_inner{
  display: flex;
  gap: 10px;
  align-items: center;
}
.doctor_inner img{
  width: 250px;
  height: auto;
}
.doctor_message{
  padding: 16px 30px;
  background-color: var(--bg10);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 200%;
  letter-spacing: 1.08px;
  border-radius: 12px;
}

@media only screen and (max-width: 768px) {
    .treatment_list_img{
        width: 100%;
    }
    .treatment_list_contents{
        width: 100%;
    }
    .treatment_list li{
        flex-flow: column;
        gap: 20px;
    }
    .treatment_list_title{
        margin-bottom: 16px;
    }
    .doctor_wrap{
      background: none;
      padding: 0;
      gap: 30px;
      display: flex;
      flex-flow: column;
    }
    .doctor_wrap2{
      background: none;
      padding: 0;
      gap: 30px;
      display: flex;
      flex-flow: column;
    }
    .doctor_wrap_graph{
      max-width: 540px;
      margin: 0 auto;
      width: 100%;
    }
    .doctor_message{
      width: 100%;
      background-color: var(--white);
    }
}

/* set */

.set_list_slide li{
  background-color: var(--white);
  border-radius: 12px;
  overflow: hidden;
  margin: 0 12px;
}
.set_list_slide.s-img li{
  border-radius: 12px 12px 0 0;
  margin-bottom:.5em;
}
.set_list_slide.s-img li img{
  max-width:100%;
}
.set_title{
  color: var(--white);
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  letter-spacing: 1.2px;
  background-color: var(--green);
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
}
.set_list_inner{
  padding: 20px;
  display: flex;
  flex-flow: column;
  gap: 10px;
}
.set_img{
  width: 100%;
}
.set_off{
  color: var(--green);
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 170%;
  text-align: center;
}
.set_price{
  text-align: center;
}
.set_price span{
  color: var(--green);
  font-size: 32px;
  font-style: normal;
  font-weight: 400;
  line-height: 130%;
}
.set_price small{
  color: var(--green);
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}
.set_contents_wrap{
  border-radius: 6px;
  background: var(--bg10);
  padding: 10px;
}
.set_contents_title{
  color: var(--green);
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: 170%;
}
.set_contents{
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 170%;
}


/* set slide */
.set_list_slide .slick-dots li{
  width: 6px !important;
  height: 6px !important;
  border-radius: 5px !important;
  overflow: hidden;
  margin: 0 6px !important;
}
.set_list_slide .slick-dots li button:before{
  background-color: #fff !important;
  color: #fff !important;
  opacity: 1 !important;
  width: 100% !important;
  height: 100% !important;
}
.set_list_slide .slick-dots li.slick-active button:before{
  background-color: var(--green) !important;
  color: var(--green) !important;
  opacity: 1 !important;
}
.set_list_slide .slick-dots li button{
  width: 100% !important;
  height: 100% !important;
}
.set_list_slide .slick-prev{
  left: -10px !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 20px !important;
  background-color: var(--green) !important;
  z-index: 10 !important;
  background-image: url(/img/top/icon_slide-white.svg) !important;
  background-size:10px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}
.set_list_slide .slick-prev:before{
  content:'' !important;
}
.set_list_slide .slick-next{
  right: -10px !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 20px !important;
  background-color: var(--green) !important;
  z-index: 10 !important;
  background-image: url(/img/top/icon_slide_next-white.svg) !important;
  background-size:10px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;

}
.set_list_slide .slick-next:before{
  content:'' !important;
}
.set_list_slide .slick-dotted.slick-slider{
  margin-bottom: 60px !important;
}
/* プランと料金について */
.plan_container{
  display: flex;
  flex-flow: column;
  gap: 80px;
}
/* table */
.plan_table {
  border-collapse: collapse;
  margin: 0 auto;
  width: 100%;
}
.plan_table.scroll {
  width: 1600px;
  overflow:auto;
}
.plan_table.white td {
  background-color:white;
}
th {
  border: 1px solid var(--border12);
  min-height: 64px;
  padding: 12px 16px;
  text-align: left;
  background: var(--greenbg);
  font-size: 15px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  vertical-align: middle;
}
td {
  text-align: left;
  border: 1px solid var(--border12);
  padding: 12px 16px;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  vertical-align: middle;
}
td .plan_price{
  color: var(--red);
  font-family:  "Figtree", sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 500;
  line-height: 130%;
}
td .plan_supplement{
  color: var(--red);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}
td .plan_supplement > span{
  color: var(--black);
  font-weight: 600;
}
td .plan_desc{
  color: var(--black);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}
.plan_table .icon{
  text-align: center;
}
.scroll th.sticky{
  position: sticky;
  top:0;
  left:0;
  border-left: none;
  border-right: none;
  background: none;
}
.scroll th.sticky::before{
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  border-left: 1px #e6e6e6 solid;
  border-right: 1px #e6e6e6 solid;
  background-color: #F1F4F2;
  z-index: -1;
  box-sizing: content-box;
}
.table_title{
  color: var(--white);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  background: var(--green);
  padding: 16px;
}
.pt2{
  background-color: var(--white) !important;
}
.plan-icon-list{
  display: flex;
  flex-wrap: wrap;
  margin-top:.5em;
}
.plan-icon-list li{
  display:block;
  margin:0 .3em .3em 0;
  padding:.5em 1em;
  border-radius: 10em;
  background-color:#ddd;
  font-size:.75em;
  line-height: 1;
}
.plan-icon-list li.on{
  background-color:#5eccc0;
  color:white;
}
@media only screen and (max-width: 768px) {
  .plan_container{
    gap: 40px;
  }
  .plan_table.scroll {
    width: 900px;
  }
  th , td{
    font-size: 13px;
    padding: 10px;
  }
  td .plan_price{
    font-size: 16px;
  }
  td .plan_supplement{
    font-size: 12px;
  }
  td .plan_desc{
    font-size: 12px;
  }
}
/* 本診療について */
.about_treatment_wrap{
  padding: 36px 42px;
  border-radius: 16px;
  display: flex;
  flex-flow: column;
  gap: 28px;
}
.about_treatment_wrap h2{
  color: var(--green);   
}
.about_treatment_list{
  display: flex;
  flex-flow: column;
  gap: 24px;
}
.about_treatment_list h3{
  padding: 0 12px;
  border-left: 3px solid var(--green);
  margin-bottom: 8px;
}
@media only screen and (max-width: 768px) {
  .about_treatment_wrap{
    padding: 28px 32px;
  }
}

/* //////////////////////// */
/* menopause */
/* //////////////////////// */
/* こんな症状を感じたら更年期のサイン!? */
.sign_wrap{
  width: 100%;
  display: flex;
  gap: 24px;
}
.sign{
  background-color: var(--white);
  border-radius: 10px;
  overflow: hidden;
  width: calc(50% - 12px);
}
.sign h3{
  text-align:center;
  color: var(--white);
  padding: 10px;
  display: flex;
  flex-flow: column;
}
.sign h3 small{
  color: var(--white);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
}
.sign .female{
  background-color: var(--red);
}
.sign .male{
  background-color: var(--blue);
}
.sign_list{
  padding: 36px 42px;
  display: flex;
  flex-flow: column;
  gap: 20px;
}
.sign_list li{
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  display: flex;
  gap: 10px;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .sign_wrap{
    flex-flow: column;
  }
  .sign{
    width: 100%;
  }
  .sign_list{
    padding: 24px;
    gap: 16px;
  }
  .sign_list li{
    font-size: 14px;
  }
}

.sign_list2,.sign_list_column4,.sign_list_column3,.sign_list_femcare{
  display: flex;
  gap: 10px;
  width: 100%;
  flex-wrap: wrap;
}
.sign_list2 li{
  border-radius: 12px;
  background: var(--white);
  width: calc(20% - 8px);
  padding: 24px 0;
  display: flex;
  flex-flow: column;
  gap: 16px;
}
.sign_list_column4 li{
  border-radius: 12px;
  background: var(--white);
  width: calc(25% - 8px);
  padding: 24px 0;
  display: flex;
  flex-flow: column;
  gap: 16px;
}
.sign_list_column3 li{
  border-radius: 12px;
  background: var(--white);
  width: calc(33.3% - 7px);
  padding: 24px 0;
  display: flex;
  flex-flow: column;
  gap: 16px;
}

.sign_list_femcare li{
  border-radius: 12px;
  background: var(--bg10);
  width: calc(33.3% - 7px);
  padding: 24px 0;
  display: flex;
  flex-flow: column;
  gap: 16px;
}
.sign_list2 li img,.sign_list_column4 li img,.sign_list_column3 li img,.sign_list_femcare li img{
  margin: 0 auto;
  display: block;
}
.sign_text{
  text-align: center;
}
.sign_title{
  text-align: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .sign_list2 li,.sign_list_column4 li,.sign_list_column3 li{
    width: calc(33.3% - 7px);
  }
}
@media only screen and (max-width: 480px) {
  .sign_list2 li,.sign_list_column4 li,.sign_list_column3 li , .sign_list_femcare li{
    width: calc(50% - 5px);
    padding: 16px 6px;
    gap: 12px;
  }
  .sign_list2 li img,.sign_list_column4 li img,.sign_list_column3 li img{
    width: 60px;
  }
}

/* faga */
.faga_about_list{
  display: flex;
  gap: 32px;
}
.faga_about_list li{
  width: calc(33.3% - 22px);
  display: flex;
  flex-flow: column;
  gap: 20px;
  justify-content: center;
  padding: 0 ;
  border: none !important;
}
.faga_about_list li img{
  width: 100%;
}
.feature_list_column .note_list li{
  padding: 0;
  border: none !important;
}
.faga_about_list2{
  width: 100%;
}
.faga_about_list2 img{
  width: 100%;
}
.treatment_table{
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 36px;
  border-radius: 20px;
  background: var(--white);
}
.treatment_aga_graph_wrap{
  display: flex;
  flex-flow: column;
  align-items: center;
  gap: 0;
  padding: 36px;
  border-radius: 20px;
  background: var(--white);
}
.treatment_aga_graph{
  width: 100%;
}

.recommend_wrap_title{
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .treatment_table{
    flex-flow: column;
    padding: 20px;
    gap: 20px;
  }
  .treatment_aga_graph_wrap{
    padding: 20px;
  }
  .faga_about_list{
    gap: 20px;
    flex-wrap: wrap;
  }
  .faga_about_list li{
    width: calc(50% - 10px);
    gap: 10px;
  }
}
@media only screen and (max-width: 480px) {
  .faga_about_list{
    gap: 20px;
    flex-wrap: wrap;
  }
  .faga_about_list li{
    width: 100%;
    gap: 10px;
  }
}

/* femcare */
/* こんな症状ありませんか？ */
.sign_femcare_wrap{
  margin: 0 auto 60px;
}
@media only screen and (max-width: 480px) {
  .sign_femcare_wrap{
    margin: 0 auto 40px;
  }
}
.sign_femcare_wrap{
  display: flex;
  flex-flow: column;
  gap: 32px;
}
.sign_femcare_title_wrap{
  display: flex;
  flex-flow: column;
  gap: 4px;
}
.femcare_desc strong{
  font-weight: 600;
}
.femcare_about_wrap{
  display: flex;
  max-width: 768px;
  margin: 0 auto;
  padding: 20px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  border-radius: 8px;
  background: var(--bg10);
}
.femcare_about{
  color: var(--black);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--red);
}

.doctor_recommend_img{
  width: 100%;
  max-width: 536px;
  margin: 0 auto;
  display: block;
}

.md_products_list{
  display: flex;
  gap: 16px;
  width: 100%;
  max-width: 680px;
  margin: 0 auto 10px;
}
.md_products_list li {
  width: calc(50% - 8px);
}
.md_products_list li img{
  width: 100%;
}
.doctor_recommend_wrap .note_list{
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
}

.md_sign_list{
  display: flex;
  gap: 16px;
  width: 100%;
  flex-wrap: wrap;
  margin: 0 auto 30px;
}
.md_sign_list li{
  border-radius: 12px;
  background: var(--white);
  width: calc(33.3% - 11px);
  padding:  0;
  display: flex;
  flex-flow: column;
  gap: 10px;
}
.md_sign_list li img{
  margin: 0 auto;
  display: block;
}
@media only screen and (max-width: 768px) {
  .md_sign_list li{
    width: calc(50% - 8px);
  }
}
@media only screen and (max-width: 480px) {
  .md_products_list{
    flex-flow: column;
  }
  .md_products_list li{
    width: 100%;
  }
  .md_sign_list li{
    width: 100%;
  }
}
/* pain */
.pain_bg{
  width: 100%;
}
@media only screen and (max-width: 1280px) {
  .pain_bg {
    width: 100%;
    height: 500px;
    object-fit: cover;
}
}
.pain_wrap{
  position: relative
}
.pain_inner{
  position: absolute;
  padding-bottom: 50px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-flow: column;
  gap: 20px;
  left: 0%;
  right: 0%;
}
.pain_title{
  color: var(--black);
  font-size: 32px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
}
.pain_list{
  display: flex;
  flex-flow: column;
  gap: 16px;
}
.pain_list li{
  color: var(--black);
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
}
.pain_list li strong{
  font-weight: 600;
}
@media only screen and (max-width: 768px) {
  .pain_title , .pain_list li, .pain_list li strong{
    color: var(--white);
  }
  .pain_title{
    font-size: 24px;
    text-align: center;
  }
  .pain_list{
    margin: 0 auto;
  }
  .pain_list li{
    font-size: 14px;
  }
  .pain_bg {
    width: 100%;
    height: 360px;
    object-fit: cover;
    object-position:50% 100%;
}
}
/* glp1 */
.cause_wrap{
  display: flex;
  flex-flow: column;
  gap: 10px;
  margin-bottom: 42px;
}
.cause_main{
  color: var(--black);
  text-align: center;
  font-size: 24px;
  font-style: normal;
  font-weight: 400;
  line-height: 240%;
}
.cause_main img{
  padding: 12px;
}
.cause_desc{
  color: var(--black);
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 240%;
}
@media only screen and (max-width: 768px) {
  .cause_desc{
    font-size: 14px;
  }
  .cause_main{
    font-size: 20px;
  }
}
/* compare */
.compare{
  display: flex;
  width: 100%;
  gap: 24px;
}
.compare li{
  width: calc(50% - 12px);
  border-radius: 10px;
  padding: 42px 24px 42px;
}
.bad_wrap{
  background: var(--bg10);
}
.good_wrap{
  border-radius: 10px;
  background:linear-gradient(252deg, rgba(237, 242, 255, 0.50) 0%, rgba(255, 237, 244, 0.50) 100%);
}
.compare_img{
  margin: 20px auto;
  display: block;
}
.compare_main{
  color: var(--black);
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
}
.compare_title{
  color: var(--black);
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
  margin-bottom: 8px;

}
.compare_desc{
  color: var(--black);
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 200%;
}
@media only screen and (max-width: 480px) {
  .compare{
    flex-flow: column;
    gap: 20px;
  }
  .compare li{
    width: 100%;
    padding: 24px;
  }
}
/* about */
.about_wrap{
  display: flex;
  flex-flow: column;
  gap: 32px;
}
.glp1_img{
  width: 100%;
  max-width: 524px;
  margin: 30px auto 40px;
  display: block;
}
.about_desc{
  color: var(--black);
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 240%;
}
.about_doc_wrap{
  display: flex;
  gap: 16px;
}
.about_doc_wrap img{
  width: 154px;
  height: 174px;
}
.about_doc_inner{
  display: flex;
  padding: 24px 30px;
  flex-direction: column;
  gap: 8px;
  border-radius: 12px;
  background: var(--white);
}
.about_doc_inner h3{
  color: var(--black);
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
}
.about_doc_desc{
  color: var(--black);
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 240%;
}

/* 1メディカルダイエットの特徴まとめ */
.md_about_list{
  display: flex;
  gap: 32px 16px;
  width: 100%;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
}
.md_about_list li{
  border-radius: 12px;
  background: var(--white);
  width: calc(33.3% - 11px);
  padding: 0;
  display: flex;
  flex-flow: column;
  gap:10px;
}
.md_about_list li img{
  margin: 0 auto;
  display: block;
}
.md_about_list .about_list_text{
  color: var(--black);
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 1.6px;
}
@media only screen and (max-width: 768px) {
  .md_about_list{
    justify-content: flex-start;
  }
  .md_about_list li{
    width: calc(50% - 8px);
  }
  .about_doc_wrap img{
    width: 78px;
    height: 87px;
  }
  .about_doc_desc{
    font-size: 14px;
    line-height: 200%;
  }
  .about_doc_inner{
    padding: 12px ;
    gap: 4px;
  }
  .about_doc_inner h3{
    font-size: 14px;
  }
}
@media only screen and (max-width: 480px) {
  .md_about_list li{
    width: 100%;
  }
  .about_doc_inner{
    padding: 10px 12px;
  }
  .about_doc_wrap{
    gap: 10px;
  }
  .about_doc_wrap img{
    width: 52px;
    height: 58px;
  }
}
.plan_wrap{
  display: flex;
  flex-flow: column;
  gap: 24px;
}
.treatment_container .plan{
  padding: 48px;
  border-radius: 20px;
  background: var(--white);
}
.plan_title_wrap{
  display: flex;
  justify-content: center;
  flex-flow: column;
  gap: 5px;
  padding: 32px 0 42px;
  margin-bottom: 32px;
  border-top:1px solid var(--gray);
  border-bottom:1px solid var(--gray);
}
.plan_title_gpl1{
  color: var(--white);
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 1.4px;
  border-radius: 40px;
  background: var(--green);
  display: flex;
  padding: 2px 30px;
  justify-content: center;
  align-items: center;
  display: inline-block;
  margin: 0 auto;
}
.plan_title{
  color: var(--black);
  font-size: 24px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 1.44px;
}
.plan_title_desc{
  color: var(--black);
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 1.6px;
}
@media only screen and (max-width: 768px) {
  .treatment_container .plan{
    padding: 20px;
    gap: 20px;
  }
  .plan_title_wrap{
    border: none;
    padding-bottom: 0;
    padding-top: 12px;
    margin-bottom: 24px;
  }
  .plan_title_desc{
    font-size: 14px;
    letter-spacing: 1.2px;
  }
  .plan_title{
    font-size: 20px;
  }
}
