@charset "UTF-8";

/*=============================
// variable
===============================*/
/* 2025.09.25 一部非表示処理箇所があるためbodyクラスで制御 */
.is-before-publish .faq {
  padding-top: 100px;
}

@media (max-width: 768px) {
  .is-before-publish .faq {
    padding-top: 13.2315521628vw;
  }
}

.is-before-publish .faq_list {
  margin-bottom: 0;
}

.is-before-publish .footer_secondary nav.pc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media (max-width: 768px) {
  .is-before-publish .footer_secondary nav.pc {
    display: none;
  }
}

.is-before-publish .footer_secondary nav.sp {
  display: none;
}

@media (max-width: 768px) {
  .is-before-publish .footer_secondary nav.sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .is-before-publish .footer_secondary nav.sp ul {
    width: 100%;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
  }

  .is-before-publish .footer_secondary nav.sp ul li {
    width: calc(50% - 1.3333333334vw);
  }

  .is-before-publish .footer_secondary nav.sp ul li span {
    letter-spacing: -0.03em;
  }
}

/* common */
.heading01 {
  margin-bottom: 40px;
  color: #016b2a;
  font-size: 40px;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  gap: 0 8px;
}

.heading01::before,
.heading01::after {
  content: "";
  width: 42px;
  height: 37px;
  background: url("../img/top/heading01_icon.png") no-repeat center/contain;
}

.button01,
.button_new
 {
  width: 100%;
  max-width: 210px;
  height: 55px;
  background: #d6007f;
  border-radius: 999px;
  border: 3px solid #fff;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
  box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
  position: relative;
}

