/*====================================================
COMMON
====================================================*/
.catch-block {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  text-align: center;
}
.catch-block_txt {
  display: inline-block;
  text-align: left;
  position: relative;
}
.catch-block_txt::before,
.catch-block_txt::after {
  content: '';
  position: absolute;
  display: block;
  border-color: #20b35c;
  border-width: 5px;
}
.catch-block_txt::before {
  border-bottom: none;
  border-right: none;
}
.catch-block_txt::after {
  border-left: none;
  border-top: none;
}
.green-ttl {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: bold;
  background-color: #20b35c;
  text-align: center;
  color: #fff;
  font-size: 4.4rem;
  border-bottom: 8px solid #166f3a;
  padding: 0.6em 0;
}
.yellow-marker {
  background: linear-gradient(transparent 0%, #fcf9bb 0%);
}
.fukidashi {
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .green-ttl {
    font-size: 3.67vw;
  }
}
@media screen and (max-width: 767px) {
  .catch-block {
    font-size: 6.4vw !important;
    line-height: 1.83 !important;
  }
  .catch-block_txt::before,
  .catch-block_txt::after {
    border-width: 0.8vw;
    width: 1.8em !important;
    height: 1.9em !important;
  }
  .catch-block_txt::before {
    left: 0 !important;
    top: 0 !important;
  }
  .catch-block_txt::after {
    right: 0 !important;
    bottom: 0 !important;
  }
  .catch-block_txt {
    padding: 1em 0.9em;
  }
  .green-ttl {
    font-size: 6.93vw;
    border-bottom-width: 1.07vw;
    padding: 0.85em 0;
    line-height: 1.46153846;
  }
}

/*====================================================
MV
====================================================*/
.mv {
  text-align: center;
  position: relative;
}
.mv-ttl_img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .mv {
    box-shadow: 0px 1px 3px 0px rgb(0 0 0 / 20%);
  }
}

