@charset "utf-8";

/* mv */
@media (min-width: 769px) {
  .underlayer_mv_img {
    background: url("../../images/life/benefits/mv.webp") no-repeat center /
      cover;
  }
}
@media (max-width: 768px) {
  .underlayer_mv_img {
    background: url("../../images/life/benefits/mv_sp.webp") no-repeat center /
      cover;
  }
  .underlayer_mv_lead_txt {
    padding-bottom: 0;
    border-bottom: none;
  }
}

/* benefits_main */
.benefits_main {
  display: flex;
  flex-direction: column;
}
.benefits_main_img img {
  width: 100%;
}
.benefits_main_note {
  display: flex;
  align-items: center;
  gap: 7rem;
  margin-top: 20rem;
  font-size: 14rem;
  line-height: 1.6;
  color: var(--color-black);
}
.benefits_main_note::before {
  display: inline-block;
  content: "";
  width: 17rem;
  height: 17rem;
  background: url(../../images/life/benefits/icon-plus.svg) no-repeat center / cover;
}
.support_block {
  display: flex;
  position: relative;
}
.support_period {
  display: flex;
  justify-content: center;
  align-items: center;
}
.support_list li {
  line-height: 2;
}
.support_list li:before {
  content: "■";
}
.support_block_wrap:not(.support_sub) .support_list li:before {
  color: var(--color-black);
}
.support_block_wrap:not(.support_sub) .support_arrow {
  position: absolute;
  width: 1px;
  background-color: var(--color-black);
}
.support_block_wrap:not(.support_sub) .support_arrow::before,
.support_block_wrap:not(.support_sub) .support_arrow::after {
  content: "";
  display: block;
  width: 1px;
  height: 5px;
  background-color: var(--color-black);
  border-radius: 100px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: center bottom;
}
.support_block_wrap:not(.support_sub) .support_arrow::before {
  rotate: -40deg;
}
.support_block_wrap:not(.support_sub) .support_arrow::after {
  rotate: 40deg;
}
.support_block_wrap + .support_block_wrap {
  border-top: 1px solid var(--color-gray-20);
}
.support_block_wrap:not(.support_sub) .support_period {
  background-color: var(--color-white);
}
@media (min-width: 769px) {
  .benefits_main {
    gap: 100px;
  }
  .border_flex_content {
    padding-top: 57px;
  }
  .support_block {
    gap: 30px;
  }
  .support_block_wrap .support_block:not(:last-child) {
    padding-bottom: 22px;
  }
  .support_block_wrap .support_block:last-child {
    padding-bottom: 48px;
  }
  .support_period {
    height: 40px;
    width: 130px;
    min-width: 130px;
    border: 1px solid var(--color-black);
  }
  .support_period_txt {
    font-size: 16px;
  }
  .support_list {
    padding-top: 10px;
  }
  .support_list li {
    font-size: 16px;
  }
  .support_block_wrap:not(.support_sub) .support_arrow {
    top: 43px;
    left: 65px;
    height: calc(100% - 43px);
  }
  .support_block_wrap + .support_block_wrap {
    padding-top: 37px;
  }
}
@media (max-width: 768px) {
  .benefits_main {
    /* gap: 30rem; */
    gap: 100rem;
  }
  .border_flex
    .border_flex_inner:nth-child(1)
    .border_flex_content:nth-child(1) {
    padding-top: 40rem;
  }
  .support_block {
    flex-direction: column;
  }
  .support_period {
    height: 36rem;
    width: 120rem;
    border: 1px solid var(--color-black);
  }
  .support_period_txt {
    font-size: 14rem;
  }
  .support_list {
    padding: 8rem 0 8rem 38rem;
  }
  .support_list li {
    font-size: 14rem;
  }
  .support_block_wrap:not(.support_sub) .support_arrow {
    top: 36rem;
    left: 19rem;
    height: calc(100% - 36rem);
  }
  .support_block_wrap + .support_block_wrap {
    padding-top: 30rem;
  }
}

/* benefits_detail */
.benefits_detail {
  display: flex;
  flex-direction: column;
}
.benefits_detail + .benefits_detail {
  border-top: 1px solid var(--color-gray-20);
}
.benefits_detail_ttl {
  line-height: 2;
}
.benefits_detail_list {
  display: flex;
  flex-direction: column;
}
.benefits_detail_list li {
  padding-left: 1em;
  text-indent: -1em;
  /* line-height: 1.5; */
  line-height: 1.6;
  color: var(--color-gray-60);
}
.benefits_detail_list li::before {
  content: "■";
  color: var(--color-black);
}
.benefits_detail_list .list-style-none {
  padding-left: initial;
  text-indent: initial;
}
.benefits_detail_list .list-style-none::before {
  content: "";
}
.benefits_detail_list li::first-line {
  color: var(--color-black);
}
@media (min-width: 769px) {
  .benefits_detail {
    gap: 24px;
  }
  .benefits_detail + .benefits_detail {
    padding-top: 56px;
    margin-top: 56px;
  }
  .benefits_detail_ttl {
    font-size: 16px;
  }
  .benefits_detail_list {
    gap: 24px;
  }
  .benefits_detail_list li {
    font-size: 16px;
  }
  .benefits_detail_list .list-style-none {
    padding-left: initial;
    text-indent: initial;
  }
}
/* chart_modal */
.chart_modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(255, 255, 255, 1);
  display: none;
  justify-content: center;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.chart_modal.is-active {
  display: flex;
}
.chart_modal_close {
  position: fixed;
  top: 10rem;
  right: 10rem;
  z-index: 10000;
  width: 40rem;
  height: 40rem;
  background: var(--color-black);
  border: none;
  border-radius: 50%;
  cursor: pointer;
}
.chart_modal_close::before,
.chart_modal_close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18rem;
  height: 2rem;
  background: var(--color-white);
  border-radius: 1px;
}
.chart_modal_close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.chart_modal_close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.chart_modal_body {
  width: 100%;
  padding: 60rem 10rem 30rem;
}
.chart_modal_body img {
  width: 100%;
  height: auto;
}
@media (max-width: 768px) {
  .benefits_main_img {
    cursor: pointer;
  }
  .benefits_main_note {
    cursor: pointer;
  }
}

@media (max-width: 768px) {
  .benefits_detail {
    gap: 20rem;
  }
  .benefits_detail + .benefits_detail {
    padding-top: 30rem;
    margin-top: 30rem;
  }
  .benefits_detail_ttl {
    font-size: 14rem;
  }
  .benefits_detail_list {
    gap: 21rem;
  }
  .benefits_detail_list li {
    font-size: 14rem;
  }
  .benefits_detail_list .list-style-none {
    padding-left: 1em;
    text-indent: initial;
  }
}