.button01::after {
  content: "";
  width: 26px;
  height: 26px;
  background: url("../img/top/cta_btn_arrow_purple.png") no-repeat
    center/contain;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

.button02 {
  margin: 0 auto;
  width: 400px;
  height: 85px;
  background: #016b2a;
  border-radius: 999px;
  color: #fff;
  font-size: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}

.button02::before {
  content: "";
  width: 9px;
  height: 13px;
  background: url("../img/common/button_icon_arrow_white.png") no-repeat
    center/contain;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

/* content */
/* mv fix 2026-01-23 */
.mv {
  padding: 0 0 97px 30px;
  background: #e3f1de;
}

.mv_inner {
  display: grid;
  grid-template-columns: 42.917vw 52.083vw;
  justify-content: space-between;
}

/* .mv_image {
  margin: 0 auto;
  max-width: 1154px;
  height: 690px;
} */
.mv_image {
  margin: 0 auto;
  max-width: 80.139vw;
  /* height: 47.917vw; */
}

/* .mv_text_1 {
  color: #fff;
  background-image: url("/assets/img/top/mv_text_bg_1.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: inline-block;
  padding: 10px 7px 26px 30px;
  font-size: 40px;
  font-weight: 600;
  margin-bottom: 12px;
} */
.mv_text_1 {
  color: #fff;
  background-image: url("/assets/img/top/mv_text_bg_1.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: inline-block;
  padding: 0.694vw 0.486vw 1.806vw 2.083vw;
  font-size: 2.778vw;
  font-weight: 600;
  margin-bottom: 0.833vw;
}

/* .mv_text_2 {
  color: #016B2A;
  font-size: 24px;
  font-weight: 500;
  line-height: 41px;
  letter-spacing: 0.5px;
  margin: 20px auto 30px;
} */
.mv_text_2 {
  color: #016b2a;
  font-size: 1.667vw;
  font-weight: 500;
  line-height: 2.847vw;
  letter-spacing: 0.035vw;
  margin: 20px auto 30px;
}

.colum_2 {
  display: flex;
  align-items: center;
}

/* .mv_text_2 .mv_text_2_spe {
  color: #DB0034;
  font-size: 30px;
  font-weight: 500;
  line-height: 41px;
  margin: 0 -10px 0 -10px;
} */
.mv_text_2 .mv_text_2_spe {
  color: #db0034;
  font-size: 2.083vw;
  font-weight: 500;
  line-height: 2.847vw;
  margin: 0 -0.694vw 0 -0.694vw;
}

.mv_image_1 {
  text-align: center;
  padding-top: 70px;
}

/* .mv_image_1_1 {
  max-width: 484px;
  margin: 0 auto;
} */
.mv_image_1_1 {
  max-width: 33.611vw;
  margin: 0 auto;
}

.mv_image_2 img {
  height: 100%;
}

.intro {
  padding: 0 30px 65px;
  background: #e3f1de;
}

.intro_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.intro_box {
  margin: 0 auto;
  padding: 57px 26px 26px;
  max-width: 840px;
  background: #fff;
  border-radius: 20px;
  position: relative;
  text-align: center;
}

.intro_box h2 {
  width: 658px;
  padding: 9px 26px 10px;
  background: #016b2a;
  border-radius: 999px;
  border: 3px solid #fff;
  color: #fff33f;
  font-size: 30px;
  font-weight: 800;
  text-align: center;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.intro_box p {
  font-size: 20px;
  line-height: 1.45;
  text-align: center;
}

/* .intro_box a {
  padding: 12px 57px 13px 30px;
  background: #FFF33F;
  border-radius: 50px;
  color: #016B2A;
  font-size: 18px;
  font-weight: 600;
  border: 3px solid #fff;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.25);
  position: relative;
  display: inline-block;
  margin: 12px auto 0;
} */

.intro_box a {
  /* padding: 0.833vw 3.958vw 0.903vw 2.083vw;
  background: #FFF33F;
  border-radius: 3.472vw;
  color: #016B2A;
  font-size: 1.25vw;
  font-weight: 600;
  border: 3px solid #fff;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.25);
  position: relative; */
  display: block;
  margin: 12px auto 0;
}

/* .intro_box a img {
  position: absolute;
  height: 32px;
  width: 32px;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
} */
.intro_box img {
  /* position: absolute;
  height: 2.222vw; */
  /* width: 2.222vw; */
  /* top: 50%;
  right: 1.111vw;
  transform: translateY(-50%); */
}

/* .intro_price {
  margin-bottom: 16px;
} */
.intro_price {
  margin-bottom: 1.111vw;
}

/* .intro_attention {
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  text-align: right;
} */
.intro_attention {
  color: #fff;
  font-size: 0.972vw;
  font-weight: 800;
  text-align: right;
}

.l_sec_added_1_bg {
  background: url("/assets/img/top/sec_added_1_bg_img.png");
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: cover;
  position: relative;
  z-index: 20;
}

/* .l_sec_added_1 {
  max-width: 1040px;
  margin: 0 auto;
  padding: 100px 0 108px;
  text-align: center;
} */
.l_sec_added_1 {
  max-width: 88.041vw;
  margin: 0 auto;
  padding: 6.944vw 0 7.5vw;
  text-align: center;
}

/* .l_sec_added_1 h2 {
  font-size: 46px;
  color: #016B2A;
  font-weight: 600;
  line-height: 68px;
  position: relative;
  display: inline-block;

  &::before {
    content: "";
    background-image: url("/assets/img/top/sec_added_titlepa_pc_img.png");
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    height: 111px;
    width: 79px;
    left: -75px;
    bottom: 10px;
  } */

.l_sec_added_1 h2 {
  font-size: 3.194vw;
  color: #016b2a;
  font-weight: 600;
  line-height: 4.722vw;
  position: relative;
  display: inline-block;

  &::before {
    content: "";
    background-image: url("/assets/img/top/sec_added_titlepa_pc_img.png");
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    height: 7.708vw;
    width: 5.486vw;
    left: -5.208vw;
    bottom: 0.694vw;
  }

  &::after {
    content: "";
    background-image: url("/assets/img/top/sec_added_titlepa_pc_img.png");
    transform: scaleX(-1);
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    height: 111px;
    width: 79px;
    right: -75px;
    bottom: 10px;
  }
}

/* .l_sec_added_1 .u_title_note {
  font-size: 24px;
  line-height: 40px;
  font-weight: 400;
  margin: 28px 0 38px;
} */
.l_sec_added_1 .u_title_note {
  font-size: 1.667vw;
  line-height: 2.778vw;
  font-weight: 400;
  margin: 1.944vw 0 2.639vw;
}

/* .l_sec_added_1 .c_sec_content {
  margin-top: 40px;
} */
.l_sec_added_1 .c_sec_content {
  margin-top: 2.778vw;
}

/* .l_sec_added_1 .c_sec_content .u_content_title {
  color: #fff;
  font-size: 36px;
  font-weight: 600;
  display: inline-block;
  background-image: radial-gradient(circle, #F5E84B 40%, transparent 41%);
  background-size: 13px 5px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding-bottom: 7.5px;
} */
.l_sec_added_1 .c_sec_content .u_content_title {
  color: #fff;
  font-size: 2.5vw;
  font-weight: 600;
  display: inline-block;
  background-image: radial-gradient(circle, #f5e84b 40%, transparent 41%);
  background-size: 0.903vw 0.347vw;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding-bottom: 0.521vw;
}

/* .l_sec_added_1 .c_sec_content .u_content_detail {
  font-size: 24px;
  font-weight: 400;
  line-height: 40px;
  margin-top: 25px;
  color: #fff;
} */
.l_sec_added_1 .c_sec_content .u_content_detail {
  font-size: 1.667vw;
  font-weight: 400;
  line-height: 2.778vw;
  margin-top: 1.736vw;
  color: #fff;
}

.l_sec_added_2_bg {
  background: #fffcf0;
  position: relative;
  z-index: 10;
}

/* .l_sec_added_2 {
  max-width: 1050px;
  margin: 0 auto;
  padding: 200px 0 100px;
  text-align: center;
  margin-top: -100px;
} */
.l_sec_added_2 {
  max-width: 72.917vw;
  margin: 0 auto;
  padding: 13.889vw 0 6.944vw;
  text-align: center;
  margin-top: -6.944vw;
}

/* .l_sec_added_2 h2 {
  font-size: 46px;
  color: #000000;
  font-weight: 600;
  line-height: 68px;
  position: relative;
  display: inline;
  background-image: linear-gradient(#F5E84B, #F5E84B);
  background-repeat: repeat-x;
  background-size: 100% 22px;
  background-position: 0 100%;

  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;

  &::after {
    content: "";
    background-image: url("/assets/img/top/sec_2_titlepa_pc_img.png");
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    height: 161px;
    width: 141px;
    right: -148px;
    bottom: -31px;
  }
} */
.l_sec_added_2 h2 {
  font-size: 3.194vw;
  color: #000000;
  font-weight: 600;
  line-height: 4.722vw;
  position: relative;
  display: inline;
  background-image: linear-gradient(#f5e84b, #f5e84b);
  background-repeat: repeat-x;
  background-size: 100% 22px;
  background-position: 0 100%;

  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;

  &::after {
    content: "";
    background-image: url("/assets/img/top/sec_2_titlepa_pc_img.png");
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    height: 11.181vw;
    width: 9.792vw;
    right: -10.278vw;
    bottom: -2.153vw;
  }
}

/* .l_sec_added_2 .l_flex_img {
  margin-top: 42px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
} */
.l_sec_added_2 .l_flex_img {
  margin-top: 2.917vw;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.083vw;
}

/* .l_sec_added_2 .l_flex_img .c_flex_content {
  border-radius: 20px;
  overflow: hidden;
  background: #fff;
  padding-top: 13px;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.25);
} */
.l_sec_added_2 .l_flex_img .c_flex_content {
  border-radius: 1.389vw;
  overflow: hidden;
  background: #fff;
  padding-top: 0.903vw;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.25);
}

/* .l_sec_added_2 .l_flex_img .c_flex_content .u_title {
  font-size: 20px;
  font-weight: 600;
  line-height: 30px;
  margin-bottom: 13px;
} */
.l_sec_added_2 .l_flex_img .c_flex_content .u_title {
  font-size: 1.389vw;
  font-weight: 600;
  line-height: 2.083vw;
  margin-bottom: 0.903vw;
}

/* .l_sec_added_2 .c_sec_content {
  margin-top: 40px;
} */
.l_sec_added_2 .c_sec_content {
  margin-top: 2.778vw;
}

/* .l_sec_added_2 .c_sec_content .u_content_title {
  margin-bottom: 40px;
  color: #016B2A;
  font-size: 40px;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  gap: 0 8px;

  &::before,
  &::after {
    content: "";
    width: 42px;
    height: 37px;
    background: url("../img/top/heading01_icon.png") no-repeat center / contain;
  }
}

.l_sec_added_2 .c_sec_content .u_content_detail {
  font-size: 24px;
  font-weight: 400;
  line-height: 40px;
  margin-top: 18px;
  color: #000000
} */
.l_sec_added_2 .c_sec_content .u_content_title {
  margin-bottom: 2.778vw;
  color: #016b2a;
  font-size: 2.778vw;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  gap: 0 0.556vw;

  &::before,
  &::after {
    content: "";
    width: 2.917vw;
    height: 2.569vw;
    background: url("../img/top/heading01_icon.png") no-repeat center / contain;
  }
}

.l_sec_added_2 .c_sec_content .u_content_detail {
  font-size: 1.667vw;
  font-weight: 400;
  line-height: 2.778vw;
  margin-top: 1.25vw;
  color: #000000;
}

.l_sec_added_3_bg {
  background: #fffcf0;
}

.l_sec_added_3 {
  max-width: 1040px;
  margin: 0 auto;
  padding: 100px 0 100px;
  text-align: center;

  h2 {
    font-size: 46px;
    color: #016b2a;
    font-weight: 600;
    line-height: 68px;
    position: relative;
    display: inline-block;
  }

  .l_sec_added_3_1 {
    margin-bottom: 100px;

    .l_flex_box {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 40px;
      margin-top: 70px;

      .l_flex_content {
        position: relative;

        .point_num {
          position: absolute;
          padding: 9px 12px;
          background: #f06f66;
          border-radius: 50px;
          color: #fff;
          font-size: 18px;
          font-weight: 500;
          display: flex;
          align-items: center;
          left: 50%;
          transform: translate(-50%, -50%);
          top: 0;

          .num {
            font-size: 32px;
          }
        }

        .c_flex_content {
          border-radius: 20px;
          overflow: hidden;
          height: 506px;
          background: #fff;
          box-shadow: 0 0 15px rgba(0, 0, 0, 0.35);

          img {
          }

          .u_title {
            font-size: 28px;
            font-weight: 600;
            margin-top: 16px;
            color: #016b2a;
            padding: 0 20px;
          }

          .u_detail {
            text-align: left;
            font-size: 20px;
            line-height: 30px;
            font-weight: 400;
            line-height: 30px;
            margin-top: 11px;
            padding: 0 20px;
          }
        }

        .c_flex_content_note {
          text-align: left;
          font-size: 18px;
          font-weight: 400;
          margin-top: 18px;
        }
      }
    }
  }

  .l_sec_added_3_2 {
    .l_content_box_1 {
      background: #fff;
      padding: 40px 60px;
      border: 3px solid #016b2a;
      border-radius: 20px;

      .u_content_title {
        color: #016b2a;
        font-size: 40px;
        font-weight: 600;

        span {
          font-size: 24px;
        }
      }

      .l_flex_box {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
        margin-top: 20px;
        /* height: 31.25vw; */

        .l_flex_content {
          border-radius: 20px;
          padding: 16px 40px 20px;

          .u_flex_content_title {
            text-align: center;
            font-size: 28px;
            font-weight: 600;
            color: #016b2a;
          }

          .u_flex_img {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 20px;
            height: 100%;
            align-items: start;

            .u_flex_img_content {
              display: flex;
              flex-direction: column;
              align-items: center;
              justify-content: center;

              img {
                width: 154px;
              }

              ul {
                text-align: left;
                /* list-style-type: square; */

                li {
                  position: relative;
                }

                li::before {
                  /* list-style-type: square; */
                  position: absolute;
                  content: "・";
                  /* margin-left: 20px; */
                  left: -13px;
                }
              }

              ul.l_service_lists {
                padding-left: 38px;

                li {
                  white-space: nowrap;
                }
              }

              ul.r_service_lists {
                padding-left: 10px;
              }

              .u_flex_img_content_text {
                height: unset;
                margin-top: 7px;
                text-align: center;
                font-size: 20px;
                font-weight: 400;
                line-height: 30px;

                span {
                  font-size: 18px;
                  line-height: 20px;
                  display: flex;
                  justify-content: flex-start;
                }
              }
            }
          }
        }

        .l_flex_content_1 {
          background: #e4f2ec;
          display: flex;
          flex-direction: column;
          justify-content: center;
          gap: 20px;
        }

        .l_flex_content_2 {
          background: #fff88e;
        }
      }

      .u_spec_text_line {
        margin-top: 30px;
        font-size: 28px;
        font-weight: 600;
        display: flex;
        justify-content: center;
        align-items: flex-end;

        .green_bg_text {
          font-size: 20px;
          color: #fff;
          background: #016b2a;
          padding: 5px 10px;
          border-radius: 20px;
          margin-right: 5px;
        }

        .text_lx {
          font-size: 40px;
          margin-left: 40px;
        }

        .text_lxx {
          font-size: 80px;
          color: #016b2a;
          line-height: 60px;
        }

        .col_text {
          display: flex;
          flex-direction: column;
        }

        .text_sm {
          font-size: 20px;
        }

        .text_l {
          font-size: 28px;
        }
      }

      .u_spec_text_note_line {
        margin-top: 20px;
        font-size: 20px;
        font-weight: 400;
      }

      .normail_text {
        margin-top: 20px;
        text-align: left;
        font-size: 18px;
        font-weight: 400;
        line-height: 30px;
      }
    }
  }
}

/* .l_sec_added_3 {
  max-width: 72.222vw;
  margin: 0 auto;
  padding: 6.944vw 0 6.944vw;
  text-align: center;

  h2 {
    font-size: 3.194vw;
    color: #016B2A;
    font-weight: 600;
    line-height: 4.722vw;
    position: relative;
    display: inline-block;
  }

  .l_sec_added_3_1 {
    margin-bottom: 6.944vw;

    .l_flex_box {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 2.778vw;
      margin-top: 4.861vw;

      .l_flex_content {
        position: relative;

        .point_num {
          position: absolute;
          padding: 0.625vw 0.833vw;
          background: #F06F66;
          border-radius: 3.472vw;
          color: #fff;
          font-size: 1.25vw;
          font-weight: 500;
          display: flex;
          align-items: center;
          left: 50%;
          transform: translate(-50%, -50%);
          top: 0;

          .num {
            font-size: 2.222vw;
          }
        }

        .c_flex_content {
          border-radius: 1.389vw;
          overflow: hidden;
          height: 100%;
          background: #fff;
          box-shadow: 0 0 15px rgba(0, 0, 0, 0.35);

          .u_title {
            font-size: 1.944vw;
            font-weight: 600;
            margin-top: 1.111vw;
            color: #016B2A;
            padding: 0 1.389vw;
          }

          .u_detail {
            text-align: left;
            font-size: 1.389vw;
            line-height: 2.083vw;
            font-weight: 400;
            line-height: 2.083vw;
            margin-top: 0.764vw;
            padding: 0 1.389vw;
          }

          a {
            padding: 0 1.389vw;
            display: block;
          }

        }

        .c_flex_content_note {
          text-align: left;
          font-size: 1.25vw;
          font-weight: 400;
          margin-top: 1.25vw;
        }
      }
    }
  }

  .l_sec_added_3_2 {

    .l_content_box_1 {
      background: #fff;
      padding: 2.778vw 4.167vw;
      border: 3px solid #016B2A;
      border-radius: 1.389vw;

      .u_content_title {
        color: #016B2A;
        font-size: 2.778vw;
        font-weight: 600;

        span {
          font-size: 1.667vw;
        }
      }

      .l_flex_box {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 1.389vw;
        margin-top: 1.389vw;

        .l_flex_content {
          border-radius: 1.389vw;
          padding: 1.111vw 2.778vw 1.389vw;

          .u_flex_content_title {
            text-align: center;
            font-size: 1.944vw;
            font-weight: 600;
            color: #016B2A;
          }

          .u_flex_img {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1.389vw;

            .u_flex_img_content {
              display: flex;
              flex-direction: column;
              align-items: center;
              justify-content: center;

              img {
                width: 10.694vw;
              }

              .u_flex_img_content_text {
                height: 6.25vw;
                margin-top: 0.486vw;
                text-align: center;
                font-size: 1.389vw;
                font-weight: 400;
                line-height: 2.083vw;

                span {
                  font-size: 1.25vw;
                  line-height: 1.389vw;
                  display: flex;
                  justify-content: flex-start;
                }
              }
            }
          }
        }

        .l_flex_content_1 {
          background: #E4F2EC;
        }

        .l_flex_content_2 {
          background: #FFF88E;
        }
      }

      .u_spec_text_line {
        margin-top: 2.083vw;
        font-size: 1.944vw;
        font-weight: 600;
        display: flex;
        justify-content: center;
        /* align-items: center; */
/* align-items: flex-end; */

.green_bg_text {
  font-size: 1.389vw;
  color: #fff;
  background: #016b2a;
  padding: 0.347vw 0.694vw;
  border-radius: 1.389vw;
  margin-right: 0.347vw;
}

.text_lx {
  font-size: 2.778vw;
  margin-left: 2.778vw;
}

.text_lxx {
  font-size: 5.556vw;
  color: #016b2a;
  line-height: 4.167vw;
}

.col_text {
  display: flex;
  flex-direction: column;
}

.text_sm {
  font-size: 1.389vw;
}

.text_l {
  font-size: 1.944vw;
}

.u_spec_text_note_line {
  margin-top: 1.389vw;
  font-size: 1.389vw;
  font-weight: 400;
}

.normail_text {
  margin-top: 1.389vw;
  text-align: left;
  font-size: 1.25vw;
  font-weight: 400;
  line-height: 2.083vw;
}

/* .l_sec_link {
  background: url("../img/top/cta_bg_green.png") no-repeat center / cover;
  padding: 78px 30px 52px;

  .c_sec_link {
    margin: 0 auto;
    max-width: 1040px;
    display: flex;
    flex-flow: row wrap;
    gap: 0 28px;
    justify-content: center;

    .l_ta_contact {
      padding: 32px 30px 22px;
      background: #fff;
      border-radius: 20px;
      position: relative;
      text-align: center;

      .fukidashi_note {
        font-size: 28px;
      }

      .fukidashi {
        margin-bottom: 31px;
        font-size: 40px;
        font-weight: 700;
        text-align: center;
        line-height: 1.45;
      }

      .l_link_box {
        display: flex;
        align-items: stretch;
        gap: 20px;

        .u_link_contact {
          background: linear-gradient(to bottom, #f06f66 0%, #ff3a2b 100%);
          border-radius: 999px;
          border: 3px solid #fff;
          color: #fff;
          font-size: 24px;
          box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
          position: relative;
          display: inline-block;
          padding: 30px 81px 20px 31px;
          line-height: 36px;

          .badge {
            position: absolute;
            top: -17px;
            left: 50%;
            transform: translateX(-50%);
            padding: 5px 20px;
            background: #016B2A;
            color: #FFF33F;
            font-size: 18px;
            border-radius: 21px;
            line-height: 1;
            white-space: nowrap;
            z-index: 2;
            box-sizing: border-box;
            border: 3px solid #fff;
            display: flex;
            align-items: center;
            justify-content: center;
          }

          .second-badge {
            font-size: 22px;
            padding: 0 1px;
          }

          .button-text {}

          .button_text_lage {
            font-size: 34px;
          }

          &::after {
            content: "";
            width: 34px;
            height: 34px;
            background: url(../img/top/cta_btn_arrow_orange.png) no-repeat center / contain;
            background-repeat: no-repeat;
            background-size: contain;
            position: absolute;
            right: 20px;
            top: 50%;
            transform: translateY(-50%);
          }
        }

        .u_link_line {
          background: linear-gradient(to bottom, #03C755 0%, #03C755 100%);
          border-radius: 999px;
          border: 3px solid #fff;
          color: #fff;
          font-size: 24px;
          box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
          position: relative;
          display: flex;
          align-items: center;
          padding: 11px 28px;
          line-height: 36px;

          .line_icon {
            width: 58px;
            height: 58px;
          }

          p {
            text-align: left;
            margin-left: 7px;
          }

          .right_arrow {
            width: 34px;
            height: 34px;
            margin-left: 21px;
          }
        }
      }

      .attention {
        margin-top: 6px;
        font-size: 18px;
        font-weight: 400;
        text-align: center;
        line-height: 1.45;
      }
    }
  }
} */
.l_sec_link {
  background: url("../img/top/cta_bg_green.png") no-repeat center / cover;
  padding: 5.417vw 2.083vw 3.611vw;

  .c_sec_link {
    margin: 0 auto;
    max-width: 72.222vw;
    display: flex;
    flex-flow: row wrap;
    gap: 0 1.944vw;
    justify-content: center;

    .l_ta_contact {
      padding: 2.222vw 2.083vw 1.528vw;
      background: #fff;
      border-radius: 1.389vw;
      position: relative;
      text-align: center;

      .fukidashi_note {
        font-size: 1.944vw;
      }

      .fukidashi {
        margin-bottom: 2.153vw;
        font-size: 2.778vw;
        font-weight: 700;
        text-align: center;
        line-height: 1.45;
      }

      .l_link_box {
        display: flex;
        align-items: center;
        gap: 1.389vw;
        justify-content: center;
        padding: 0 80px;

        .u_link_contact {
          /* background: linear-gradient(to bottom, #f06f66 0%, #ff3a2b 100%);
          border-radius: 69.375vw;
          border: 3px solid #fff;
          color: #fff;
          font-size: 1.667vw;
          box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
          position: relative;
          display: inline-block;
          padding: 2.083vw 5.625vw 1.389vw 2.153vw;
          line-height: 2.5vw; */

          /* .badge {
            position: absolute;
            top: -1.181vw;
            left: 50%;
            transform: translateX(-50%);
            padding: 0.347vw 1.389vw;
            background: #016B2A;
            color: #FFF33F;
            font-size: 1.25vw;
            border-radius: 1.458vw;
            line-height: 1;
            white-space: nowrap;
            z-index: 2;
            box-sizing: border-box;
            border: 3px solid #fff;
            display: flex;
            align-items: center;
            justify-content: center;
          }

          .second-badge {
            font-size: 1.528vw;
            padding: 0 0.069vw;
          }

          .button-text {}

          .button_text_lage {
            font-size: 2.361vw;
          }

          &::after {
            content: "";
            width: 2.361vw;
            height: 2.361vw;
            background: url(../img/top/cta_btn_arrow_orange.png) no-repeat center / contain;
            background-repeat: no-repeat;
            background-size: contain;
            position: absolute;
            right: 1.389vw;
            top: 50%;
            transform: translateY(-50%);
          } */
        }

        .u_link_line {
          background: linear-gradient(to bottom, #03c755 0%, #03c755 100%);
          border-radius: 69.375vw;
          border: 3px solid #fff;
          color: #fff;
          font-size: 1.667vw;
          box-shadow: 0 0 4px rgba(44, 44, 44, 0.18);
          position: relative;
          display: flex;
          align-items: center;
          padding: 0.764vw 1.944vw;
          line-height: 2.5vw;

          .line_icon {
            width: 4.028vw;
            height: 4.028vw;
          }

          p {
            text-align: left;
            margin-left: 0.486vw;
          }

          .right_arrow {
            width: 2.361vw;
            height: 2.361vw;
            margin-left: 1.458vw;
          }
        }
      }

      .attention {
        margin-top: 0.417vw;
        font-size: 1.25vw;
        font-weight: 400;
        text-align: center;
        line-height: 1.45;
      }
    }
  }
}

/* .management {
  padding: 100px 30px;
  background: #FFFCF0;
}

.management_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.management_image {
  margin-bottom: 82px;
}

.management_list {
  margin-bottom: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 0 32px;
} */
.management {
  padding: 6.944vw 2.083vw;
  background: #fffcf0;
}

.management_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.management_image {
  margin-bottom: 5.694vw;
}

.management_list {
  margin-bottom: 2.778vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 0 2.222vw;
}

/* .management_list>li {
  width: calc(50% - 16px);
}

.management_list>li:nth-child(1) {
  position: relative;
}

.management_list>li:nth-child(1)::before {
  margin-top: 120px;
  content: "";
  width: 3px;
  height: calc(100% - 120px);
  background: url("../img/top/boreder_dots.png") no-repeat;
  background-repeat: repeat-y;
  background-position: top center;
  background-size: contain;
  position: absolute;
  top: 0;
  right: -19px;
} */
.management_list > li {
  width: calc(50% - 1.111vw);
}

.management_list > li:nth-child(1) {
  position: relative;
}

.management_list > li:nth-child(1)::before {
  margin-top: 8.333vw;
  content: "";
  width: 0.208vw;
  height: calc(100% - 8.333vw);
  background: url("../img/top/boreder_dots.png") no-repeat;
  background-repeat: repeat-y;
  background-position: top center;
  background-size: contain;
  position: absolute;
  top: 0;
  right: -1.319vw;
}

.management_list > li:nth-child(2) .title {
  border-top: 3px solid #009f4c;
  border-bottom: 3px solid #009f4c;
  color: #009f4c;
}

.management_list > li:nth-child(2) .title span {
  background: #009f4c;
}

.management_list > li:nth-child(2) .price dl dt,
.management_list > li:nth-child(2) .price dl dd {
  border: 4px solid #009f4c;
}

.management_list > li:nth-child(2) .price dl dt {
  color: #009f4c;
}

.management_list > li:nth-child(2) .price dl dd {
  background: #009f4c;
}

.management_list > li:nth-child(2) .desc {
  margin-bottom: 1.944vw;
}

/* .management_list>li:nth-child(2) .image {
  margin-bottom: 10px;
} */
.management_list > li:nth-child(2) .image {
  margin-bottom: 0.694vw;
}

/* 
.management_list>li .title {
  margin-bottom: 28px;
  padding: 20px 10px 10px;
  border-top: 3px solid #F06F66;
  border-bottom: 3px solid #F06F66;
  color: #F06F66;
  font-size: 48px;
  font-weight: 800;
  text-align: center;
  position: relative;
}

.management_list>li .title span {
  padding: 4px 16px 5px;
  background: #F06F66;
  border-radius: 999px;
  color: #fff;
  font-size: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
} */
.management_list > li .title {
  margin-bottom: 1.944vw;
  padding: 1.389vw 0.694vw 0.694vw;
  border-top: 3px solid #f06f66;
  border-bottom: 3px solid #f06f66;
  color: #f06f66;
  font-size: 3.333vw;
  font-weight: 800;
  text-align: center;
  position: relative;
}

.management_list > li .title span {
  padding: 0.278vw 1.111vw 0.347vw;
  background: #f06f66;
  border-radius: 69.375vw;
  color: #fff;
  font-size: 1.389vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

/* .management_list>li .title span:before {
  content: "";
  width: calc(100% - 5px);
  height: calc(100% - 4px);
  border: 1px solid #fff;
  border-radius: 999px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
} */
.management_list > li .title span:before {
  content: "";
  width: calc(100% - 0.347vw);
  height: calc(100% - 0.278vw);
  border: 1px solid #fff;
  border-radius: 69.375vw;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

/* .management_list>li .image {
  margin-bottom: 4px;
}

.management_list>li .desc {
  margin-bottom: 16px;
  font-size: 20px;
  line-height: 1.45;
}

.management_list>li .box {
  margin-bottom: 24px;
} */
.management_list > li .image {
  margin-bottom: 0.278vw;
}

.management_list > li .desc {
  margin-bottom: 1.111vw;
  font-size: 1.389vw;
  line-height: 1.45;
}

.management_list > li .box {
  margin-bottom: 1.667vw;
}

/* .management_list>li .price dl {
  margin-bottom: 12px;
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  overflow: hidden;
} */
.management_list > li .price dl {
  margin-bottom: 0.833vw;
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  overflow: hidden;
}

/* .management_list>li .price dl dt,
.management_list>li .price dl dd {
  padding: 11px 6px;
  font-size: 24px;
  font-weight: 700;
  border: 4px solid #F06F66;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.management_list>li .price dl dt {
  color: #F06F66;
  width: 150px;
  border-right: none;
  border-radius: 999px 0 0 999px;
}

.management_list>li .price dl dd {
  width: calc(100% - 150px);
  background: #F06F66;
  border-radius: 0 999px 999px 0;
  border-left: none;
  color: #fff;
}

.management_list>li .price dl dd span {
  letter-spacing: -0.27em;
}

.management_list>li .price p {
  margin-bottom: 25px;
  text-align: center;
}

.management_list>li .price p .text {
  margin-right: 10px;
  font-size: 20px;
}

.management_list>li .price p .number {
  font-family: "poppins", sans-serif;
  font-size: 40px;
  font-weight: 800;
}

.management_list>li .price p .tax {
  font-size: 20px;
  font-weight: 700;
}

.management_list>li .price ul {
  font-size: 16px;
  line-height: 1.375;
}

.management_box {
  padding: 40px 20px 20px;
  background: #fff;
  border-radius: 20px;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}

.management_box picture {
  margin: 0 auto;
  max-width: 972px;
}

.management_box .attention {
  margin-top: 16px;
  display: block;
  font-size: 16px;
  text-align: right;
}

.flow {
  padding: 0 30px 0;
  background: #FFFCF0;
}

.flow_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.flow_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 0 40px;
}

.flow_list>li {
  width: calc(25% - 30px);
  position: relative;
}

.flow_list>li:not(:last-child)::before {
  content: "";
  width: 37px;
  height: 53px;
  background: url("../img/top/flow_list_icon_arrow.png") no-repeat center/contain;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(100%, -50%);
  transform: translate(100%, -50%);
} */
.management_list > li .price dl dt,
.management_list > li .price dl dd {
  padding: 0.764vw 0.417vw;
  font-size: 1.667vw;
  font-weight: 700;
  border: 4px solid #f06f66;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.management_list > li .price dl dt {
  color: #f06f66;
  width: 10.417vw;
  border-right: none;
  border-radius: 69.375vw 0 0 69.375vw;
}

.management_list > li .price dl dd {
  width: calc(100% - 10.417vw);
  background: #f06f66;
  border-radius: 0 69.375vw 69.375vw 0;
  border-left: none;
  color: #fff;
}

.management_list > li .price dl dd span {
  letter-spacing: -0.27em;
}

.management_list > li .price p {
  margin-bottom: 1.736vw;
  text-align: center;
}

.management_list > li .price p .text {
  margin-right: 0.694vw;
  font-size: 1.389vw;
}

.management_list > li .price p .number {
  font-family: "poppins", sans-serif;
  font-size: 2.778vw;
  font-weight: 800;
}

.management_list > li .price p .tax {
  font-size: 1.389vw;
  font-weight: 700;
}

.management_list > li .price ul {
  font-size: 1.111vw;
  line-height: 1.375;
}

.management_box {
  padding: 2.778vw 1.389vw 1.389vw;
  background: #fff;
  border-radius: 1.389vw;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}

.management_box picture {
  margin: 0 auto;
  max-width: 67.5vw;
}

.management_box .attention {
  margin-top: 1.111vw;
  display: block;
  font-size: 1.111vw;
  text-align: right;
}

.flow {
  padding: 0 2.083vw 0;
  background: #fffcf0;
}

.flow_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.flow_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  /* -ms-flex-flow: row wrap;
  flex-flow: row wrap; */
  gap: 0 2.778vw;
  padding-bottom: 100px;
}

.flow_list > li {
  width: calc(25% - 2.083vw);
  position: relative;
}

.flow_list > li:not(:last-child)::before {
  content: "";
  width: 2.569vw;
  height: 3.681vw;
  background: url("../img/top/flow_list_icon_arrow.png") no-repeat
    center/contain;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(100%, -50%);
  transform: translate(100%, -50%);
}

.flow_list > li a {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

/* .other {
  padding: 100px 30px;
}

.other_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.other_content {
  padding: 52px 20px;
  background: #F7F7F7;
  border-radius: 30px;
}

.other_content .title01 {
  margin-bottom: 28px;
  font-size: 35px;
  line-height: 1.48;
  font-weight: 800;
  text-align: center;
} */
.other {
  padding: 6.944vw 2.083vw;
}

.other_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.other_content {
  padding: 3.611vw 1.389vw;
  background: #f7f7f7;
  border-radius: 2.083vw;
}

.other_content .title01 {
  margin-bottom: 1.944vw;
  font-size: 2.431vw;
  line-height: 1.48;
  font-weight: 800;
  text-align: center;
}

/* .other_content>.desc {
  margin-bottom: 69px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}

.other_content .box01 {
  max-width: 900px;
  margin: 0 auto;
  padding: 63px 40px;
  background: #fff;
  border-radius: 20px 20px 0 0;
  position: relative;
}

.other_content .box01>h3 {
  padding: 12px 46px;
  background: #009F4C;
  border: 3px solid #fff;
  border-radius: 999px;
  color: #fff;
  font-size: 30px;
  font-weight: 800;
  white-space: nowrap;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.other_content .box01 .column {
  margin-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
} */
.other_content > .desc {
  margin-bottom: 4.792vw;
  font-size: 1.944vw;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}

.other_content .box01 {
  max-width: 62.5vw;
  margin: 0 auto;
  padding: 4.375vw 2.778vw;
  background: #fff;
  border-radius: 1.389vw 1.389vw 0 0;
  position: relative;
}

.other_content .box01 > h3 {
  padding: 0.833vw 3.194vw;
  background: #009f4c;
  border: 3px solid #fff;
  border-radius: 69.375vw;
  color: #fff;
  font-size: 2.083vw;
  font-weight: 800;
  white-space: nowrap;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.other_content .box01 .column {
  margin-bottom: 2.083vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.other_content .box01 .column .primary {
  width: 43.22%;
}

/* .other_content .box01 .column .primary .desc {
  font-size: 20px;
  line-height: 1.45;
} */
.other_content .box01 .column .primary .desc {
  font-size: 1.389vw;
  line-height: 1.45;
}

.other_content .box01 .column .primary .price {
  color: #009f4c;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* .other_content .box01 .column .primary .price .label {
  margin-right: 4px;
  padding: 4px 6px;
  border: 1px solid #009F4C;
  font-size: 20px;
} */
.other_content .box01 .column .primary .price .label {
  margin-right: 0.278vw;
  padding: 0.278vw 0.417vw;
  border: 1px solid #009f4c;
  font-size: 1.389vw;
}

/* .other_content .box01 .column .primary .price .number {
  font-family: "Poppins", sans-serif;
  font-size: 47px;
  font-weight: 800;
} */
.other_content .box01 .column .primary .price .number {
  font-family: "Poppins", sans-serif;
  font-size: 3vw;
  font-weight: 800;
}

/* .other_content .box01 .column .primary .price .tax {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.05em;
} */
.other_content .box01 .column .primary .price .tax {
  font-size: 1.389vw;
  font-weight: 800;
  letter-spacing: -0.05em;
}

/* .other_content .box01 .column .primary .attention {
  font-size: 16px;
  line-height: 1.375;
} */
.other_content .box01 .column .primary .attention {
  font-size: 1.111vw;
  line-height: 1.375;
}

.other_content .box01 .column .secondary {
  width: 54.33%;
}

/* .other_content .box01 .image {
  margin-bottom: 29px;
} */
.other_content .box01 .image {
  margin-bottom: 2.014vw;
}

/* .other_content .box01 .buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 0 36px;
} */
.other_content .box01 .buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 0 2.5vw;
}

/* .other_content .box01 .buttons .logo {
  width: 218px;
} */
.other_content .box01 .buttons .logo {
  width: 15.139vw;
}

.other_content .box01 .buttons .button01 {
  background: #009f4c;
}

.other_content .box01 .buttons .button01::after {
  background: url("../img/top/botton01_arrow_green.png") no-repeat
    center/contain;
}

.other_content .box02 {
  max-width: 62.5vw;
  margin: 0 auto;
  padding: 2.778vw;
  background: url("../img/top/other_box02_bg.png") no-repeat center/cover;
  border-radius: 0 0 1.389vw 1.389vw;
}

.other_content .box02 .list {
  margin-bottom: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 0 20px;
}

.other_content .box02 .list li {
  width: calc(50% - 10px);
  padding: 20px 28px;
  background: #fff;
  border-radius: 20px;
  border: 3px solid #ea5532;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
}

.other_content .box02 .list li:nth-child(2) {
  border: 3px solid #009fb9;
}

.other_content .box02 .list li:nth-child(2) h4 {
  color: #009fb9;
}

.other_content .box02 .list li:nth-child(2) figure {
  width: 210px;
}

.other_content .box02 .list li:nth-child(2) .button01 {
  background: #009fb9;
}

.other_content .box02 .list li:nth-child(2) .button01::before {
  background: url("../img/top/button01_arrow_blue.png") no-repeat center/contain;
}

.other_content .box02 .list li h4 {
  margin-bottom: 12px;
  color: #ea5532;
  font-size: 20px;
  font-weight: 800;
  text-align: center;
}

.other_content .box02 .list li p {
  margin-bottom: 16px;
  font-size: 16px;
  line-height: 1.5;
}

.other_content .box02 .list li figure {
  margin: auto auto 8px;
  width: 189px;
}

.other_content .box02 .list li .button01 {
  margin: auto auto 0;
  background: #ea5532;
}

.other_content .box02 .list li .button01::before {
  background: url("../img/top/button01_arrow_orange.png") no-repeat
    center/contain;
}

.other_content .box02 .attention {
  font-size: 16px;
  line-height: 1.375;
}

/* .other_content {

  .box02 {

    .l_box_content {
      background: #fff;
      padding: 40px;
      border: 3px solid #D6007F;
      border-radius: 20px;
      text-align: center;

      .u_box_title {
        font-size: 36px;
        font-weight: 700;
        color: #D6007F;
      }

      .u_title_note {
        margin-top: 10px;
        font-size: 24px;
        font-weight: 400;
        line-height: 40px;
        margin-bottom: 16px;
      }

      .u_box_img {
        max-width: 374px;
        margin: 0 auto;
        display: block;
      }

      .u_link {
        margin-top: 23px;
        background: #D6007F;
        border: 2px solid #fff;
        box-shadow: 0 0 15px rgba(0, 0, 0, 0.35);
        color: #fff;
        padding: 14px 45px;
        border-radius: 60px;
        display: inline-block;
        position: relative;

        &::after {
          content: "";
          background-image: url("/assets/img/top/right_orange_arrow.png");
          background-repeat: no-repeat;
          background-size: contain;
          height: 26px;
          width: 26px;
          position: absolute;
          top: 50%;
          transform: translateY(-50%);
          right: 10px;
        }
      }
    }
  }
}

.voice {
  background: #FFFCF0;
  padding: 100px 30px;
}

.voice_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.voice_list {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 36px;
}

.voice_list li {
  padding: 28px;
  width: calc(50% - 18px);
  background: #fff;
  border-radius: 20px;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}

.voice_list li .head {
  margin-bottom: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0 19px;
}

.voice_list li .head figure {
  width: 134px;
}

.voice_list li .head .content {
  width: calc(100% - 134px - 19px);
}

.voice_list li .head .content h3 {
  margin-bottom: 6px;
  color: #F06F66;
  font-size: 22px;
  font-weight: 800;
}

.voice_list li .head .content p {
  font-size: 16px;
}

.voice_list li .desc {
  font-size: 16px;
  line-height: 1.5;
}

.faq {
  background: #FFFCF0;
  padding: 0 30px 100px;
}

.faq_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.faq_list {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
}

.faq_list dt {
  margin-bottom: 10px;
  position: relative;
  cursor: pointer;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.faq_list dt:hover {
  opacity: 0.8;
}

.faq_list dt::before,
.faq_list dt::after {
  content: "";
  width: 30px;
  height: 6px;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 28px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  z-index: 1;
}

.faq_list dt::after {
  -webkit-transform: translate(0, -50%) rotate(90deg);
  transform: translate(0, -50%) rotate(90deg);
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.faq_list dt.is-open::after {
  opacity: 0;
}

.faq_list dt p {
  padding: 27px 20px 27px 77px;
  background: #F06F66;
  font-size: 20px;
  color: #fff;
  border-radius: 20px;
  position: relative;
}

.faq_list dt p::before {
  content: "Q";
  font-family: "Poppins", sans-serif;
  font-size: 48px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 27px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

.faq_list dd {
  display: none;
  margin-bottom: 28px;
  padding: 27px;
  background: #fff;
  font-size: 18px;
  font-weight: 700;
  border-radius: 20px;
  line-height: 1.33;
}

.useful {
  padding: 100px 30px;
}

.useful_inner {
  margin: 0 auto;
  max-width: 1040px;
}

.useful_list {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 36px 28px;
}

.useful_list li {
  width: calc(33.33% - 18.6666666667px);
}

.useful_list li a figure {
  margin-bottom: 10px;
  border-radius: 10px;
}

.useful_list li a time {
  margin-bottom: 4px;
  display: block;
  font-family: "Poppins", sans-serif;
  font-size: 12px;
}

.useful_list li a h3 {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.31;
}

.float-banner {
  width: 218px;
  height: 108px;
  position: fixed;
  bottom: 24px;
  right: 24px;
  -webkit-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  z-index: 1000;
  pointer-events: none;
} */
.other_content {
  .box02 {
    .l_box_content {
      background: #fff;
      padding: 2.778vw;
      border: 3px solid #d6007f;
      border-radius: 1.389vw;
      text-align: center;

      .u_box_title {
        font-size: 2.5vw;
        font-weight: 700;
        color: #d6007f;
      }

      .u_title_note {
        margin-top: 0.694vw;
        font-size: 1.667vw;
        font-weight: 400;
        line-height: 2.778vw;
        margin-bottom: 1.111vw;
        /* color: #016b2a; */
      }

      .u_box_img {
        max-width: 25.972vw;
        margin: 0 auto;
        display: block;
      }

      .u_link {
        margin-top: 23px;
        display: block;

        img {
          max-width: 14.583vw;
          width: 100%;
        }

        /* background: #D6007F;
        border: 2px solid #fff;
        box-shadow: 0 0 15px rgba(0, 0, 0, 0.35);
        color: #fff;
        padding: 0.972vw 3.125vw;
        border-radius: 4.167vw;
        display: inline-block;
        position: relative; */

        /* &::after {
          content: "";
          background-image: url("/assets/img/top/right_orange_arrow.png");
          background-repeat: no-repeat;
          background-size: contain;
          height: 1.806vw;
          width: 1.806vw;
          position: absolute;
          top: 50%;
          transform: translateY(-50%);
          right: 0.694vw;
        } */
      }
    }
  }
}

.voice {
  background: #fffcf0;
  padding: 6.944vw 2.083vw;
}

.voice_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.voice_list {
  margin-bottom: 4.167vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 2.5vw;
}

.voice_list li {
  padding: 1.944vw;
  width: calc(50% - 1.25vw);
  background: #fff;
  border-radius: 1.389vw;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}

.voice_list li .head {
  margin-bottom: 0.833vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0 1.319vw;
}

.voice_list li .head figure {
  width: 9.306vw;
}

.voice_list li .head .content {
  width: calc(100% - 9.306vw - 1.319vw);
}

.voice_list li .head .content h3 {
  margin-bottom: 0.417vw;
  color: #f06f66;
  font-size: 1.528vw;
  font-weight: 800;
}

.voice_list li .head .content p {
  font-size: 1.111vw;
}

.voice_list li .desc {
  font-size: 1.111vw;
  line-height: 1.5;
}

.faq {
  background: #fffcf0;
  padding: 0 2.083vw 6.944vw;
}

.faq_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.faq_list {
  margin-bottom: 4.167vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
}

.faq_list dt {
  margin-bottom: 0.694vw;
  position: relative;
  cursor: pointer;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.faq_list dt:hover {
  opacity: 0.8;
}

.faq_list dt::before,
.faq_list dt::after {
  content: "";
  width: 2.083vw;
  height: 0.417vw;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 1.944vw;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  z-index: 1;
}

.faq_list dt::after {
  -webkit-transform: translate(0, -50%) rotate(90deg);
  transform: translate(0, -50%) rotate(90deg);
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.faq_list dt.is-open::after {
  opacity: 0;
}

.faq_list dt p {
  padding: 1.875vw 1.389vw 1.875vw 5.347vw;
  background: #f06f66;
  font-size: 1.389vw;
  color: #fff;
  border-radius: 1.389vw;
  position: relative;
}

.faq_list dt p::before {
  content: "Q";
  font-family: "Poppins", sans-serif;
  font-size: 3.333vw;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 1.875vw;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

.faq_list dd {
  display: none;
  margin-bottom: 1.944vw;
  padding: 1.875vw;
  background: #fff;
  font-size: 1.25vw;
  font-weight: 700;
  border-radius: 1.389vw;
  line-height: 1.33;
}

.useful {
  padding: 6.944vw 2.083vw;
}

.useful_inner {
  margin: 0 auto;
  max-width: 72.222vw;
}

.useful_list {
  margin-bottom: 4.167vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 2.5vw 1.944vw;
}

.useful_list li {
  width: calc(33.33% - 1.296vw);
}

.useful_list li a figure {
  margin-bottom: 0.694vw;
  border-radius: 0.694vw;
}

.useful_list li a time {
  margin-bottom: 0.278vw;
  display: block;
  font-family: "Poppins", sans-serif;
  font-size: 0.833vw;
}

.useful_list li a h3 {
  font-size: 1.528vw;
  font-weight: 700;
  line-height: 1.31;
}

.float-banner {
  width: 22.139vw;
  height: 7.5vw;
  position: fixed;
  right: 1.667vw;
  bottom: 5.667vw;
  z-index: 1000;

  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.4s ease,
    transform 0.4s ease;
  pointer-events: none;
}

.float-banner.is-show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.is-hidden-fixed-banner .float-banner {
  -webkit-transform: translateX(calc(100% + 24px));
  transform: translateX(calc(100% + 24px));
}

/* edit start an */
/* .tb_price_wrap {
  background: #E4F2EC;
  border-radius: 20px;
  padding: 26px 30px;
  margin-top: 40px;
} */
.tb_price_wrap {
  background: #e4f2ec;
  border-radius: 1.389vw;
  padding: 1.806vw 2.083vw;
  margin-top: 2.778vw;
}

.tb_price_wrap .tb_price_head_content {
  display: flex;
  gap: 15px;
  padding-bottom: 20px;
  border-bottom: 2px solid #016b2a;
}

.tb_price_head_content .tb_price_head_box {
  display: flex;
  gap: 8px;
}

.tb_price_head_box img {
  width: 95px;
  height: 95px;
}

.tb_price_head_box_text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}

.tb_price_head_box_text .tb_price_head_box_text_title {
  color: #016b2a;
  font-size: 28px;
  font-family: "M PLUS 1p";
  letter-spacing: 1.68px;
  font-weight: 700;
}

.tb_price_head_box_text_title .tb_price_head_box_text_title_hasborder {
  font-size: 21px;
  padding: 2px 7px;
  background: #016b2a;
  border-radius: 6px;
  color: #ffffff;
  margin-left: 8px;
}

.tb_price_head_box_text .tb_price_head_box_text_dsc {
  font-size: 18px;
  font-family: "M PLUS 1p";
  font-weight: 500;
  text-align: left;
}

.tb_price_head_box_text_dsc .tb_price_head_box_text_dsc_stand {
  font-size: 20px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  letter-spacing: 1.2px;
  writing-mode: vertical-rl;
  text-orientation: upright;
}

.tb_price_head_box_text_dsc .tb_price_head_box_text_dsc_price {
  font-size: 56px;
  font-family: "Poppins";
  font-weight: 600;
  letter-spacing: -1.2px;
}

.tb_price_head_box_text_dsc .tb_price_head_box_text_dsc_en {
  font-size: 28px;
  font-family: "M PLUS 1p";
  font-weight: 500;
}

.tb_cost_title {
  color: #016b2a;
  font-family: "M PLUS 1p";
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 1.44px;
  text-align: left;
  margin-top: 20px;
  margin-bottom: 10px;
}

.tb_cost_content {
  background: #fdf88e;
  font-family: "M PLUS 1p";
  font-size: 24px;
  letter-spacing: 1.44px;
  font-weight: 700;
  border: 1px solid #016b2a;
}

.cost_toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.cost_box {
  background: #ffffff;
  overflow: hidden;
}

.table_wrap {
  width: 100%;
}

.cost_table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

/* .cost_table th {
  border-right: 1px solid #016B2A;
  border-bottom: 1px solid #016B2A;
  padding: 15px 12px 10px 14px;
  text-align: center;
  font-weight: 700;
  color: #0b5a2b;
  vertical-align: middle;
} */
.cost_table th {
  border-right: 1px solid #016b2a;
  border-bottom: 1px solid #016b2a;
  padding: 1.042vw 0.833vw 0.694vw 0.972vw;
  text-align: center;
  font-weight: 700;
  color: #0b5a2b;
  vertical-align: middle;
  word-wrap: break-word;
}

/* .cost_table td {
  border-right: 1px solid #016B2A;
  border-bottom: 1px solid #016B2A;
  padding: 10px 10px;
  text-align: center;
  font-weight: 700;
  color: #0b5a2b;
  font-size: 28px;
  vertical-align: middle;
} */
.cost_table td {
  border-right: 1px solid #016b2a;
  border-bottom: 1px solid #016b2a;
  padding: 0.694vw 0.694vw;
  text-align: center;
  font-weight: 700;
  color: #0b5a2b;
  font-size: 1.7vw;
  vertical-align: middle;
  word-wrap: break-word;
  white-space: nowrap;
}

.cost_table th:last-child,
.cost_table td:last-child {
  border-right: 0;
}

.cost_table .col_total {
  background: #fff799;
}

.cost_table .total_cell {
  background: #fff799;
  font-size: 1.987vw;
  letter-spacing: 0.167vw;
}

.cost_table .col_month {
  width: 139px;
}

.cost_table .col_en {
  width: 256px;
}

.dots_area {
  display: grid;
  place-items: center;
  padding: 5px 0;
}

.dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #016b2a;
  display: block;
  margin: 3px 0;
}

.table_wrap_expanded {
  max-height: 0;
  overflow: hidden;
  transition: max-height 280ms ease;
}

.table_wrap_collapsed {
  display: block;
}

.toggle_btn {
  width: 100%;
  height: 54px;
  border-radius: 28px;
  background: #0b7a36;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  cursor: pointer;
  user-select: none;
  font-size: 20px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  letter-spacing: 1.2px;
}

.toggle_icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #ffffff;
  color: #0b7a36;
  display: grid;
  place-items: center;
  font-size: 18px;
  line-height: 1;
}

.toggle_icon_minus,
.toggle_text_close {
  display: none;
}

.l_content_box_2 {
  background: #fff;
  padding: 40px 60px;
  border: 3px solid #f06f66;
  border-radius: 20px;
  margin-top: 42px;
}

.pink_content_title {
  font-size: 24px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  letter-spacing: 1.44px;
  color: #f06f66;
}

.pink_content_title_bold {
  font-size: 40px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  padding-right: 13px;
}

.col_2 {
  display: flex;
  gap: 20px;
}

.col_2 .col_2_box {
  padding: 16px 26px 26px 26px;
  border-radius: 20px;
  margin-top: 20px;
}

.col_2 .box_pink {
  background: #ffe8e6;
}

.col_2 .box_yellow {
  background: #fff88e;
}

.col_2_box .col_2_box_title {
  font-size: 28px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  color: #f06f66;
  margin-bottom: 15px;
}

.col_2_box .col_2_box_content {
  display: flex;
  gap: 20px;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-family: "M PLUS 1p";
  font-weight: 500;
  letter-spacing: 1.8px;
}

.col_2_box_content .col_2_box_content_dsc {
  text-align: left;
}

.col_2_box_content_dsc li {
  /* list-style-type: square; */
  /* margin-left: 20px; */
  position: relative;
}

.col_2_box_content_dsc li::before {
  /* list-style-type: square; */
  position: absolute;
  content: "・";
  /* margin-left: 20px; */
  left: -13px;
}

.col_2_box_content img {
  width: 154px;
  height: 154px;
}

.col_2_price {
  display: flex;
  gap: 32px;
  margin-top: 10px;
  align-items: flex-end;
  justify-content: center;
}

.col_2_price .col_2_price_txt {
  font-size: 24px;
  font-family: "M PLUS 1p";
  font-weight: 700;
  letter-spacing: 1.44px;
  padding-bottom: 16px;
}

.col_2_price_txt .col_2_price_txt_pink {
  color: #ffffff;
  background: #f06f66;
  border-radius: 21px;
  padding: 2px 10px;
}

.col_2_price .col_2_price_num_content {
  font-size: 20px;
  font-family: "M PLUS 1p";
  font-weight: 800;
  display: flex;
  gap: 9px;
  justify-content: center;
  align-items: center;
}

/* .col_2_price_num_content .col_2_price_num_content_num {
  font-size: 80px;
  font-family: "Poppins";
  font-weight: 700;
  color: #F06F66;
} */
/* .col_2_price_num_content .col_2_price_num_content_num {
  font-size: 5.556vw;
  font-family: "Poppins";
  font-weight: 700;
  color: #F06F66;
} */
.col_2_price_num_content .col_2_price_num_content_num {
  font-size: 5.556vw;
  font-family: "Poppins";
  font-weight: 700;
  color: #f06f66;
}

.col_2_price_num_content .col_2_price_num_content_txt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.col_2_price_num_content_txt .col_2_price_num_content_txt_bold {
  font-size: 28px;
}

.col_2_note_content {
  font-size: 18px;
  font-family: "M PLUS 1p";
  font-weight: 500;
  text-align: left;
  margin-top: 12px;
}

/* edit end an */

@media (max-width: 768px) {
  /* common */
  .heading01 {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 6.106870229vw;
    font-size: 28px;
    gap: 0 1.0178117048vw;
    align-items: flex-end;
  }

  .heading01::before,
  .heading01::after {
    width: 6.6157760814vw;
    height: 5.5979643766vw;
  }

  .button01,
.button_new {
    max-width: 53.4351145038vw;
    height: 13.9949109415vw;
    border: 0.7633587786vw solid #fff;
    font-size: 5.0890585242vw;
    -webkit-box-shadow: 0 0 1.0178117048vw rgba(44, 44, 44, 0.18);
    box-shadow: 0 0 1.0178117048vw rgba(44, 44, 44, 0.18);
  }

  .button01::after {
    width: 6.6157760814vw;
    height: 6.6157760814vw;
    right: 2.5445292621vw;
  }

  .button02 {
    width: 72.010178117vw;
    height: 13.9949109415vw;
    font-size: 4.5801526718vw;
  }

  .button02::before {
    width: 2.5445292621vw;
    height: 4.0712468193vw;
    right: 4.0712468193vw;
  }

  /* content */
  .mv {
    padding: 0;
  }

  .mv_image {
    max-width: 94.1475826972vw;
  }

  .intro {
    padding: 13.333vw 20px 20px;
  }

  .intro_inner {
    /* max-width: 353px; */
  }

  .intro_box {
    margin: 0 auto 2.545vw;
    padding: 15.195929vw 5.816794vw 4.106870229vw;
    max-width: 100%;
    border-radius: 5.0890585242vw;
  }

  .intro_box h2 {
    width: 81.934vw;
    padding: 2.545vw;
    border: 0.7633587786vw solid #fff;
    font-size: 4.58vw;
    line-height: 1.5;
  }

  .intro_box p {
    font-size: 4.0712468193vw;
    line-height: 1.43;
    letter-spacing: -0.03em;
  }

  .intro_price {
    margin-bottom: 2.5445292621vw;
  }

  .intro_attention {
    font-size: 3.0534351145vw;
  }

  .l_sec_added_2 .l_flex_img .c_flex_content .u_title {
    font-size: 16px;
    padding: 10px;
    line-height: 24px;
  }

  .l_sec_added_2 .c_sec_content {
    margin-top: 26px;
  }

  .tb_price_wrap {
    padding: 2.083vw;

    .tb_price_head_content {
      flex-direction: column;

      .tb_price_head_box {
        img {
          /* width: 82px;
          height: 82px; */
          /* width: 20.655vw;
          height: 20.655vw; */
          /* width: 15.655vw;
          height: 15.655vw; */
          width: 13.655vw;
          height: 13.655vw;
        }

        .tb_price_head_box_text {
          p {
            /* font-size: 18px; */
            font-size: 4.58vw;
          }

          .tb_price_head_box_text_dsc {
            display: flex;
            align-items: baseline;
            gap: 5px;

            .tb_price_head_box_text_dsc_stand {
              /* font-size: 14px; */
              font-size: 3vw;
              transform: translateY(4px);
            }

            .tb_price_head_box_text_dsc_price {
              /* font-size: 36px; */
              font-size: 7vw;
            }

            .tb_price_head_box_text_dsc_en {
              font-size: 4.58vw;
            }
          }

          span:last-child {
            /* font-size: 12px; */
            font-size: 3.053vw;
          }
        }
      }
    }
  }

  .cost_table .total_cell {
    font-size: 1.987vw;
    font-size: 3.023vw;
  }

  .management {
    padding: 13.2315521628vw 5.0890585242vw 0;
  }

  .management_image {
    margin-bottom: 17.8117048346vw;
  }

  .management_list {
    margin-bottom: 13.2315521628vw;
    gap: 11.7048346056vw 0;
  }

  .management_list > li {
    width: 100%;
  }

  .management_list > li:nth-child(1)::before {
    display: none;
  }

  .management_list > li:nth-child(2) .title {
    border-top: 0.7633587786vw solid #009f4c;
    border-bottom: 0.7633587786vw solid #009f4c;
  }

  .management_list > li:nth-child(2) .price dl dt,
  .management_list > li:nth-child(2) .price dl dd {
    border: 1.0178117048vw solid #009f4c;
  }

  .management_list > li:nth-child(2) .desc {
    margin-bottom: 4.0712468193vw;
  }

  .management_list > li:nth-child(2) .image {
    margin-bottom: 4.5801526718vw;
  }

  .management_list > li:nth-child(2) .price dl dd {
    font-size: 4.0712468193vw;
  }

  .management_list > li .title {
    margin-bottom: 6.106870229vw;
    padding: 6.106870229vw 2.5445292621vw 3.5623409669vw;
    border-top: 0.7633587786vw solid #f06f66;
    border-bottom: 0.7633587786vw solid #f06f66;
    font-size: 10.1781170483vw;
  }

  .management_list > li .title span {
    padding: 1.0178117048vw 4.5801526718vw 1.272264631vw;
    font-size: 5.0890585242vw;
  }

  .management_list > li .title span:before {
    width: calc(100% - 1.272264631vw);
    height: calc(100% - 1.272264631vw);
    border: 0.2544529262vw solid #fff;
  }

  .management_list > li .image {
    margin-bottom: 4.0712468193vw;
  }

  .management_list > li .desc {
    margin-bottom: 5.0890585242vw;
    font-size: 4.0712468193vw;
    line-height: 1.43;
  }

  .management_list > li .box {
    margin-bottom: 6.106870229vw;
  }

  .management_list > li .price dl {
    margin-bottom: 3.0534351145vw;
  }

  .management_list > li .price dl dt,
  .management_list > li .price dl dd {
    padding: 2.5445292621vw 1.5267175573vw;
    font-size: 4.5801526718vw;
    border: 1.0178117048vw solid #f06f66;
  }

  .management_list > li .price dl dt {
    width: 28.4987277354vw;
  }

  .management_list > li .price dl dd {
    position: relative;
    left: -0.2544529262vw;
    width: calc(100% - 28.4987277354vw);
  }

  .management_list > li .price p {
    margin-bottom: 3.0534351145vw;
    text-align: center;
  }

  .management_list > li .price p .text {
    margin-right: 2.5445292621vw;
    font-size: 4.5801526718vw;
  }

  .management_list > li .price p .number {
    font-size: 9.1603053435vw;
  }

  .management_list > li .price p .tax {
    font-size: 4.5801526718vw;
  }

  .management_list > li .price ul {
    font-size: 3.0534351145vw;
    line-height: 1.5;
  }

  .management_box {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    padding: 8.1424936387vw 5.0890585242vw;
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
  }

  .management_box picture {
    margin: 0 auto 4.3256997455vw;
    max-width: 100%;
  }

  .management_box .attention {
    margin-top: 4.0712468193vw;
    font-size: 3.0534351145vw;
    line-height: 1.66;
    text-align: left;
  }

  .flow {
    padding: 0 20px 20px;
  }

  .flow_list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 40px;
    padding-bottom: 40px;

    li {
      width: 100%;

      a {
        width: 100%;
      }
    }
  }

  .flow_inner {
    max-width: unset;
  }

  /* .flow_list>li {
    width: calc(50% - 6.8702290076vw / 2);
  } */

  .flow_list > li:not(:last-child)::before {
    width: 6.6157760814vw;
    height: 9.6692111959vw;
    transform: translate(120%, -50%);
  }

  .flow_list > li:nth-child(2)::before {
    display: none;
  }

  .other {
    padding: 13.2315521628vw 0 0;
  }

  .other_content {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    padding: 10.1781170483vw 5.0890585242vw;
    border-radius: 0;
  }

  .other_content .title01 {
    margin-bottom: 4.0712468193vw;
    font-size: 7.1246819338vw;
    line-height: 1.5;
  }

  .other_content > .desc {
    margin-bottom: 15.2671755725vw;
    font-size: 5.0890585242vw;
    line-height: 1.45;
    font-weight: 500;
  }

  .other_content .box01 {
    max-width: 100%;
    padding: 12.9770992366vw 5.0890585242vw 8.1424936387vw;
    border-radius: 5.0890585242vw 5.0890585242vw 0 0;
  }

  .other_content .box01 > h3 {
    padding: 19px 55px;
    width: 100%;
    border: 0.7633587786vw solid #fff;
    font-size: 18px;
    text-align: center;
    letter-spacing: -0.03em;
  }

  .other_content .box01 .column {
    margin-bottom: 5.0890585242vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .other_content .box01 .column .primary {
    width: 100%;
  }

  .other_content .box01 .column .primary .desc {
    font-size: 4.0712468193vw;
    line-height: 1.43;
  }

  .other_content .box01 .column .primary .price {
    margin-bottom: 2.5445292621vw;
  }

  .other_content .box01 .column .primary .price .label {
    margin-right: 1.0178117048vw;
    padding: 1.0178117048vw 1.5267175573vw;
    border: 0.2544529262vw solid #009f4c;
    font-size: 4.0712468193vw;
  }

  .other_content .box01 .column .primary .price .number {
    font-size: 9.1781170483vw;
    padding-left: 10px;
  }

  .other_content .box01 .column .primary .price .tax {
    position: relative;
    bottom: -1.5267175573vw;
    font-size: 4.0712468193vw;
  }

  .other_content .box01 .column .secondary {
    width: 100%;
  }

  .other_content .box01 .column .secondary figure {
    margin-bottom: 3.0534351145vw;
  }

  .other_content .box01 .column .secondary .attention {
    font-size: 3.0534351145vw;
    line-height: 1.66;
  }

  .other_content .box01 .image {
    margin-bottom: 6.106870229vw;
  }

  .other_content .box01 .buttons {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 5.0890585242vw;
  }

  .other_content .box01 .buttons .logo {
    width: 55.4707379135vw;
  }

  .other_content .box02 {
    max-width: 100%;
    padding: 7.1246819338vw 5.8524173028vw;
    background: url("../img/top/other_box02_bg_sp.png") no-repeat center/cover;
    border-radius: 0 0 5.0890585242vw 5.0890585242vw;
  }

  .other_content .box02 .l_box_content {
    border-radius: 4.089vw;
    padding: 8vw 2.778vw;
  }

  .other_content .box02 .l_box_content .u_box_title {
    /* font-size: 20px; */
    font-size: 5.089vw;
  }

  .other_content .box02 .l_box_content .u_title_note {
    font-size: 4.071vw;
    /* line-height: 24px; */
    line-height: 6.107vw;
    margin-bottom: 3.111vw;
    margin-top: 2.667vw;
  }

  .other_content .box02 .l_box_content .u_box_img {
    max-width: 58.667vw;
  }

  .other_content .box02 .l_box_content .u_link {
    margin-top: 5.344vw;
  }

  .other_content .box02 .l_box_content .u_link img {
    max-width: 53.435vw;
  }

  .other_content .box02 .list {
    margin-bottom: 5.0890585242vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    gap: 6.106870229vw;
  }

  .other_content .box02 .list li {
    width: 100%;
    padding: 5.0890585242vw 4.5801526718vw;
    border-radius: 5.0890585242vw;
    border: 0.7633587786vw solid #ea5532;
  }

  .other_content .box02 .list li:nth-child(2) {
    border: 3px solid #009fb9;
  }

  .other_content .box02 .list li:nth-child(2) h4 {
    color: #009fb9;
  }

  .other_content .box02 .list li:nth-child(2) figure {
    width: 53.4351145038vw;
  }

  .other_content .box02 .list li:nth-child(2) .button01 {
    background: #009fb9;
  }

  .other_content .box02 .list li:nth-child(2) .button01::before {
    background: url("../img/top/button01_arrow_blue.png") no-repeat
      center/contain;
  }

  .other_content .box02 .list li h4 {
    margin-bottom: 3.0534351145vw;
    font-size: 5.0890585242vw;
  }

  .other_content .box02 .list li p {
    margin-bottom: 3.0534351145vw;
    font-size: 4.0712468193vw;
    line-height: 1.5;
  }

  .other_content .box02 .list li figure {
    margin: 0 auto 2.0356234097vw;
    width: 43.0025445293vw;
  }

  .other_content .box02 .attention {
    font-size: 3.0534351145vw;
    line-height: 1.66;
  }

  /**/
  .l_sec_link {
    padding: 45px 30px 30px;

    .cta_contact {
      padding: 15px;

      span {
        font-size: 16px;
      }

      p {
        font-size: 18px;
      }

      .attention {
        font-size: 12px;
      }
    }

    .c_sec_link {
      .l_ta_contact {
        .l_link_box {
          flex-direction: column;
          align-items: center;
        }
      }
    }

    .colum_2 {
      display: flex;
      flex-direction: column;
      gap: 15px;
    }
  }

  .tb_cost_title {
    /* font-size: 14px; */
    font-size: 3.562vw;
  }

  .cost_table {
    th,
    td {
      font-size: 3.023vw;
    }

    .col_month {
      width: 15%;
    }

    .col_en {
      width: 30%;
    }
  }

  .dots_area {
    .dot {
      width: 3px;
      height: 3px;
      margin: 2px 0;
    }
  }

  .toggle_btn {
    /* font-size: 12px; */
    font-size: 3.053vw;
    height: 13.74vw;
  }

  .toggle_icon {
    width: 8.142vw;
    height: 8.142vw;
    font-size: 4.58vw;
  }

  .l_content_box_2 {
    padding: 20px;

    h3 {
      font-size: 16px;
      margin-bottom: 14px;

      span {
        font-size: 20px;
        display: block;
        margin-bottom: 10px;
      }
    }

    .col_2 {
      flex-direction: column;
      gap: 12px;

      .col_2_box {
        h4 {
          font-size: 18px;
          margin-bottom: 6px;
        }

        .col_2_box_content {
          display: grid;
          /* grid-template-columns: 30% 1fr; */
          grid-template-columns: 1fr 1fr;
          justify-items: center;

          p {
            font-size: 16px;
          }

          .col_2_box_content_dsc {
            line-height: 25px;
          }
        }
      }

      .col_2_box {
        margin-top: 0;
        padding: 12px;

        img {
          width: 100%;
          height: 100%;
          object-fit: contain;
        }
      }

      .box_yellow {
        .col_2_box_content {
          ul {
            font-size: 16px;
            line-height: 19px !important;

            li {
              font-size: 12px;
            }
          }
        }
      }
    }
  }

  .col_2_price {
    flex-direction: column;
    margin-top: 16px;
    gap: 0;
    align-items: center;

    .col_2_price_txt {
      font-size: 14px;
      padding-bottom: 5px;
    }

    .col_2_price_num_content {
      .col_2_price_num_content_num {
        font-size: 50px;
      }

      .col_2_price_num_content_txt {
        font-size: 16px;

        p {
          font-size: 16px;
          line-height: 20px;
        }
      }
    }
  }

  .col_2_note_content {
    p {
      font-size: 14px;
    }
  }

  /**/

  .voice {
    padding: 13.2315521628vw 5.0890585242vw 0;
  }

  .voice_list {
    margin-bottom: 8.1424936387vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    gap: 5.0890585242vw;
  }

  .voice_list li {
    padding: 5.0890585242vw;
    width: 100%;
    border-radius: 5.0890585242vw;
    -webkit-box-shadow: 0 0.7633587786vw 1.5267175573vw rgba(0, 0, 0, 0.16);
    box-shadow: 0 0.7633587786vw 1.5267175573vw rgba(0, 0, 0, 0.16);
  }

  .voice_list li .head {
    margin-bottom: 1.5267175573vw;
    gap: 0 2.7989821883vw;
  }

  .voice_list li .head figure {
    width: 23.9185750636vw;
  }

  .voice_list li .head .content {
    width: calc(100% - 23.9185750636vw - 2.7989821883vw);
  }

  .voice_list li .head .content h3 {
    margin-bottom: 2.5445292621vw;
    font-size: 4.0712468193vw;
  }

  .voice_list li .head .content p {
    font-size: 3.0534351145vw;
  }

  .voice_list li .desc {
    font-size: 3.0534351145vw;
  }

  .faq {
    padding: 13.2315521628vw 5.0890585242vw;
  }

  .faq_list {
    margin-bottom: 8.1424936387vw;
  }

  .faq_list dt {
    margin-bottom: 2.5445292621vw;
  }

  .faq_list dt::before,
  .faq_list dt::after {
    width: 4.834605598vw;
    height: 1.0178117048vw;
    right: 5.0890585242vw;
  }

  .faq_list dt p {
    padding: 4.0712468193vw 18.8295165394vw 4.0712468193vw 18.8295165394vw;
    font-size: 5.0890585242vw;
    border-radius: 5.0890585242vw;
    font-weight: 800;
  }

  .faq_list dt p::before {
    font-size: 8.1424936387vw;
    left: 5.0890585242vw;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
  }

  .faq_list dd {
    display: none;
    margin-bottom: 5.0890585242vw;
    padding: 7.1246819338vw;
    font-size: 4.0712468193vw;
    border-radius: 5.0890585242vw;
  }

  .useful {
    padding: 13.2315521628vw 5.0890585242vw;
  }

  .useful_list {
    margin-bottom: 8.1424936387vw;
    gap: 6.106870229vw;
  }

  .useful_list li {
    width: calc(50% - 6.106870229vw / 2);
  }

  .useful_list li a figure {
    margin-bottom: 3.0534351145vw;
    border-radius: 2.5445292621vw;
    overflow: hidden;
  }

  .useful_list li a time {
    margin-bottom: 1.0178117048vw;
    font-size: 3.0534351145vw;
  }

  .useful_list li a h3 {
    font-size: 4.0712468193vw;
    line-height: 1.43;
  }

  .float-banner {
    width: 43.5114503817vw;
    height: 21.6284987277vw;
    bottom: 2.5445292621vw;
    right: 2.5445292621vw;
    pointer-events: auto;
  }

  .is-hidden-fixed-banner .float-banner {
    -webkit-transform: translateX(calc(100% + 2.5445292621vw));
    transform: translateX(calc(100% + 2.5445292621vw));
  }

  .mv_text_1 {
    display: inline-block;
    padding: 10px 7px 20px 30px;
    /* font-size: 24px; */
    font-size: 6.045vw;
    font-weight: 600;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 30px;
  }

  .mv_image_2 img {
    height: unset;
  }

  .mv_image {
    margin: 0 auto;
    max-width: 1154px;
    height: unset;
  }

  .mv_image_1_1 {
    max-width: 303px;
    margin: 0 auto;
  }

  .mv_text_2 {
    color: #016b2a;
    font-size: 16px;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: 0.5px;
    margin: 20px auto 0;
  }

  .mv_text_2 .mv_text_2_spe {
    color: #db0034;
    font-size: 20px;
    font-weight: 500;
    line-height: 41px;
    margin: 0 0 0 -10px;
  }

  .mv_inner {
    grid-template-columns: 1fr;
    justify-content: space-between;
  }

  .mv_image_1 {
    padding-top: 20px;
    grid-row: 2;
  }

  .l_sec_added_2 {
    max-width: unset;
    padding: 80px 20px 30px;
  }

  .l_sec_added_1 h2 {
    font-size: 24px;
    line-height: 34px;
  }

  .l_sec_added_1 {
    padding: 6.944vw 0 13.5vw;
  }

  .l_sec_added_1 h2::after {
    height: 42px;
    width: 28px;
    right: -29px;
    bottom: 3px;
  }

  .l_sec_added_1 h2::before {
    height: 42px;
    width: 28px;
    left: -29px;
    bottom: 3px;
  }

  .l_sec_added_1 .u_title_note {
    font-size: 16px;
    line-height: 24px;
    color: #016b2a;
  }

  .l_sec_added_1 .u_img {
    padding: 0 20px;
  }

  .l_sec_added_1 .c_sec_content .u_content_title {
    font-size: 18px;
  }

  .l_sec_added_1 .c_sec_content .u_content_detail {
    /* font-size: 16px; */
    font-size: 3.6vw;
    line-height: 23px;
  }

  .l_sec_added_2 h2 {
    font-size: 6.045vw;
    color: #000000;
    font-weight: 600;
    line-height: 34px;
    position: relative;
    display: inline;
    background-image: linear-gradient(#f5e84b, #f5e84b);
    background-repeat: repeat-x;
    background-size: 100% 12px;
    background-position: 0 100%;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
  }

  .l_sec_added_2 h2 {
    &::after {
      content: "";
      position: absolute;
      background-repeat: no-repeat;
      background-size: contain;
      height: 66px;
      width: 55px;
      right: -3px;
      bottom: 28px;
    }
  }

  .l_sec_added_2 .l_flex_img {
    margin-top: 42px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
    /* padding: 0 40px; */
  }

  .c_sec_content {
    margin-top: 26px !important;
  }

  .l_sec_added_2 .c_sec_content .u_content_title {
    margin-bottom: 0px;
    font-size: 6.5vw;
    /* line-height: 42px; */
    line-height: 60px;
  }

  .l_sec_added_2 .c_sec_content .u_content_title {
    &::before,
    &::after {
      content: none;
    }
  }

  .l_sec_added_2 .c_sec_content .u_content_detail {
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    margin-top: 18px;
    color: #000000;
  }

  .l_sec_added_3 {
    padding: 40px 0;
  }

  .l_sec_added_3 h2 {
    font-size: 28px;
    color: #016b2a;
    font-weight: 600;
    line-height: 34px;
    position: relative;
    display: inline-block;
  }

  .l_sec_added_3 .l_sec_added_3_1 {
    margin-bottom: 40px;
  }

  .l_sec_added_3 .l_sec_added_3_1 .l_flex_box {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-top: 0;
    overflow-x: auto;
    /* padding-left: 40px;
    padding-top: 30px; */
    padding: 30px 0 10px 40px;
  }

  .l_sec_added_3 .l_sec_added_3_1 .l_flex_box .l_flex_content {
    position: relative;
    min-width: 271px;
  }

  .l_sec_added_3 .l_sec_added_3_2 {
    padding: 0 20px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 {
    background: #fff;
    padding: 20px;
    border: 3px solid #016b2a;
    border-radius: 20px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .u_content_title {
    color: #016b2a;
    font-size: 20px;
    font-weight: 600;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .l_flex_box {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 20px;
    height: unset;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_content_title {
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    color: #016b2a;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    img {
    width: 100%;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    ul
    li {
    font-size: 12px;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    ul {
    line-height: 20px;
    margin-top: 5px;
  }

  .l_service_area {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 21.374vw;
  }

  .r_service_area {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 29.008vw;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    ul.l_service_lists {
    /* padding-left: 6.5vw; */
    padding-left: 2.5vw;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    ul.r_service_lists {
    /* margin-left: -12vw; */
    padding-left: 2.5vw;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    .u_flex_img_content_text {
    height: unset;
    margin-top: 7px;
    text-align: center;
    /* font-size: 16px; */
    font-size: 3.8vw;
    font-weight: 400;
    line-height: 20px;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .l_flex_box
    .l_flex_content
    .u_flex_img
    .u_flex_img_content
    .u_flex_img_content_text
    span {
    font-size: 12px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .l_flex_box .l_flex_content {
    border-radius: 20px;
    /* padding: 16px 27px 20px; */
    padding: 16px 20px 20px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .u_spec_text_line {
    margin-top: 30px;
    font-size: 18px;
    font-weight: 600;
    display: block;
    justify-content: center;
    /* align-items: center; */
    align-items: flex-end;
  }

  .l_sec_added_3
    .l_sec_added_3_2
    .l_content_box_1
    .u_spec_text_line
    .green_bg_text {
    font-size: 14px;
    color: #fff;
    background: #016b2a;
    padding: 5px 10px;
    border-radius: 20px;
    margin-right: 5px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .u_spec_text_line .text_lx {
    font-size: 24px;
    margin-left: 0;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .u_spec_text_line .text_lxx {
    font-size: 50px;
    color: #016b2a;
    line-height: 60px;
  }

  .l_sec_added_3 .l_sec_added_3_2 .l_content_box_1 .u_spec_text_line .col_text {
    display: inline-block;
    flex-direction: column;
    width: 80px;
  }

  .faq_inner {
    max-width: unset;
  }

  .useful_inner {
    max-width: unset;
  }

  .l_sec_added_3 {
  }
}

/* 20260316 */
.txtBar {
  color: #016b2a;
  font-size: 38px;
  font-weight: bold;
  display: flex;
  text-align: center;
  align-items: center;
  padding: 25px 50px;
  border-radius: 15px;
}
.txtBar.yellow {
  background-color: #f5e84b;
}
@media(max-width: 600px) {
  .txtBar.yellow {
  background-color: white;
  font-size: 14px;
  padding: 3% 3%;
}
}
.txtBar.green {
  background-color: #016b2a;
  color: white;
  display: flex;
  justify-content: center;
  margin-top: 40px;
}
@media(max-width: 600px) {
  .txtBar.green {
  margin-top: 5%;
  font-size: 18px;
  padding: 3% 0;
}
}
.txtBar.white {
  color: #016b2a;
  background-color: white;
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

/* カラー変数（必要に応じて既存のCSS変数に書き換えてください） */
/* カラー変数（変更なし） */
.osaka-v-container {
  --osaka-dark-green: #1a5d36;
  --osaka-bg-light: #e9f5e9;
  --osaka-white: #ffffff;

  margin: 30px 0 0 0px;
  font-family: sans-serif;
}

/* アイコンとタイトルの並び（下揃えから中央揃えに微調整） */
.osaka-v-header-row {
  display: flex;
  align-items: center; /* 画像に合わせて中央揃えの方が見栄えが良い場合が多いです */
  border-bottom: 5px solid var(--osaka-white);
  margin-bottom: 25px;
}

/* 家のアイコン画像エリア */
.osaka-v-house-icon {
  width: 130px; /* 元のCSSアイコンと同じ幅 */
  margin-right: 25px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
@media(max-width: 600px) {
  .osaka-v-house-icon {
  width: 15%; /* 元のCSSアイコンと同じ幅 */
  margin-right: 3%;
}
}

/* 画像自体のスタイル */
.osaka-v-house-img {
  width: 100%;
  height: auto; /* アスペクト比を維持 */
  display: block;
}

/* --- 以下、元のコードからCSSアイコン描画部分を削除 --- */

/* タイトルテキスト（変更なし） */
.osaka-v-main-title {
  width: 100%;
  color: var(--osaka-dark-green);
  font-size: clamp(24px, 5vw, 48px);
  font-weight: 800;
  margin: 0;
  line-height: 1.2;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* タイトル末尾の丸数字（変更なし） */
.osaka-v-title-circle {
  font-size: 0.8em;
  border: 4px solid var(--osaka-dark-green);
  border-radius: 50%;
  width: 1.2em;
  height: 1.2em;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-left: 10px;
  flex-shrink: 0;
}
@media(max-width: 600px) {
  .osaka-v-title-circle {
  font-size: 0.8em;
  border: 2px solid var(--osaka-dark-green);
  border-radius: 50%;
  width: 1.2em;
  height: 1.2em;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-left: 10px;
  flex-shrink: 0;
}
}

/* 本文テキスト（変更なし） */
.osaka-v-content-body {
  color: var(--osaka-dark-green);
  font-size: clamp(18px, 3vw, 32px);
  font-weight: bold;
  line-height: 1.6;
}

.osaka-v-content-body p {
  margin: 0 0 10px 0;
}
section.banners {
  padding: 20px 0;
}
@media(max-width: 600px) {
  section.banners {
  padding: 5% 3%;
}
section.banners a {
  margin-right: 3%;
}
section.banners a:last-child {
  margin-right: 0%;
}
}
.intro_inner.columnbox {
  display: flex;
  justify-content: space-around;
}
.flow_list.excep,
.l_sec_added_3.excep {
  padding-bottom: 50px;
}
@media(max-width: 600px) {
  .flow_list.excep,
.l_sec_added_3.excep {
  padding-bottom: 5%;
}
}
.l_sec_added_3_1.excep {
  margin-bottom: 50px;
}
section.serviceArea {
  background-color: #e3f1de;
  padding: 50px 0;
}
@media(max-width: 600px) {
  section.serviceArea {
  padding: 5% 0;
}
}
.map {
  display: flex;
  justify-content: space-around;
  padding: 20px 40px;
  background-color: white;
  border-radius: 15px;
  margin-top: 30px;
}
@media(max-width: 600px) {
  .map {
  padding: 5% 3%;
  margin-top: 5%;
  }
}
.map img {
  width: 30%;
}
.map .right {
  width: 60%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media(max-width: 600px) {
  .map .right {
  width: 100%;
}
}
.map .title {
  font-size: 24px;
  color: #016b2a;
  font-weight: bold;
  text-align: center;
  margin-top: 20px;
  margin-bottom: 40px;
}
@media(max-width: 600px) {
  .map .title {
  font-size: 1.3em;
  margin-top: 3%;
  margin-bottom: 3%;
}
}
.map .description {
  text-align: center;
  font-size: 18px;
  line-height: 1.5;
  margin-bottom: 40px;
}
@media(max-width: 600px) {
  .map .description {
  font-size: 0.9em;
  margin-bottom: 3%;
}
}
.map .areaButton {
  display: block;
  width: 65%;
  margin: 0 auto;
  font-size: 35px;
  font-weight: bold;
  color: white;
  background-color: #f0776d;
  padding: 15px;
  border-radius: 35px;
  text-align: center;
}
@media(max-width: 600px) {
  .map .areaButton {
  width: 80%;
  font-size: 1.6em;
  padding: 2% 0;
}
}

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600;700&display=swap");

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

main.arealist {
  background: #e3f1de;
  font-family: "Noto Sans JP", sans-serif;
  display: flex;
  flex-direction: column;
  /* justify-content: center; */
  align-items: center;
  padding: 20px;
}

main.arealist .mini {
  background-color: #016b2a;
  color: white;
}
@media (max-width: 600px) {
  .txtBar.mini {
    width: 90%;
    padding: 15px 0px;
    margin: 0 auto;
    font-size: 22px;
  }
  main.arealist line,
  .map-dot,
  .region {
    display: none;
  }
}

.map-container {
  max-width: 1040px;
  width: 100%;
  margin-top: 30px;
  background-color: #ffffff;
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 6px 30px rgba(0, 0, 0, 0.12);
}
@media (max-width: 600px) {
  .map-container {
  margin-top: 5%;
  padding-bottom: 12%;
  padding-right: 3%;
  padding-left: 3%;
  }
}
.map-description {
  text-align: center;
  position: absolute;
  bottom: -10%;
  right: 0;
  font-size: 0.20em;
  width: 70%;
  font-weight: bold;
  color: #016B2A;
}
.map-description span {
  font-size: 0.55rem;
  font-weight: normal;
  display: block;
  margin-top: 2%;
  color: #5B5B5B;
}

.map-layout {
  position: relative;
  width: 100%;
  padding-top: 78%;
}

.map-inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/* Japan map image */
.japan-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 1;
  pointer-events: none;
}

/* Region blocks */
.map-layout .region {
  position: absolute;
  z-index: 3;
  border: solid 2px #3a8c3a;
  border-radius: 10px;
  padding: 5px;
}

.region-title {
  background: #3a8c3a;
  color: #fff;
  font-size: clamp(10px, 1.3vw, 14px);
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 5px;
  margin-bottom: 5px;
  letter-spacing: 0.5px;
  white-space: nowrap;
  font-size: 22px;
  display: block;
  text-align: center;
}

.pref-grid {
  display: grid;
  gap: 3px;
}
.pref-grid.cols-2 {
  grid-template-columns: 1fr 1fr;
}
.pref-grid.cols-1 {
  grid-template-columns: 1fr;
}

.pref {
  background: #fff;
  border: 1.5px solid #3a8c3a;
  border-radius: 5px;
  padding: 3px 10px;
  font-size: clamp(9px, 1.15vw, 12.5px);
  font-weight: 600;
  color: #2d5a2d;
  white-space: nowrap;
  text-align: center;
  transition: all 0.2s ease;
  cursor: default;
  font-size: 22px;
}
.pref.preparation {
    opacity: 0.4;
}

.pref:hover {
  background: #3a8c3a;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(58, 140, 58, 0.3);
  opacity: 1.0!important;
}
.pref.preparation:hover {
  opacity: 0.4!important;
}

/* Connection lines */
.lines-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.conn-line {
  stroke: #4a9a4a;
  stroke-width: 1.2;
  fill: none;
  opacity: 0.55;
}

.map-dot {
  fill: #1e5a1e;
  opacity: 0.85;
}

/* ===== Region Positions ===== */
.region-kansai {
  top: 3%;
  left: 10%;
}
.region-chugoku {
  top: 30%;
  left: 8%;
}
.region-kyushu {
  bottom: 0%;
  left: 0.5%;
}
.region-shikoku {
  bottom: 0%;
  left: 35%;
}
.region-koshinetsu {
  top: 3%;
  left: 33%;
}
.region-tokai {
  bottom: 3%;
  right: 35%;
}
.region-hokkaido {
  top: 5%;
  right: 5.5%;
}
.region-tohoku {
  top: 17%;
  right: 7.5%;
}
.region-kanto {
  bottom: 5%;
  right: 5.5%;
}

@media (max-width: 600px) {
  .map-container {
    /* padding: 12px; */
  }
  .pref {
    padding: 2px 6px;
  }
  .region-title {
    padding: 3px 8px;
  }
}

/* ここから都道府県選択アコーディオン */
.pc_view {
  display: block;
}
.sp_view {
  display: none;
}
@media (max-width: 600px) {
  .pc_view {
  display: none;
}
.sp_view {
  display: block;
}
}
/* PCでは隠す */
@media screen and (max-width: 767px) {
  .sp-only {
    display: block;
    padding: 10px 0px;
  }
  .accordion-container {
    width: 100%;
  }
  .search-container {
    width: 80%;
  }
  .search-container button {
    text-align: center;
  }

  /* チェックボックスは隠す */
  .accordion-check {
    display: none;
  }

  /* ラベル（ボタン部分） */
  .accordion-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px;
    border: 2px solid #007bc3; /* スクショに近い青 */
    background: #fff;
    font-weight: bold;
    font-size: 1.1rem;
    cursor: pointer;
    border-radius: 4px;
  }

  /* アニメーションの肝：高さを0で保持 */
  .accordion-content {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.4s ease-out; /* ここで時間を調整（0.4秒） */
    visibility: hidden;
    border-left: 2px solid #007bc3;
    border-right: 2px solid #007bc3;
    background: #fff;
  }

  /* 中身を包むコンテナ */
  .content-inner {
    overflow: hidden;
  }

  /* チェックが入った時（開いた時）の状態 */
  .accordion-check:checked + .accordion-label + .accordion-content {
    grid-template-rows: 1fr;
    visibility: visible;
    border-bottom: 2px solid #007bc3;
  }

  /* 矢印の回転アニメーション */
  .arrow-icon {
    transition: transform 0.3s;
  }
  .accordion-check:checked + .accordion-label .arrow-icon {
    transform: rotate(180deg);
  }

  /* リストのデザイン */
  .pref-list {
    margin: 0;
    padding: 10px 20px;
    list-style: none;
  }
  .pref-list li a {
    display: block;
    padding: 12px 0;
    color: #333;
    text-decoration: none;
    border-bottom: 1px solid #eee;
  }

  /* 検索ボタン */
  /* .search-button {
    display: block;
    background-color: #ff5a50; /* スクショに近い朱色 */
    color: #fff;
    text-align: center;
    padding: 16px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    font-size: 1.2rem;
    box-shadow: 0 4px 0 #d4483f; /* 少し立体感 */
  } */
}
/* リスト内のラジオボタンを少し綺麗に */
.pref-list li {
    border-bottom: 1px solid #eee;
}
.pref-list label {
    display: block;
    padding: 15px;
    cursor: pointer;
    width: 100%;
}
/* 選択された項目の背景色を変える */
.pref-list input[type="radio"]:checked + span, 
.pref-list label:has(input:checked) {
    background-color: #f0f7ff;
    color: #007bc3;
    font-weight: bold;
}

/* 検索ボタンをbuttonタグ用に調整 */
.search-button {
    width: 100%;
    border: none;
    appearance: none;
    /* あとは前回お伝えした背景色などのスタイルを継続 */
    background-color: #ff5a50;
    color: #fff;
    padding: 16px;
    border-radius: 8px;
    font-weight: bold;
    font-size: 1.2rem;
    cursor: pointer;
}
/* .footer_secondary nav.pc {
  display: block;
} */
.footer_secondary nav.sp {
  display: none;
}
@media (max-width: 600px) {
  .footer_secondary nav.pc {
  display: none!important;
}
.footer_secondary nav.sp {
  display: block!important;
}
}
.button01.excep:before,
.button01.excep:after {
 content: none;
}
/*# sourceMappingURL=style.css.map */