/*====================================================
INTRO
====================================================*/
.intro {
  text-align: center;
  padding: 11rem 0 7rem;
}
.intro-ttl {
  font-size: 4.4rem;
  line-height: 1.68 !important;
  margin-bottom: 1.65em;
}
.intro-ttl_txt::before,
.intro-ttl_txt::after {
  width: 1.6em;
  height: 1.7em;
}
.intro-ttl_txt::before {
  left: -1.2em;
  top: -0.5em;
}
.intro-ttl_txt::after {
  right: -1.2em;
  bottom: -0.5em;
}
.intro_txt {
  font-size: 3rem;
  line-height: 2;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .intro_inner {
    width: 80%;
  }
  .intro-ttl {
    font-size: 3.67vw;
  }
  .intro_txt {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .intro {
    padding: 12vw 0 13vw;
  }
  .intro_inner {
    width: 90%;
  }
  .intro-ttl {
    font-size: 6.93vw !important;
    margin-bottom: 9vw;
  }
  .intro-ttl_txt {
    padding: 0.6em 1.1em;
  }
  .intro_txt {
    font-size: 4.8vw;
    line-height: 1.94;
  }
}

/*====================================================
ONAYAMI
====================================================*/
.onayami {
  padding: 1.81em 0 3.19em;
  background-color: #e0f4e8;
  text-align: center;
  position: relative;
  font-size: 3.6rem;
}
.onayami::before {
  content: '';
  position: absolute;
  display: block;
  width: 5.44em;
  background-image: url(../img/common/triangle_green.svg);
  background-size: contain;
  left: 50%;
  transform: translateX(-50%);
  bottom: -10%;
  aspect-ratio: 98/45;
}
.onayami::after {
  content: '';
  position: absolute;
  display: block;
  width: 2.22em;
  background-image: url(../img/index/onayami_arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  left: 50%;
  transform: translateX(-50%);
  bottom: -3%;
  aspect-ratio: 11/10;
}
.onayami_ttl {
  font-weight: bold;
  margin-bottom: 0.7em;
}
.onayami_list {
  text-align: left;
  background-color: #fff;
  font-size: 3rem;
  line-height: 2;
  font-weight: bold;
  border: 3px dashed #c1c1c1;
  padding: 1.1em 1.5em 1.4em 3.3em;
  border-radius: 0.467em;
  position: relative;
}
.onayami_list::after {
  content: '';
  position: absolute;
  width: 3.47222222em;
  background-image: url(../img/index/onayami.png);
  background-repeat: no-repeat;
  aspect-ratio: 249/431;
  background-size: contain;
  bottom: -28.5%;
  right: 8%;
}
.onayami_item {
  background-image: url(../img/common/icon_check_red.png);
  background-repeat: no-repeat;
  background-size: 1.167em;
  background-position: left;
  padding-left: 1.8em;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .onayami {
    font-size: 3vw;
  }
  .onayami_inner {
    width: 95%;
  }
  .onayami_list {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .onayami {
    font-size: 6.93vw;
    padding: 2.1em 0 5.5em;
  }
  .onayami::before {
    bottom: -8%;
  }
  .onayami::after {
    width: 2em;
    bottom: -4.5%;
  }
  .onayami_inner {
    width: 90%;
  }
  .onayami_ttl {
    line-height: 1.85;
    margin-bottom: 1.2em;
  }
  .onayami_list {
    font-size: 5.33vw;
    padding: 1.2em 0.7em 2em;
    line-height: 1.6;
    display: flex;
    flex-direction: column;
    gap: 1em;
  }
  .onayami_item {
    background-position: left top 0.3em;
    background-size: 1.1em;
  }
  .onayami_list::after {
    right: inherit;
    left: 50%;
    transform: translateX(-50%);
    width: 3.9em;
    bottom: -34%;
  }
}

/*====================================================
SOLVE
====================================================*/
.solve {
  text-align: center;
  padding: 2.16em 0 2.61em;
  font-size: 4.4rem;
}
.solve_ttl {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: bold;
  margin-bottom: 1em;
}
.solve_img {
  width: 9.55em;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .solve {
    font-size: 3.67vw;
  }
}
@media screen and (max-width: 767px) {
  .solve {
    font-size: 6.93vw;
    padding: 3.5em 0 4em;
  }
  .solve_ttl {
    line-height: 1.69;
    margin-bottom: 1.7em;
  }
  .solve_img {
    width: 11.2em;
  }
}

/*====================================================
OVERVIEW
====================================================*/
.overview {
  text-align: center;
  padding-bottom: 9rem;
}
.overview_ttl {
  padding: 0.8em 0;
  position: relative;
  margin-bottom: 1.37em;
}
.overview_ttl::before {
  content: '';
  position: absolute;
  display: block;
  width: 20rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #20b35c;
  left: 50%;
  top: -57%;
  transform: translateX(-50%);
  z-index: -1;
}
.overview_ttl::after {
  content: '';
  position: absolute;
  display: block;
  width: 7rem;
  aspect-ratio: 139/132;
  left: 50%;
  top: -37%;
  transform: translateX(-50%);
  background-image: url(../img/index/overview_ttl.png);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;
}
.overview_movie-ttl {
  font-size: 3rem;
  font-weight: bold;
  margin-bottom: 0.8em;
}
.overview_movie-wrap {
  max-width: 78rem;
  margin: 0 auto;
}
.overview_movie {
  position: relative;
  width: 100%;
  height: 0px;
  padding-top: 56.25%;
}
.overview_movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.overview_movie-note {
  font-size: 2rem;
  font-family: 'Noto Sans JP', sans-serif;
  color: #eb4a4a;
  border: 2px solid;
  display: inline-block;
  padding: 0.6em 3.2em;
  margin-top: 2.2em;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .overview_ttl::before {
    width: 16.67vw;
  }
  .overview_ttl::after {
    width: 5.83vw;
  }
}
@media screen and (max-width: 767px) {
  .overview {
    padding-bottom: 15.5vw;
  }
  .overview_ttl {
    padding: 1.8em 0 1.2em;
    margin-bottom: 1.55em;
  }
  .overview_ttl::before {
    width: 37vw;
    top: -15vw;
  }
  .overview_ttl::after {
    width: 13vw;
    top: -10vw;
  }
  .overview_movie-ttl {
    font-size: 5.33vw;
    margin-bottom: 1.3em;
  }
  .overview_movie-note {
    font-size: 3.73vw;
    padding: 0.7em 0.3em;
    margin-top: 2em;
  }
}

/*====================================================
MERITS
====================================================*/
.merits {
  background-color: #e0f4e8;
  padding-bottom: 15rem;
  overflow-x: hidden;
}
.merits_ttl {
  margin-bottom: 2.2em;
}
.merits_list {
  flex-direction: column;
  gap: 6rem;
}
.merits-item {
  background-color: #fff;
  padding: 7rem 0;
  border-radius: 4rem;
  position: relative;
  z-index: 0;
}
.merits-item::before {
  content: '';
  position: absolute;
  display: block;
  background-color: #fff;
  width: 50vw;
  height: 100%;
  left: calc(50% - 25vw);
  transform: translateX(-50%);
  top: 0;
  z-index: -1;
}
.merits-item:nth-child(even)::before {
  left: inherit;
  left: calc(50% + 25vw);
}
.merits-item_ttl {
  justify-content: flex-start;
  align-items: center;
  font-size: 3rem;
  gap: 1.4em;
  margin-bottom: 0.7em;
}
.merits-item_ttl-txt {
  line-height: 1.53;
  font-weight: bold;
}
.merits-item_ttl-num {
  height: 2.8em;
}
.merits-item_ttl-img {
  height: 2.9em;
}
.merits-item_txt {
  font-size: 2.4rem;
  line-height: 2;
  padding: 0 1em;
}
.merits-item_btn {
  background-color: #20b35c;
  color: #fff;
  font-size: 3rem;
  font-weight: bold;
  width: 100%;
  display: block;
  text-align: center;
  margin-top: 1.3em;
  padding: 0.6em 4em;
  border-radius: 9999px;
  background-image: url(../img/index/merits_item_btn_arrow.png);
  background-repeat: no-repeat;
  background-position: right 1em top 1em;
  background-size: 2.6em;
}
.merits-cs-mark {
  margin-top: 9rem;
}
.merits-cs-mark_ttl {
  font-size: 3rem;
  font-weight: bold;
  margin-bottom: 0.4em;
}
.merits-cs-mark_content {
  align-items: flex-start;
}
.merits-cs-mark_txt {
  width: 77%;
  font-size: 2rem;
  line-height: 1.9;
}
.merits-cs-mark_img {
  width: 19.78835979%;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .merits {
    padding-bottom: 12.5vw;
  }
  .merits_inner {
    width: 95%;
  }
  .merits-item_inner,
  .merits-cs-mark_inner {
    width: 90%;
  }
  .merits-item {
    border-radius: 3.33vw;
  }
  .merits-item_ttl {
    font-size: 2.5vw;
  }
  .merits-item_txt {
    font-size: 2vw;
    padding: 0;
  }
  .merits-item_btn {
    font-size: 2.5vw;
  }
  .merits-cs-mark_ttl {
    font-size: 2.5vw;
  }
  .merits-cs-mark_txt {
    font-size: 1.67vw;
  }
}
@media screen and (max-width: 767px) {
  .merits_list {
    gap: 11vw;
  }
  .merits-item_inner {
    width: 100%;
  }
  .merits-item_ttl-num {
    width: auto;
    height: 2.3em;
  }
  .merits-item_ttl-img {
    width: auto;
    height: 2.7em;
    display: block;
    margin-left: auto;
  }
  .merits-item_ttl {
    font-size: 6.4vw;
    gap: 0.9em;
    margin-bottom: 1.3em;
  }
  .merits-item {
    padding: 13vw 7vw 11vw 0;
    border-radius: 5.33vw;
  }
  .merits-item:nth-child(even) {
    padding: 13vw 0 13vw 7vw;
  }
  .merits-item_txt {
    padding: 0 0 0 0.2em;
    font-size: 5.07vw;
  }
  .merits-item_btn {
    font-size: 5.33vw;
    padding: 1em 0 2.1em 0;
    border-radius: 1.0625em;
    background-position: center bottom 0.8em;
    background-size: 3.5em;
    line-height: 1.60075;
  }
  .merits-cs-mark {
    margin-top: 18vw;
  }
  .merits-cs-mark_content {
    flex-direction: column;
    gap: 8vw;
    align-items: center;
  }
  .merits-cs-mark_txt {
    width: 100%;
    line-height: 1.89;
    font-size: 4.488vw;
  }
  .merits-cs-mark_ttl {
    margin-bottom: 0.3em;
  }
  .merits-cs-mark_img {
    width: 62%;
  }
}

/*====================================================
FEATURE
====================================================*/
.feature_ttl {
  margin-bottom: 1.9em;
}
.feature-catch {
  font-size: 3rem;
  line-height: 1.53;
  margin-bottom: 2em;
}
.feature-catch_txt::before,
.feature-catch_txt::after {
  width: 2.2em;
  height: 2.5em;
}
.feature-catch_txt::before {
  left: -2.2em;
  top: -1em;
}
.feature-catch_txt::after {
  right: -2.2em;
  bottom: -1em;
}
.feature-head {
  padding-bottom: 6rem;
  position: relative;
}
.feature-head::after {
  content: '';
  position: absolute;
  display: block;
  width: 20rem;
  height: 7rem;
  clip-path: polygon(100% 0, 0 0, 50% 100%);
  background-color: #fff;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
}
.feature-head-item {
  width: 30%;
  flex-direction: column;
  align-items: center;
  gap: 2em;
}
.feature-head-item_txt-wrap {
  line-height: 1.89;
  background-color: #e0f4e8;
  padding: 2em 1.6em;
  flex: 1;
  border-radius: 1em;
  display: flex;
  align-items: center;
}
.feature-head-item_txt-wrap::after {
  content: '';
  position: absolute;
  width: 2.833em;
  aspect-ratio: 51/16;
  display: block;
  background-image: url(../img/index/feature_head_item_txt_bg.png);
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background-size: contain;
}
.feature-head-item_img {
  height: 18.5rem;
  object-fit: contain;
}
.feature-content {
  background-color: #e0f4e8;
  padding: 15rem 0;
}
.feature-content_ttl {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 4rem;
  text-align: center;
  background-color: #20b35c;
  border-radius: 0.35em;
  color: #fff;
  padding: 0.2em 0;
  margin-bottom: 0.7em;
}
.feature-content-overall-view {
  background-color: #fff;
  padding: 4rem 0 6.2rem;
  margin-bottom: 8rem;
}
.feature-content-overall-view_ttl {
  text-align: center;
}
.feature-content-overall-view_img {
  margin-bottom: 2rem;
}
.feature-content-overall-view_catch {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  padding: 0.6em 0 2.2em;
  background-image: url(../img/index/feature_content_overall_view_catch.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 10.54em;
}
.feature-content-overall-view-community_ttl {
  text-align: center;
  font-size: 3.6rem;
  font-weight: bold;
  margin-bottom: 0.1em;
}
.feature-content-overall-view-community_content {
  border-radius: 0.8rem;
  border: 4px solid #ed507e;
}
.feature-content-overall-view-community_content-ttl {
  text-align: center;
  font-weight: bold;
  font-size: 2.4rem;
  color: #fff;
  background-color: #ed507e;
  padding: 0.3em 0;
}
.feature-content-overall-view-community_content-txt {
  font-size: 2rem;
  line-height: 1.9;
  padding: 1em 1.9em 1.4em;
}
.feature-content-opt-in {
  margin-bottom: 5.5rem;
}
.feature-content-opt-in-ttl {
  font-size: 3rem;
  line-height: 1.53;
  margin-bottom: 1.5em;
}
.feature-content-opt-in-ttl_txt::before,
.feature-content-opt-in-ttl_txt::after {
  width: 2.2em;
  height: 2.5em;
}
.feature-content-opt-in-ttl_txt::before {
  left: -2.2em;
  top: -1em;
}
.feature-content-opt-in-ttl_txt::after {
  right: -2.2em;
  bottom: -1em;
}
.feature-content-opt-in-list {
  max-width: 78rem;
  margin: 0 auto;
}
.feature-content-opt-in-item_txt-wrap {
  line-height: 1.89;
  background-color: #fff;
  padding: 1.2em 1.6em;
  flex: 1;
  border-radius: 1em;
  display: flex;
  align-items: center;
}
.feature-content-opt-in-item_txt-wrap::after {
  content: '';
  position: absolute;
  width: 2.833em;
  aspect-ratio: 51/16;
  display: block;
  background-image: url(../img/index/feature_content_opt_in_item_txt_bg.png);
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background-size: contain;
}
.feature-content-opt-in-item {
  width: 46.15%;
  flex-direction: column;
  align-items: center;
  gap: 2em;
}
.feature-content-share-item {
  width: 48.33%;
  background-color: #fff;
  border-radius: 2rem;
  border: 5px solid #20b35c;
  text-align: center;
  padding: 4.3% 2.9% 3.3%;
}
.feature-content-share-item_ttl {
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 4.4rem;
  color: #005230;
  margin-bottom: 0.3em;
}
.feature-content-share-item_list {
  flex-direction: column;
  gap: 1.5rem;
}
.feature-content-share-item_item {
  text-align: left;
  background-color: #e0f4e8;
  padding: 2.3rem 3.2rem;
}
.feature-content-share-item_item-ttl {
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 0.1em;
}
.feature-content-share-item_item-ttl-num {
  font-size: 1.8rem;
  background-color: #20b35c;
  color: #fff;
  width: 1.56em;
  height: 1.56em;
  text-align: center;
  border-radius: 0.17em;
  margin-right: 0.8em;
}
.feature-content-share-item_item-ttl-txt {
  font-size: 2.4rem;
  font-weight: bold;
}
.feature-content-share-item_img {
  margin-bottom: 2rem;
}
.feature-content-share-item_item-txt {
  font-size: 2rem;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .feature-content_ttl {
    font-size: 3.33vw;
  }
  .feature-head_second-inner {
    width: 80%;
  }
  .feature-catch {
    font-size: 2.5vw;
  }
  .feature-head-item {
    width: 31.5%;
    font-size: 1.5vw;
  }
  .feature-content {
    padding: 12.5vw 0;
  }
  .feature-content_inner {
    width: 95%;
  }
  .feature-content-overall-view {
    padding: 3.33vw 2.5% 5.17vw;
  }
  .feature-content-overall-view-community_content-ttl {
    font-size: 2vw;
  }
  .feature-content-overall-view-community_content-txt {
    font-size: 1.67vw;
  }
  .feature-content-opt-in-ttl {
    font-size: 2.5vw;
  }
  .feature-content-opt-in_inner {
    width: 80%;
  }
  .feature-content-share-item_ttl {
    font-size: 3.67vw;
  }
  .feature-content-share-item_img {
    height: 17.47vw;
  }
  .feature-content-share-item_item-ttl-num {
    font-size: 1.5vw;
  }
  .feature-content-share-item_item-ttl-txt {
    font-size: 2vw;
  }
  .feature-content-share-item_item-txt {
    font-size: 1.67vw;
  }
}
@media screen and (max-width: 767px) {
  .feature-head {
    padding-bottom: 20vw;
  }
  .feature-head_second-inner {
    width: 100%;
  }
  .feature-head-list {
    gap: 9vw;
  }
  .feature-head-item {
    width: 100%;
    font-size: 4.47vw;
  }
  .feature-head-item_txt-wrap {
    line-height: 1.89;
  }
  .feature-head-item_img {
    height: 46.5vw;
  }
  .feature-head::after {
    width: 24vw;
    height: 11vw;
  }
  .feature-content {
    padding: 20vw 0;
  }
  .feature-content_ttl {
    font-size: 6.4vw;
    margin-bottom: 1em;
  }
  .feature-content-overall-view {
    padding: 7.2vw 5% 8.3vw;
    margin-bottom: 11vw;
  }
  .feature-content-overall-view_ttl-img {
    width: 66vw;
  }
  .feature-content-overall-view_catch {
    font-size: 4vw;
    padding: 0.7em 0 1.5em;
    background-size: 11em;
    margin-bottom: 0.7em;
  }
  .feature-content-overall-view-community_ttl {
    font-size: 6.4vw;
  }
  .feature-content-overall-view-community_content {
    border-radius: 2.13vw;
  }
  .feature-content-overall-view-community_content-ttl {
    font-size: 4.53vw;
    line-height: 1.38;
    padding: 0.6em 0;
  }
  .feature-content-overall-view-community_content-txt {
    font-size: 3.73vw;
    line-height: 1.93;
    padding: 1.1em 1.1em 1.4em;
  }
  .feature-content-opt-in {
    margin-bottom: 18vw;
  }
  .feature-content-opt-in_inner {
    width: 100%;
  }
  .feature-content-opt-in-list {
    flex-direction: column;
    gap: 13vw;
  }
  .feature-content-opt-in-item {
    width: 100%;
    gap: 3em;
  }
  .feature-content-opt-in-item_txt-wrap {
    font-size: 4.45vw;
    line-height: 1.89;
    padding: 1.1em 1.8em;
  }
  .feature-content-opt-in-item_img {
    height: 39vw;
    width: auto;
  }
  .feature-content-share-list {
    flex-direction: column;
    gap: 7vw;
  }
  .feature-content-share-item {
    width: 100%;
    padding: 8.1vw 5%;
  }
  .feature-content-share-item_ttl {
    font-size: 6.93vw;
    margin-bottom: 0.5em;
  }
  .feature-content-share-item_img {
    height: 34vw;
    width: auto;
    margin-bottom: 5vw;
  }
  .feature-content-share-item_item {
    padding: 5.5vw 3.5vw;
  }
  .feature-content-share-item_item-ttl-txt {
    font-size: 4.27vw;
  }
  .feature-content-share-item_item-ttl-num {
    font-size: 3.52vw;
    width: 1.56em;
    height: 1.56em;
    margin-right: 0.6em;
  }
  .feature-content-share-item_item-txt {
    font-size: 3.73vw;
    line-height: 1.79;
  }
}

/*====================================================
CASE
====================================================*/
.case {
  padding-bottom: 13.5rem;
}
.case_ttl {
  margin-bottom: 2.3em;
}
.case-list {
  justify-content: center;
  gap: 4rem 5%;
  align-items: stretch;
  margin-bottom: 12.5rem;
}
.case-item {
  width: 30%;
  border-radius: 2rem;
  border: 4px solid #20b35c;
  overflow: hidden;
  flex-direction: column;
  justify-content: flex-start;
}
.case-item_ttl {
  font-size: 3rem;
  color: #fff;
  background-color: #20b35c;
  text-align: center;
  padding: 0.2em 0;
}
.case-item_content {
  text-align: center;
  padding: 9% 7.5%;
  align-items: center;
  flex-direction: column;
  flex: 1;
  gap: 4.8rem;
}
.case-item_catch {
  text-align: left;
  font-size: 2.2rem;
  font-weight: bold;
  margin-top: 0.5em;
  margin-bottom: 0.8em;
}
.case-item_txt {
  text-align: left;
  line-height: 1.89;
}
.case-item_btn {
  background-color: #20b35c;
  color: #fff;
  display: inline-block;
  padding: 0.5em 3.4em;
  border-radius: 9999px;
  font-size: 2rem;
  background-image: url(../img/common/arrow_yellow.svg);
  background-repeat: no-repeat;
  background-size: 1.15em;
  background-position: right 0.8em center;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .case {
    padding-bottom: 11.25vw;
  }
  .case-list {
    justify-content: space-between;
    gap: 3.33vw 3%;
  }
  .case-item {
    width: 48.5%;
  }
  .case-item:last-child {
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .case {
    padding-bottom: 17vw;
  }
  .case-list {
    flex-direction: column;
    gap: 10vw;
    margin-bottom: 17vw;
  }
  .case-item {
    width: 100%;
    border-radius: 2.67vw;
  }
  .case_ttl {
    margin-bottom: 1.6em;
  }
  .case-item_ttl {
    font-size: 6.4vw;
    padding: 0.3em 0;
  }
  .case-item_content {
    gap: 5vw;
  }
  .case-item_img {
    width: auto;
    height: 42vw;
  }
  .case-item_catch {
    font-size: 5.432vw;
    margin-top: 0.9em;
    margin-bottom: 0.6em;
  }
  .case-item_txt {
    font-size: 4.44vw;
  }
  .case-item_btn {
    font-size: 5.33vw;
    padding: 0.55em 3.9em;
    background-position: right 1.4em center;
  }
  .case_second-inner {
    width: 100%;
  }
}

/*====================================================
DIFFERENCE
====================================================*/
.difference {
  padding-bottom: 12.5rem;
  background-color: #e0f4e8;
}
.difference-catch {
  font-size: 3.6rem;
  line-height: 1.53;
  margin-bottom: 2em;
}
.difference_ttl {
  margin-bottom: 2.5em;
}
.difference-catch_txt::before,
.difference-catch_txt::after {
  width: 2.2em;
  height: 2.5em;
}
.difference-catch_txt::before {
  left: -2.2em;
  top: -1em;
}
.difference-catch_txt::after {
  right: -2.2em;
  bottom: -1em;
}
.difference_txt {
  font-size: 2.4rem;
  line-height: 2;
  margin-bottom: 2.3em;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .difference {
    padding-bottom: 10.41666667vw;
  }
  .difference_inner {
    width: 80%;
  }
  .difference-catch {
    font-size: 3vw;
  }
  .difference_txt {
    font-size: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .difference_inner {
    width: 90%;
  }
  .difference_ttl {
    margin-bottom: 1.4em;
  }
  .difference_txt {
    font-size: 4.27vw;
  }
  .difference-catch {
    margin-bottom: 1em;
  }
}

/*====================================================
FUTURE
====================================================*/
.future {
  padding-bottom: 9rem;
}
.future_ttl {
  margin-bottom: 2em;
}
.future-catch {
  font-size: 3rem;
  line-height: 1.53;
  margin-bottom: 1.5em;
  margin-bottom: 2.4em;
}
.future-catch_txt::before,
.future-catch_txt::after {
  width: 2.2em;
  height: 2.5em;
}
.future-catch_txt::before {
  left: -2.2em;
  top: -1em;
}
.future-catch_txt::after {
  right: -2.2em;
  bottom: -1em;
}
.future_txt {
  font-size: 2rem;
  line-height: 1.9;
  margin-top: 1.8em;
}
.future-trademark {
  text-align: center;
  padding: 7rem 0 1rem;
}
.future-trademark_txt {
  font-size: 2rem;
  font-weight: bold;
  display: inline-block;
  border: 1px solid #c8c8c8;
  padding: 0.7em 1.2em;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .future {
    padding-bottom: 7.5vw;
  }
  .future_inner {
    width: 80%;
  }
  .future-catch {
    font-size: 2.5vw;
  }
  .future_txt {
    font-size: 1.67vw;
  }
}
@media screen and (max-width: 767px) {
  .future {
    padding-bottom: 22vw;
  }
  .future_inner {
    width: 90%;
  }
  .future_ttl {
    margin-bottom: 1.6em;
  }
  .future_txt {
    font-size: 4.27vw;
    line-height: 2;
  }
  .future-trademark {
    padding: 10vw 0 4vw;
  }
  .future-trademark_txt {
    font-size: 2rem;
    border: 1px solid #c8c8c8;
    padding: 0.4em 0;
    display: block;
    line-height: 1.625;
  }
}
