@charset "UTF-8";
.solution_core_lists .item_order_counter, .cc_section_heading strong, .problem_heading, .cc_price_field_legend, .cc_price_field_title strong, .cc_price_01 .item_tag, .cc_price_01 .item_price .bigger, .cc_price_02 .item_title strong, .cc_option_plan .item_tag, .insight_contact_btn_phone, .cc_faq .item_char, .data_menu_title, .cc_layout_tag {
  font-family: "Montserrat", sans-serif;
}

.problem_lists .item_title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.problem_lists .item_title {
  line-clamp: 2;
  -webkit-line-clamp: 2;
}

.insight_contact_btn_apply {
  font-family: "Noto Sans JP", sans-serif;
}

.utilization_btn_item {
  font-family: "M PLUS 1p", sans-serif;
}

.solution_core_lists .item_order_counter, .cc_section_heading strong, .problem_heading, .cc_price_field_legend, .cc_price_field_title strong, .cc_price_01 .item_tag, .cc_price_01 .item_price .bigger, .cc_price_02 .item_title strong, .cc_option_plan .item_tag, .insight_contact_btn_phone, .cc_faq .item_char, .data_menu_title, .cc_layout_tag {
  font-family: "Montserrat", sans-serif;
}

.cc_note, .flow_note > li, .data_note {
  font-size: 1.2rem;
}
@media only screen and (min-width: 768px) {
  .cc_note, .flow_note > li, .data_note {
    font-size: 1.4rem;
  }
}

.cc_price_01:has(.cc_price_field) + .cc_note, .cc_option_plan .item_displayed > li span, .cc_award_note_detail p {
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_01:has(.cc_price_field) + .cc_note, .cc_option_plan .item_displayed > li span, .cc_award_note_detail p {
    font-size: 1.6rem;
  }
}

.solution_power_list .item_content ul, .cc_price_field_tags > li, .cc_price_01 .item_lists > li, .p_solution_child .mv_child_kata > span {
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_content ul, .cc_price_field_tags > li, .cc_price_01 .item_lists > li, .p_solution_child .mv_child_kata > span {
    font-size: 1.7rem;
  }
}

.utilization_intro, .utilization_list_item .item_body, .cc_usage .item_info_detail, .cc_usage .item_note, .solution_power_list .item_exam, .solution_core_lists .item_body, .cc_price_field_sub_title, .cc_price_01 .item_intro, .flow_lists .item_estimated, .cc_feature_classic .item_body, .cc_award_list .item_title {
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .utilization_intro, .utilization_list_item .item_body, .cc_usage .item_info_detail, .cc_usage .item_note, .solution_power_list .item_exam, .solution_core_lists .item_body, .cc_price_field_sub_title, .cc_price_01 .item_intro, .flow_lists .item_estimated, .cc_feature_classic .item_body, .cc_award_list .item_title {
    font-size: 1.8rem;
  }
}

.utilization_info_data .item_title, .utilization_info_data .item_detail, .solution_power_list .item_content p, .problem_lists .item_body > p, .cc_price_01 .item_price_init, .cc_price_detail .item_body, .cc_option_plan .item_displayed > li, .insight_desc, .insight_mess, .flow_lists .item_txt, .data_menu_link {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .utilization_info_data .item_title, .utilization_info_data .item_detail, .solution_power_list .item_content p, .problem_lists .item_body > p, .cc_price_01 .item_price_init, .cc_price_detail .item_body, .cc_option_plan .item_displayed > li, .insight_desc, .insight_mess, .flow_lists .item_txt, .data_menu_link {
    font-size: 1.9rem;
  }
}

.cc_usage .item_tag, .solution_core_desc, .cc_section_leading, .cc_price_detail .item_link, .cc_option_plan .item_tag, .flow_lists .item_tags .item_rounded, .cc_feature_classic .item_link, .cc_faq .item_a .item_body, .data_desc, .data_menu_link .txt, .cc_award_leading, .cc_layout_leading {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_tag, .solution_core_desc, .cc_section_leading, .cc_price_detail .item_link, .cc_option_plan .item_tag, .flow_lists .item_tags .item_rounded, .cc_feature_classic .item_link, .cc_faq .item_a .item_body, .data_desc, .data_menu_link .txt, .cc_award_leading, .cc_layout_leading {
    font-size: 2rem;
  }
}

.problem_lists .item_body > ul li, .cc_price_field_legend, .cc_price_01 .item_tag {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item_body > ul li, .cc_price_field_legend, .cc_price_01 .item_tag {
    font-size: 2.1rem;
  }
}

.cc_usage .item_info_title, .problem_solution_heading_kata, .cc_price_02 .item_tags > li, .flow_lists .item_rounded {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_info_title, .problem_solution_heading_kata, .cc_price_02 .item_tags > li, .flow_lists .item_rounded {
    font-size: 2.2rem;
  }
}

.p_solution_child .mv_child_leading, .insight_contact_btn_apply {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .p_solution_child .mv_child_leading, .insight_contact_btn_apply {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.003164557 * (100vw - 768px)),
        2.5rem
    );
  }
}

.solution_power_list .item_sub_title, .cc_faq .item_char, .cc_layout_tag {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_sub_title, .cc_faq .item_char, .cc_layout_tag {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.0047468354 * (100vw - 768px)),
        2.6rem
    );
  }
}

.cc_price_field_tag, .cc_price_01 .item_title {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_field_tag, .cc_price_01 .item_title {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.0063291139 * (100vw - 768px)),
        2.7rem
    );
  }
}

.cc_option_plan .item_order, .p_solution_child .mv_child_kata {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan .item_order, .p_solution_child .mv_child_kata {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.0079113924 * (100vw - 768px)),
        2.8rem
    );
  }
}

.problem_lists[data-col="3"] .item_title {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="3"] .item_title {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.0094936709 * (100vw - 768px)),
        2.9rem
    );
  }
}

.solution_core_lists .item_title, .problem_lists .item_title, .flow_lists .item_title, .cc_faq .item_q, .cc_faq .item_q .item_body {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .solution_core_lists .item_title, .problem_lists .item_title, .flow_lists .item_title, .cc_faq .item_q, .cc_faq .item_q .item_body {
    font-size: clamp(
        2.5rem,
        calc(2.5rem + 0.0079113924 * (100vw - 768px)),
        3rem
    );
  }
}

.cc_usage .item_title, .solution_core_lists .item_order_counter, .problem_leading, .cc_price_detail .item_title, .cc_option_plan .item_title, .insight_contact_btn_phone, .cc_feature_classic .item_title {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_title, .solution_core_lists .item_order_counter, .problem_leading, .cc_price_detail .item_title, .cc_option_plan .item_title, .insight_contact_btn_phone, .cc_feature_classic .item_title {
    font-size: clamp(
        2.5rem,
        calc(2.5rem + 0.0110759494 * (100vw - 768px)),
        3.2rem
    );
  }
}

.cc_price_01 .item_price {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 .item_price {
    font-size: clamp(
        2.5rem,
        calc(2.5rem + 0.0142405063 * (100vw - 768px)),
        3.4rem
    );
  }
}

.solution_power_list .item_title, .insight_contact_tag {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_title, .insight_contact_tag {
    font-size: clamp(
        2.5rem,
        calc(2.5rem + 0.0174050633 * (100vw - 768px)),
        3.6rem
    );
  }
}

.problem_solution_phrase, .insight_heading {
  font-size: 2.2rem;
}
@media only screen and (min-width: 768px) {
  .problem_solution_phrase, .insight_heading {
    font-size: clamp(
        3rem,
        calc(3rem + 0.0158227848 * (100vw - 768px)),
        4rem
    );
  }
}

.data_heading {
  font-size: 2.2rem;
}
@media only screen and (min-width: 768px) {
  .data_heading {
    font-size: clamp(
        3rem,
        calc(3rem + 0.0221518987 * (100vw - 768px)),
        4.4rem
    );
  }
}

.data_menu_title {
  font-size: 2.2rem;
}
@media only screen and (min-width: 768px) {
  .data_menu_title {
    font-size: clamp(
        3rem,
        calc(3rem + 0.0237341772 * (100vw - 768px)),
        4.5rem
    );
  }
}

.cc_section_title, .cc_price_field_title, .cc_award_heading, .cc_layout_title {
  font-size: 2.2rem;
}
@media only screen and (min-width: 768px) {
  .cc_section_title, .cc_price_field_title, .cc_award_heading, .cc_layout_title {
    font-size: clamp(
        3rem,
        calc(3rem + 0.0253164557 * (100vw - 768px)),
        4.6rem
    );
  }
}

.cc_price_02 .item_title {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item_title {
    font-size: clamp(
        3.5rem,
        calc(3.5rem + 0.0284810127 * (100vw - 768px)),
        5.3rem
    );
  }
}

.cc_section_heading {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .cc_section_heading {
    font-size: clamp(
        3.5rem,
        calc(3.5rem + 0.0316455696 * (100vw - 768px)),
        5.5rem
    );
  }
}

.cc_price_01 .item_price .bigger {
  font-size: 3.2rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 .item_price .bigger {
    font-size: clamp(
        4rem,
        calc(4rem + 0.0411392405 * (100vw - 768px)),
        6.6rem
    );
  }
}

.cc_section_heading strong {
  font-size: 3.5rem;
}
@media only screen and (min-width: 768px) {
  .cc_section_heading strong {
    font-size: clamp(
        4.5rem,
        calc(4.5rem + 0.0411392405 * (100vw - 768px)),
        7.1rem
    );
  }
}

.problem_heading {
  font-size: 5rem;
}
@media only screen and (min-width: 768px) {
  .problem_heading {
    font-size: clamp(
        5.5rem,
        calc(5.5rem + 0.0474683544 * (100vw - 768px)),
        8.5rem
    );
  }
}

.cc_price_field_title strong {
  font-size: 5rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_field_title strong {
    font-size: clamp(
        5.5rem,
        calc(5.5rem + 0.0522151899 * (100vw - 768px)),
        8.8rem
    );
  }
}

.cc_price_02 .item_title strong {
  font-size: 5rem;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item_title strong {
    font-size: clamp(
        5.5rem,
        calc(5.5rem + 0.0537974684 * (100vw - 768px)),
        8.9rem
    );
  }
}

.cc_layout {
  --cc-bg-color: var(--color-sub-1);
  position: relative;
  margin-top: 60px;
  padding-bottom: 60px;
}
@media only screen and (min-width: 768px) {
  .cc_layout {
    margin-top: 82px;
    padding-bottom: 100px;
  }
}
@media only screen and (min-width: 768px) {
  .cc_layout + .cc_layout {
    margin-top: 141px;
  }
}
.cc_layout[data-themes=right]::before, .cc_layout[data-themes=left]::before {
  content: "";
  top: 18px;
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=right]::before, .cc_layout[data-themes=left]::before {
    width: 77.533333%;
    top: 22px;
  }
}
.cc_layout[data-themes=right]::before {
  right: 0;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=right]::before {
    border-top-left-radius: 60px;
  }
}
.cc_layout[data-themes=left]::before {
  left: 0;
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=left]::before {
    border-top-right-radius: 80px;
  }
}
.cc_layout[data-themes=cover] {
  color: #fff;
  margin-top: 0;
  padding-top: 60px;
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=cover] {
    padding-top: 134px;
    padding-bottom: 76px;
    margin-top: 0;
  }
}
.cc_layout[data-themes=cover]::before {
  content: "";
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=cover] + .cc_layout {
    margin-top: 122px;
  }
}
@media only screen and (min-width: 768px) {
  .cc_layout[data-themes=none] + .cc_layout {
    margin-top: 35px;
  }
}
.cc_layout::before {
  background-color: var(--cc-bg-color);
  position: absolute;
  inset: 0;
  z-index: -1;
}
.cc_layout_tag {
  font-weight: 700;
  line-height: 1.2307692308;
  letter-spacing: 0.12em;
  color: #fff;
  text-align: center;
  width: 280px;
  height: 36px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -18px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_layout_tag {
    width: 356px;
    height: 44px;
    margin-top: -22px;
  }
}
.cc_layout_tag::after {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  background-color: var(--color-main-1);
  mask-image: url("./../images/common/bg_solution_tag.svg");
  mask-position: center center;
  mask-repeat: no-repeat;
  mask-size: contain;
}
.cc_layout_tag + .cc_layout_title {
  margin-top: 16px;
}
@media only screen and (min-width: 768px) {
  .cc_layout_tag + .cc_layout_title {
    margin-top: 28px;
  }
}
.cc_layout_title {
  font-weight: 700;
  line-height: 1.1086956522;
  letter-spacing: 0.07em;
  text-align: center;
}
.cc_layout_leading {
  font-weight: 400;
  line-height: 1.85;
  letter-spacing: 0.04em;
  margin-top: 23px;
}
@media only screen and (min-width: 768px) {
  .cc_layout_leading {
    text-align: center;
  }
}

.cc_award_heading {
  font-weight: 800;
  letter-spacing: 0.07em;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .cc_award_heading {
    line-height: 1.1086956522;
  }
}
.cc_award_logo {
  width: 300px;
  margin-top: 17px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_award_logo {
    width: 578px;
  }
}
.cc_award_leading {
  font-weight: 400;
  line-height: 1.85;
  letter-spacing: 0.05em;
  color: #464646;
  text-align: center;
  margin-top: 19px;
}
.cc_award_list {
  width: clamp(300px, (100vw - 500px) * 1000, 100%);
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 30px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_award_list {
    width: 100%;
    max-width: 950px;
    gap: 40px;
    margin-top: 48px;
  }
}
.cc_award_list .item {
  width: clamp(50% - 10px, (500px - 100vw) * 1000, 100%);
}
@media only screen and (min-width: 768px) {
  .cc_award_list .item {
    width: clamp(33.33% - 26.6666666667px, (900px - 100vw) * 1000, 50% - 20px);
  }
}
.cc_award_list .item_photo {
  width: 100%;
}
.cc_award_list .item_title {
  font-weight: 700;
  line-height: 1.6666666667;
  letter-spacing: 0.08em;
  margin-top: 11px;
  text-align: center;
}
.cc_award_note {
  display: flex;
  gap: 10px 20px;
  align-items: center;
  flex-direction: column;
  border: 1px solid #707070;
  padding: 10px 20px 20px;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .cc_award_note {
    flex-direction: row;
    margin-top: 46px;
    padding: 19px 33px 14px;
  }
}
.cc_award_note_icon {
  width: 168px;
  flex-shrink: 0;
}
.cc_award_note_detail p {
  font-weight: 400;
  line-height: 1.625;
  color: var(--color-txt);
}
.cc_award_note_detail p a,
.cc_award_note_detail p strong {
  font-weight: 600;
  color: #4b9eff;
}
.cc_award_note_detail p a {
  text-decoration: underline;
  text-underline-offset: 3px;
}
@media only screen and (min-width: 768px) {
  .cc_award_note_detail p a {
    transition: 300ms ease;
  }
  .cc_award_note_detail p a:hover {
    text-decoration-color: rgba(0, 0, 0, 0);
  }
}

.core {
  padding-bottom: 48px;
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  text-align: center;
}
.core_heading {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  margin-bottom: 12px;
}
.core_desc {
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 1.85;
  margin-bottom: 42px;
  text-align: left;
}
.core_desc br {
  display: none;
}
.core_list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-left: 0;
  gap: 28px;
}
.core_item {
  width: 100%;
  padding: 0;
}
.core_item_content {
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  line-height: 1.6;
}
.core_item_inner {
  height: 100%;
  padding: 12px;
  border-radius: 14px;
}
.core_item_head {
  display: flex;
  position: relative;
  padding-left: 60px;
  margin-bottom: 7px;
}
.core_item_head .icon {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 50px;
  width: auto;
}
.core_item_head .icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.core_item_head .text {
  color: var(--text-color);
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: 0.03em;
}
.core_content {
  text-align: left;
  font-size: 1.8rem;
  color: var(--text-color);
}
.core_content .color-dark-orange {
  font-weight: 800;
}

@media only screen and (min-width: 768px) {
  .core_heading {
    font-size: 4rem;
  }
  .core_desc {
    font-size: 1.6rem;
    margin-bottom: 20px;
    text-align: left;
  }
  .core_desc br {
    display: none;
  }
  .core_list {
    width: calc(100% + 40px);
    margin-left: -20px;
    gap: 0;
  }
  .core_item {
    width: 50%;
    padding: 20px;
  }
  .core_item_content {
    font-size: 1.6rem;
  }
  .core_item_inner {
    padding: 12px 20px;
    border-radius: 14px;
  }
  .core_item_head {
    padding-left: 90px;
    margin-bottom: 7px;
  }
  .core_item_head .icon {
    height: 70px;
  }
  .core_item_head .text {
    font-size: 2.2rem;
  }
}
@media only screen and (min-width: 1025px) {
  .core {
    padding-bottom: 80px;
    margin-top: 59px;
  }
  .core_heading {
    font-size: 4.6rem;
    margin-bottom: 8px;
  }
  .core_desc {
    font-size: 2rem;
    margin-bottom: 27px;
    text-align: center;
  }
  .core_desc br {
    display: inline;
  }
  .core_list {
    width: calc(100% + 40px);
    margin-left: -20px;
    gap: 0;
  }
  .core_item {
    width: 50%;
    padding: 20px;
  }
  .core_item_content {
    font-size: 1.9rem;
  }
  .core_item_inner {
    height: 100%;
    padding: 19px 32px 35px 32px;
    border-radius: 20px;
  }
  .core_item_head {
    padding-left: 113px;
    margin-bottom: 7px;
  }
  .core_item_head .icon {
    height: 84px;
  }
  .core_item_head .text {
    font-size: 3rem;
  }
}
.data {
  position: relative;
  z-index: 1;
  padding: 30px 0;
}
@media only screen and (min-width: 768px) {
  .data {
    padding: 33px 0 50px 0;
  }
}
.data_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.data_bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.data_subtitle {
  font-size: 1.8rem;
  letter-spacing: 0.03em;
  font-weight: 700;
  line-height: 1.5;
}
.data_heading {
  font-weight: 700;
  line-height: 1.5454545455;
  color: var(--color-txt);
}
.data_desc {
  line-height: 1.85;
  letter-spacing: 0.05em;
  color: var(--color-txt);
  margin-top: 10px;
}
.data_note {
  font-weight: 300;
  line-height: 1.9285714286;
  letter-spacing: 0.045em;
  color: var(--color-txt);
}
.data_menu {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .data_menu {
    margin-top: 78px;
  }
}
.data_menu_title {
  font-weight: 800;
  letter-spacing: 0.11em;
  line-height: 1.25;
  color: var(--color-main-1);
}
.data_menu_list {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 10px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .data_menu_list {
    gap: 22px;
    flex-direction: row;
    margin-left: -1px;
    margin-right: -1px;
  }
}
.data_menu_item {
  width: calc(50% - 4px);
  padding: 0;
}
@media only screen and (min-width: 768px) {
  .data_menu_item {
    width: 173px;
  }
}
.data_menu_link {
  font-weight: 700;
  line-height: 1.3684210526;
  letter-spacing: 0.1em;
  color: var(--color-main-1);
  width: 100%;
  display: flex;
  gap: 8px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px;
  border: 1px solid var(--color-main-1);
  background-color: #fff;
  border-radius: 10px;
}
@media only screen and (min-width: 768px) {
  .data_menu_link {
    height: 70px;
    border-width: 2px;
    transition: 300ms ease;
    cursor: pointer;
  }
  .data_menu_link:hover {
    opacity: 1;
    background-color: var(--color-main-1);
    color: #fff;
  }
}
.data_menu_link::after {
  content: "";
  width: 26px;
  aspect-ratio: 3.0833333333;
  display: inline-block;
  background-color: currentColor;
  mask-image: url("./../images/common/icon_arc_down.svg");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  transition: inherit;
}
@media only screen and (min-width: 768px) {
  .data_menu_link::after {
    width: 37px;
  }
}
.data_menu_link .txt {
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--color-main-1);
  transition: all 0.35s ease-in-out;
}

.cc_faq {
  margin-top: 30px;
  padding-bottom: 30px;
}
@media only screen and (min-width: 768px) {
  .cc_faq {
    margin-top: 62px;
    padding-bottom: 55px;
  }
}
.cc_faq .list {
  display: flex;
  gap: 20px;
  flex-direction: column;
  padding-left: 20px;
}
@media only screen and (min-width: 768px) {
  .cc_faq .list {
    gap: 30px;
    padding-left: 30px;
  }
}
.cc_faq .item {
  --cc-color: var(--color-accent-1);
}
.cc_faq .item_q {
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.1em;
  color: #fff;
  display: flex;
  gap: 6px;
  align-items: center;
  background-color: #5eb7e8;
  border-radius: 13px 13px 0 0;
  padding: 12px 12px 12px 0;
}
@media only screen and (min-width: 768px) {
  .cc_faq .item_q {
    min-height: 80px;
  }
}
.cc_faq .item_q .item_body {
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.1em;
}
.cc_faq .item_q .item_char {
  color: #5eb7e8;
}
.cc_faq .item_q .item_char::before {
  background-color: #fff;
}
.cc_faq .item_q .item_char::after {
  background-color: #5eb7e8;
}
.cc_faq .item_a {
  display: flex;
  gap: 6px;
  align-items: flex-start;
  background-color: #ebf4ff;
  border-radius: 0 0 13px 13px;
  padding: 12px 12px 12px 0;
}
@media only screen and (min-width: 768px) {
  .cc_faq .item_a {
    min-height: 80px;
    padding: 12px 38px 16px 0;
  }
}
.cc_faq .item_a .item_body {
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.05em;
  color: var(--color-txt);
}
.cc_faq .item_a strong {
  font-weight: 800;
  color: var(--cc-color);
}
.cc_faq .item_a .item_char {
  color: #fff;
  top: 3px;
}
.cc_faq .item_a .item_char::before, .cc_faq .item_a .item_char::after {
  background-color: var(--cc-color);
}
.cc_faq .item_char {
  font-weight: 800;
  line-height: 1.7307692308;
  width: 30px;
  aspect-ratio: 1.1764705882;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 0;
  left: -15px;
  flex-shrink: 0;
}
@media only screen and (min-width: 768px) {
  .cc_faq .item_char {
    width: 60px;
    left: -30px;
  }
}
.cc_faq .item_char::before, .cc_faq .item_char::after {
  content: "";
  width: calc(100% + 24px);
  aspect-ratio: 1.1538461538;
  position: absolute;
  left: -12px;
  z-index: -1;
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: right center;
}
@media only screen and (min-width: 768px) {
  .cc_faq .item_char::before, .cc_faq .item_char::after {
    width: 100%;
    width: 60px;
    left: 0;
  }
}
.cc_faq .item_char::before {
  mask-image: url("./../images/solution_area_signal/icon_faq_fill.svg");
}
.cc_faq .item_char::after {
  mask-image: url("./../images/solution_area_signal/icon_faq_border.svg");
}

.cc_feature_classic {
  margin-top: 48px;
}
.cc_feature_classic .list {
  display: flex;
  gap: 40px 20px;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .list {
    gap: 50px;
  }
}
.cc_feature_classic .item {
  --cc-color: #2866de;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .item {
    width: clamp(33.33% - 33.3333333333px, (1025px - 100vw) * 1000, 50% - 25px);
  }
}
.cc_feature_classic .item_photo {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .item_photo {
    min-height: 200px;
  }
}
.cc_feature_classic .item_photo img {
  width: auto;
  max-width: 100%;
}
.cc_feature_classic .item_title {
  font-weight: 800;
  line-height: 1.59375;
  letter-spacing: 0.07em;
  color: var(--cc-color);
  text-align: center;
  margin-top: 18px;
}
.cc_feature_classic .item_body {
  line-height: 1.9444444444;
  letter-spacing: 0.08em;
  min-height: 80px;
  margin-top: 12px;
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .item_body {
    min-height: 100px;
  }
}
.cc_feature_classic .item_body strong {
  font-weight: 800;
  color: var(--cc-color);
}
.cc_feature_classic .item_link {
  font-weight: 800;
  letter-spacing: 0.2em;
  color: #fc83b6;
  width: 240px;
  max-width: 100%;
  min-height: 41px;
  display: flex;
  align-items: center;
  position: relative;
  margin-top: 16px;
  margin-left: auto;
  margin-right: auto;
  padding: 4px 60px 4px 24px;
  filter: drop-shadow(2px 2px 7px rgba(77, 71, 61, 0.24));
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .item_link {
    width: 305px;
    min-height: 52px;
    opacity: 1;
    margin-top: 20px;
  }
  .cc_feature_classic .item_link:hover {
    color: #fff;
  }
  .cc_feature_classic .item_link:hover::before {
    background-color: #fc83b6;
  }
}
.cc_feature_classic .item_link::before, .cc_feature_classic .item_link::after {
  content: "";
  position: absolute;
  inset: 0;
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: right center;
}
.cc_feature_classic .item_link::before {
  background-color: #fff;
  mask-image: url("./../images/solution_area_signal/bg_btn.svg");
  z-index: -1;
  transition: 300ms ease;
}
.cc_feature_classic .item_link::after {
  mask-image: url("./../images/solution_area_signal/bg_btn_border.svg");
  background-color: #fc83b6;
}
.cc_feature_classic .item_link .icon {
  width: 24px;
  aspect-ratio: 0.9285714286;
  position: absolute;
  top: 50%;
  right: 20px;
  translate: 0 -50%;
  background-color: currentColor;
  mask-image: url("./../images/solution_area_signal/icon_btn_more.svg");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: right center;
}
@media only screen and (min-width: 768px) {
  .cc_feature_classic .item_link .icon {
    width: 30px;
  }
}

.flow {
  margin-top: 80px;
}
@media only screen and (min-width: 768px) {
  .flow {
    margin-top: 142px;
  }
}
.flow_lists {
  display: flex;
  gap: 80px;
  flex-direction: column;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .flow_lists {
    gap: 60px;
    padding-left: 44px;
  }
}
.flow_lists .item {
  --cc-color: var(--color-accent-3);
  background-color: #f4f9ff;
  border: 2px solid var(--cc-color);
  border-radius: 13px;
  position: relative;
  padding: 14px;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item {
    padding: 12px 14px;
    padding-top: clamp(12px, (1025px - 100vw) * 1000, 30px);
    border-width: 3px;
  }
}
.flow_lists .item:nth-child(2) {
  --cc-color: var(--color-accent-4);
}
.flow_lists .item:nth-child(3) {
  --cc-color: var(--color-accent-1);
}
.flow_lists .item:nth-child(4) {
  --cc-color: var(--color-accent-6);
}
.flow_lists .item + .item::before {
  content: "";
  position: absolute;
  top: -47px;
  left: 50%;
  translate: -50% -50%;
  border-top: 15px solid #bec1c6;
  border-left: 40px solid rgba(190, 193, 198, 0);
  border-right: 40px solid rgba(190, 193, 198, 0);
}
@media only screen and (min-width: 768px) {
  .flow_lists .item + .item::before {
    top: -33px;
    left: 48%;
    border-top: 30px solid #bec1c6;
    border-left: 80px solid rgba(190, 193, 198, 0);
    border-right: 80px solid rgba(190, 193, 198, 0);
  }
}
.flow_lists .item_row {
  --row-width: 1078;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_row {
    min-height: 80px;
    display: flex;
    gap: 30px 10px;
    flex-wrap: wrap;
    flex-direction: row;
  }
}
.flow_lists .item_col:nth-child(1) {
  width: 100px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_col:nth-child(1) {
    width: calc(54 / var(--row-width) * 100% - 10px);
    width: 44px;
    align-self: center;
    margin-left: 0;
    margin-right: 0;
  }
}
.flow_lists .item_col:nth-child(2) {
  width: 100%;
  margin-top: 14px;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_col:nth-child(2) {
    width: calc(287 / (var(--row-width) - 204) * 100% - 10px);
    width: clamp(287 / (var(--row-width) - 204) * 100% - 10px, (1025px - 100vw) * 1000, 100% - 100px);
    align-self: center;
    margin-top: 0;
  }
}
.flow_lists .item_col:nth-child(3) {
  width: 100%;
  margin-top: 10px;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_col:nth-child(3) {
    flex: 1;
    align-self: center;
    margin-top: 0;
  }
}
.flow_lists .item_col:nth-child(4) {
  width: 100%;
  flex-shrink: 0;
  margin-top: 14px;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_col:nth-child(4) {
    width: 160px;
    margin-top: 0px;
  }
}
.flow_lists .item_icon {
  width: 100%;
  position: relative;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_icon {
    height: 44px;
  }
}
.flow_lists .item_icon::after {
  content: "";
  width: 100%;
  aspect-ratio: 1.1678947368;
  background-color: var(--cc-color);
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  mask-image: url("./../images/common/img_frame.svg");
  mask-position: center center;
  mask-repeat: no-repeat;
  mask-size: 100%;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_icon::after {
    width: 201.7272727273%;
    left: -17px;
  }
}
.flow_lists .item_icon img {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_icon img {
    width: 201.7272727273%;
    aspect-ratio: 1.1678947368;
    position: absolute;
    top: 50%;
    left: -16px;
    translate: -50% -50%;
  }
}
.flow_lists .item_title {
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.07em;
  padding-top: 2px;
  margin-left: -6px;
  margin-right: -6px;
}
.flow_lists .item_txt {
  font-weight: 400;
  line-height: 1.4736842105;
  letter-spacing: 0.05em;
  color: var(--color-txt);
}
.flow_lists .item_rounded {
  font-weight: 800;
  line-height: 1.4545454545;
  letter-spacing: 0.15em;
  text-align: center;
  color: #fff;
  width: 100%;
  background-color: var(--cc-color);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_rounded {
    min-height: 80px;
    padding: 12px;
  }
}
.flow_lists .item_tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_tags[data-count="2"] .item_rounded:nth-child(2) {
    width: calc(66.66% - 5.3333333333px);
  }
}
.flow_lists .item_tags .item_rounded {
  width: calc(50% - 4px);
  width: clamp(50% - 4px, (640px - 100vw) * 1000, 100%);
  min-height: 60px;
  font-weight: 700;
  letter-spacing: 0.06em;
}
@media only screen and (min-width: 768px) {
  .flow_lists .item_tags .item_rounded {
    width: calc(33.33% - 5.3333333333px);
    min-height: 80px;
  }
}
.flow_lists .item_estimated {
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.045em;
  color: var(--color-txt);
  padding: 1px 10px;
}
.flow_lists .item_estimated .other {
  font-weight: 800;
  color: var(--cc-color);
}
.flow_note {
  margin-top: 16px;
}
.flow_note > li {
  font-weight: 300;
  line-height: 1.7857142857;
  letter-spacing: 0.045em;
  color: var(--color-txt);
  display: flex;
}
.flow_note > li::before {
  content: "※";
  flex-shrink: 0;
}

.insight {
  background-color: #5eb7e8;
  color: #fff;
  position: relative;
  padding: 90px 0 40px;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .insight {
    padding-top: 80px;
  }
}
.insight_photo {
  width: 120px;
  position: absolute;
  top: -60px;
  right: 11.3%;
}
@media only screen and (min-width: 768px) {
  .insight_photo {
    width: 243px;
    max-width: 20%;
    position: absolute;
    top: -97px;
  }
}
.insight_photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}
.insight_heading {
  font-weight: 700;
  line-height: 1.525;
  letter-spacing: 0.05em;
}
.insight_desc {
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.8421052632;
  margin-top: 14px;
}
.insight_border {
  max-width: 360px;
  margin-top: 30px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .insight_border {
    margin-top: 45px;
  }
}
.insight_contact {
  width: 340px;
  max-width: 100%;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 17px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .insight_contact {
    width: 100%;
    gap: 20px 40px;
    padding-left: 10px;
    padding-right: 10px;
  }
}
.insight_contact_tag {
  display: inline-flex;
  font-weight: 700;
  line-height: 1.9444444444;
  letter-spacing: 0.09em;
  position: relative;
  margin-top: 40px;
  padding-left: 30px;
  padding-right: 30px;
}
@media only screen and (min-width: 768px) {
  .insight_contact_tag {
    padding-left: 60px;
    padding-right: 60px;
  }
}
.insight_contact_tag::before, .insight_contact_tag::after {
  content: "";
  width: 2px;
  height: 28px;
  background-color: currentColor;
  border-radius: 10px;
  position: absolute;
  top: 51%;
  translate: 0 -50%;
}
@media only screen and (min-width: 768px) {
  .insight_contact_tag::before, .insight_contact_tag::after {
    width: 4px;
    height: 46px;
  }
}
.insight_contact_tag::before {
  left: 12px;
  rotate: -45deg;
}
.insight_contact_tag::after {
  right: 12px;
  rotate: 45deg;
}
.insight_contact .lr_goals_more_link {
  width: 100%;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  padding: 8px 32px;
  filter: none;
}
@media only screen and (min-width: 768px) {
  .insight_contact .lr_goals_more_link {
    width: 521.82px;
    height: 76px;
    padding: 8px 110px;
  }
}
@media only screen and (min-width: 768px) {
  .insight_contact .lr_goals_more_link_arrow {
    width: 16px;
    height: 16px;
    right: 24px;
  }
}
.insight_contact_btn_apply .icon_left, .insight_contact_btn_apply .icon_right, .insight_contact_btn_phone .icon_left, .insight_contact_btn_phone .icon_right {
  position: absolute;
  top: 50%;
  translate: 0 -50%;
}
.insight_contact_btn_apply .icon_left, .insight_contact_btn_phone .icon_left {
  left: 20px;
}
.insight_contact_btn_apply .icon_right, .insight_contact_btn_phone .icon_right {
  right: 20px;
}
.insight_contact_btn_apply {
  font-weight: 800;
  letter-spacing: 0.13em;
}
.insight_contact_btn_apply .icon_left {
  width: 32px;
}
@media only screen and (min-width: 768px) {
  .insight_contact_btn_apply .icon_left {
    width: 51px;
    left: 40px;
  }
}
.insight_contact_btn_apply .icon_right {
  width: 24px;
}
@media only screen and (min-width: 768px) {
  .insight_contact_btn_apply .icon_right {
    width: 41px;
    right: 38px;
  }
}
.insight_contact_btn_phone {
  font-weight: 700;
  letter-spacing: 0.08em;
}
.insight_contact_btn_phone .icon_left {
  width: 28px;
}
@media only screen and (min-width: 768px) {
  .insight_contact_btn_phone .icon_left {
    width: 45px;
    left: 34px;
  }
}
.insight_mess {
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.7894736842;
  margin-top: 24px;
  padding-bottom: 24px;
}
@media only screen and (min-width: 768px) {
  .insight_mess {
    margin-top: 37px;
    padding-bottom: 37px;
    text-align: center;
  }
}

.p_solution_child .mv_child {
  display: flex;
}
.p_solution_child .mv_child_inner {
  width: 280px;
  height: auto;
  gap: 10px;
  flex-shrink: 0;
  flex-direction: column;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .p_solution_child .mv_child_inner {
    width: 780px;
    width: clamp(600px, (100vw - 1025px) * 1000, 780px);
    gap: 24px;
    padding-top: 5px;
  }
}
.p_solution_child .mv_child_right, .p_solution_child .mv_child_left {
  width: 50%;
  position: relative;
}
.p_solution_child .mv_child_right::after, .p_solution_child .mv_child_left::after {
  content: "";
  width: 100vw;
  height: 100%;
  top: 0;
  position: absolute;
  background-color: var(--color-main-1);
  mask-image: url("./../images/common/img_mv_child_shape.svg");
  mask-size: cover;
  mask-repeat: no-repeat;
  mask-position: right center;
}
@media only screen and (min-width: 768px) {
  .p_solution_child .mv_child_right::after, .p_solution_child .mv_child_left::after {
    min-width: 830px;
    width: 57.6388888889vw;
  }
}
.p_solution_child .mv_child_left::after {
  right: 0;
}
.p_solution_child .mv_child_right::after {
  left: 0;
  scale: -1 1;
}
.p_solution_child .mv_child_leading {
  font-weight: 700;
  line-height: 1.48;
  letter-spacing: 0.12em;
  color: #4c4948;
  text-align: center;
}
.p_solution_child .mv_child_heading {
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .p_solution_child .mv_child_heading {
    max-width: calc(100% - 100px);
  }
}
@media only screen and (min-width: 768px) {
  .p_solution_child .mv_child_heading img {
    width: auto;
  }
}
.p_solution_child .mv_child_kata {
  font-weight: 900;
  line-height: 1.44;
  text-align: center;
}
.p_solution_child .mv_child_kata > span {
  font-weight: 500;
  letter-spacing: 0.15em;
}

.cc_note {
  font-weight: 300;
  line-height: 1.8571428571;
  letter-spacing: 0.045em;
  color: var(--color-txt);
  margin-top: 20px;
}

.cc_option_plan {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan {
    margin-top: 62px;
  }
}
.cc_option_plan .list {
  display: flex;
  gap: 60px 20px;
  flex-wrap: wrap;
  counter-reset: option-plan;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan .list {
    gap: 60px 42px;
    gap: 60px clamp(20px, (100vw - 1025px) * 1000, 42px);
  }
}
.cc_option_plan .item {
  --cc-color: var(--color-accent-3);
  --cc-bg-color: #e5fce5;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  background-color: var(--cc-bg-color);
  border-radius: 10px;
  counter-increment: option-plan;
  text-align: center;
  padding: 0px 20px 20px;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan .item {
    width: clamp(50% - 21px, (1025px - 100vw) * 1000, 50% - 10px);
    border-radius: 20px;
    padding: 0px 24px 26px;
  }
}
.cc_option_plan .item:nth-child(2) {
  --cc-color: var(--color-accent-4);
  --cc-bg-color: #dbf9ff;
}
.cc_option_plan .item:nth-child(3) {
  --cc-color: var(--color-accent-1);
  --cc-bg-color: #d4e5fa;
}
.cc_option_plan .item:nth-child(4) {
  --cc-color: var(--color-accent-6);
  --cc-bg-color: #ede0ff;
}
.cc_option_plan .item:nth-child(5) {
  --cc-color: var(--color-accent-2);
  --cc-bg-color: #f4f9ff;
}
.cc_option_plan .item:nth-child(6) {
  --cc-color: var(--color-accent-5);
  --cc-bg-color: #dbf9ff;
}
.cc_option_plan .item_tag {
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #fff;
  width: 300px;
  max-width: 100%;
  height: 40px;
  margin-top: -20px;
  background-color: var(--cc-color);
  border-radius: 99px;
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan .item_tag {
    width: 300px;
    height: 40px;
    padding-top: 5px;
  }
}
.cc_option_plan .item_order {
  font-weight: 800;
}
.cc_option_plan .item_order::after {
  content: counter(option-plan);
}
.cc_option_plan .item_title {
  font-weight: 800;
  line-height: 1.59375;
  letter-spacing: 0.1em;
  color: var(--color-rext);
  margin-top: 15px;
}
.cc_option_plan .item_displayed {
  margin-top: 17px;
}
.cc_option_plan .item_displayed > li {
  min-height: 56px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.05em;
  color: var(--cc-color);
  display: flex;
  gap: 4px;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  border-radius: 10px;
  padding: 8px 10px;
}
@media only screen and (min-width: 768px) {
  .cc_option_plan .item_displayed > li {
    gap: 0px;
  }
}
.cc_option_plan .item_displayed > li:nth-child(2n+1) {
  background-color: #fff;
}
.cc_option_plan .item_displayed > li span {
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.05em;
}

.cc_price_detail {
  margin-top: 48px;
}
.cc_price_detail + .cc_section_title {
  margin-top: 50px;
}
@media only screen and (min-width: 768px) {
  .cc_price_detail + .cc_section_title {
    margin-top: 63px;
  }
}
.cc_price_detail .list {
  display: flex;
  gap: 40px 20px;
  flex-wrap: wrap;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .cc_price_detail .list {
    gap: 50px;
  }
}
.cc_price_detail .item {
  --cc-color: #2866de;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
}
@media only screen and (min-width: 768px) {
  .cc_price_detail .item {
    width: clamp(33.33% - 33.3333333333px, (1025px - 100vw) * 1000, 50% - 25px);
  }
}
.cc_price_detail .item_photo {
  width: 80%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_price_detail .item_photo {
    width: 100%;
    min-height: 200px;
  }
}
.cc_price_detail .item_photo img {
  width: auto;
  max-width: 100%;
}
.cc_price_detail .item_title {
  font-weight: 800;
  line-height: 1.59375;
  letter-spacing: 0.07em;
  color: var(--cc-color);
  text-align: center;
  margin-top: 27px;
}
.cc_price_detail .item_body {
  line-height: 1.8421052632;
  letter-spacing: 0.115em;
  margin-top: 17px;
}
.cc_price_detail .item_body strong {
  font-weight: 800;
  color: var(--cc-color);
}
.cc_price_detail .item_link {
  font-weight: 800;
  letter-spacing: 0.2em;
  color: #fc83b6;
  width: 240px;
  max-width: 100%;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-top: 16px;
  filter: drop-shadow(2px 2px 7px rgba(77, 71, 61, 0.24));
}
@media only screen and (min-width: 768px) {
  .cc_price_detail .item_link {
    width: 305px;
    min-height: 52px;
    opacity: 1;
    margin-top: 24px;
  }
  .cc_price_detail .item_link:hover {
    color: #fff;
  }
  .cc_price_detail .item_link:hover::before {
    background-color: #fc83b6;
  }
}
.cc_price_detail .item_link::before, .cc_price_detail .item_link::after {
  content: "";
  position: absolute;
  inset: 0;
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: right center;
}
.cc_price_detail .item_link::before {
  background-color: #fff;
  mask-image: url("./../images/solution_area_signal/bg_btn.svg");
  z-index: -1;
  transition: 300ms ease;
}
.cc_price_detail .item_link::after {
  mask-image: url("./../images/solution_area_signal/bg_btn_border.svg");
  background-color: #fc83b6;
}
.cc_price_detail .item_link .icon {
  width: 24px;
  aspect-ratio: 0.9285714286;
  position: absolute;
  top: 50%;
  right: 20px;
  translate: 0 -50%;
  background-color: currentColor;
  mask-image: url("./../images/solution_area_signal/icon_btn_more.svg");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: right center;
}
@media only screen and (min-width: 768px) {
  .cc_price_detail .item_link .icon {
    width: 30px;
  }
}

.cc_price_field {
  width: 900px;
  max-width: 100%;
  background-color: #fff;
  border: 2px solid var(--cc-color);
  border-radius: 10px;
  position: relative;
  padding: 0 20px 20px;
}
@media only screen and (min-width: 768px) {
  .cc_price_field {
    border-radius: 13px;
    padding: 0 40px 43px;
  }
}
.cc_price_field_legend {
  font-weight: 600;
  letter-spacing: 0.11em;
  color: #fff;
  width: 100%;
  height: 44px;
  background-color: var(--cc-color);
  border-radius: 99px;
  translate: 0 -50%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .cc_price_field_legend {
    width: 300px;
  }
}
.cc_price_field_tag {
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.8888888889;
  color: var(--cc-color);
  text-align: center;
}
.cc_price_field_sub_title {
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--cc-color);
  text-align: center;
}
.cc_price_field_body {
  width: 700px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.cc_price_field_body hr {
  width: 100%;
  border-top: 2px solid var(--cc-color);
  margin-top: 4px;
  margin-bottom: 11px;
}
.cc_price_field_title {
  font-weight: 600;
  line-height: 1.4347826087;
  letter-spacing: 0.15em;
}
.cc_price_field_title strong {
  font-weight: 700;
  line-height: 1.15;
}
.cc_price_field_detail {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  margin-top: 24px;
}
@media only screen and (min-width: 768px) {
  .cc_price_field_detail {
    gap: 30px;
    flex-direction: row;
    align-items: flex-start;
  }
}
.cc_price_field_tags {
  width: 300px;
  max-width: 100%;
  display: flex;
  gap: 15px;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .cc_price_field_tags {
    width: 300px;
  }
}
.cc_price_field_tags > li {
  font-weight: 600;
  line-height: 1.5294117647;
  letter-spacing: 0.06em;
  text-align: center;
  width: 100%;
  min-height: 54px;
  background-color: #dbebff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
}
.cc_price_field_tags > li strong {
  font-weight: 900;
  color: var(--custom-color-2);
}

.cc_price_01 {
  margin-top: 50px;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 {
    margin-top: 74px;
  }
}
@media only screen and (min-width: 768px) {
  .cc_price_01:has(.cc_price_field) {
    margin-top: 104px;
  }
}
.cc_price_01:has(.cc_price_field) + .cc_note {
  font-weight: 700;
  line-height: 1.6875;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .cc_price_01:has(.cc_price_field) + .cc_note {
    margin-top: 24px;
  }
}
@media only screen and (min-width: 768px) {
  .cc_price_01 + .cc_note {
    margin-top: 28px;
  }
}
.cc_price_01 .list {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  justify-content: center;
}
.cc_price_01 .item,
.cc_price_01 .cc_price_field {
  --cc-color: var(--color-accent-4);
}
.cc_price_01 .item:nth-child(2),
.cc_price_01 .cc_price_field:nth-child(2) {
  --cc-color: var(--color-accent-1);
}
.cc_price_01 .item:nth-child(3),
.cc_price_01 .cc_price_field:nth-child(3) {
  --cc-color: var(--color-accent-6);
}
.cc_price_01 .item {
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  border: 2px solid var(--cc-color);
  border-radius: 10px;
  background-color: #fff;
  position: relative;
  padding: 0px 24px 24px;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 .item {
    width: calc(33.33% - 26.6666666667px);
    width: clamp(33.33% - 26.6666666667px, (1024px - 100vw) * 1000, 50% - 20px);
    border-width: 3px;
    border-radius: 13px;
    padding: 0px 26px 23px;
  }
}
.cc_price_01 .item_tag {
  font-weight: 800;
  line-height: 1.6;
  letter-spacing: 0.11em;
  color: #fff;
  background-color: var(--cc-color);
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 99px;
  margin-top: -22px;
  padding: 4px 10px;
}
.cc_price_01 .item_title {
  font-weight: 800;
  line-height: 1.8888888889;
  letter-spacing: 0.06em;
  color: var(--cc-color);
  min-height: 40px;
  position: relative;
  padding-top: 1px;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 .item_title {
    min-height: 59px;
  }
}
.cc_price_01 .item_title::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: currentColor;
  border-radius: 10px;
  position: absolute;
  left: 0;
  bottom: 0;
}
.cc_price_01 .item_intro {
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--cc-color);
  margin-top: 13px;
}
.cc_price_01 .item_price {
  font-weight: 800;
  line-height: 1.4411764706;
  color: var(--color-txt);
  margin-top: 10px;
}
.cc_price_01 .item_price .bigger {
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.06em;
  color: #545251;
}
.cc_price_01 .item_price .what {
  letter-spacing: 0.06em;
  color: #545251;
}
.cc_price_01 .item_price_init {
  font-weight: 700;
  letter-spacing: 0.045em;
  line-height: 1.5789473684;
  color: var(--color-txt);
}
.cc_price_01 .item_lists {
  display: flex;
  gap: 8px;
  flex-direction: column;
  margin-top: 10px;
}
.cc_price_01 .item_lists > li {
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.06em;
  background-color: #dbebff;
  border-radius: 10px;
  padding: 8px 10px 7px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .cc_price_01 .item_lists > li {
    min-height: 54px;
  }
}
.cc_price_01 .item_lists > li:nth-child(4), .cc_price_01 .item_lists > li:nth-child(5), .cc_price_01 .item_lists > li:nth-child(6) {
  background-color: #fce5d5;
  color: #ef653c;
  font-weight: 800;
}
.cc_price_02 {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 {
    margin-top: 56px;
  }
}
.cc_price_02 .list {
  display: flex;
  gap: 20px;
  flex-direction: column;
}
.cc_price_02 .item {
  --cc-color: var(--color-main-1);
  width: 100%;
  background-color: #ebf4ff;
  border-radius: 10px;
  position: relative;
  padding: 12px 24px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item {
    gap: 16px;
    flex-direction: row;
    border-radius: 20px;
    padding: 23px 24px 24px;
  }
}
.cc_price_02 .item_title {
  font-weight: 800;
  line-height: 1.4339622642;
  letter-spacing: 0.14em;
  color: var(--cc-color);
}
.cc_price_02 .item_title strong {
  font-weight: 700;
  padding-right: 3px;
}
.cc_price_02 .item_icon {
  width: 40px;
  aspect-ratio: 1.1538888889;
  background-color: #fff;
  mask-image: url("./../images/solution/icon_pd_shape.svg");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item_icon {
    width: 68px;
    top: 5px;
    left: -6px;
  }
}
.cc_price_02 .item_icon::before, .cc_price_02 .item_icon::after {
  content: "";
  position: absolute;
  background-color: var(--cc-color);
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
}
.cc_price_02 .item_icon::before {
  inset: 0;
  mask-image: url("./../images/solution/icon_pd_border.svg");
}
.cc_price_02 .item_icon::after {
  width: 20px;
  aspect-ratio: 1;
  mask-image: url("./../images/solution/icon_pd_plus.svg");
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item_icon::after {
    width: 33px;
  }
}
.cc_price_02 .item_tags {
  display: flex;
  gap: 8px;
  flex-direction: column;
  margin-top: 10px;
}
.cc_price_02 .item_tags > li {
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.18em;
  color: #fff;
  text-align: center;
  background-color: var(--cc-color);
  border-radius: 10px;
  padding: 8px 10px 7px;
}
@media only screen and (min-width: 768px) {
  .cc_price_02 .item_tags > li {
    min-width: 300px;
    min-height: 44px;
  }
}

.cc_price_03 .list {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

.problem_solution {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .problem_solution {
    margin-top: 71px;
  }
}
.problem_solution_col {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.problem_solution_heading {
  width: 360px;
  max-width: 80%;
  display: flex;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .problem_solution_heading {
    width: 100%;
  }
}
.problem_solution_heading img {
  max-width: 300px;
}
.problem_solution_heading_kata {
  font-weight: 900;
  line-height: 2.3181818182;
  letter-spacing: 0.2em;
  color: var(--color-txt);
  margin-top: 4px;
}
.problem_solution_phrase {
  font-weight: 500;
  line-height: 1.275;
  letter-spacing: 0.1em;
  margin-top: -6px;
}
.problem_solution_phrase .bigger {
  font-weight: 900;
}
@media only screen and (min-width: 768px) {
  .problem_solution_phrase .bigger {
    margin-left: 12px;
  }
}
.problem_solution_bottom_icon {
  width: 120px;
  aspect-ratio: 4.4;
  background-color: var(--custom-color-1);
  mask-image: url("./../images/common/icon_arc_down_bigger.svg");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
  margin-top: 22px;
}
@media only screen and (min-width: 768px) {
  .problem_solution_bottom_icon {
    width: 220px;
  }
}

.problem {
  margin-top: 50px;
}
.problem_heading {
  font-weight: 800;
  line-height: 1.2117647059;
  letter-spacing: 0.11em;
  color: var(--color-sub-1);
}
.problem_leading {
  font-weight: 700;
  line-height: 1.59375;
  letter-spacing: 0.01em;
  text-align: center;
  margin-top: -26px;
}
@media only screen and (min-width: 768px) {
  .problem_leading {
    margin-top: -42px;
  }
}
.problem_lists {
  --icon-width: 74.74px;
  width: 100%;
  display: flex;
  gap: 50px 20px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 50px;
}
@media only screen and (min-width: 768px) {
  .problem_lists {
    --icon-width: 113.28px;
    gap: 42px;
    margin-top: 87px;
  }
}
.problem_lists[data-col="3"] {
  --icon-width: 74.74px;
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="3"] {
    gap: 62px 39px;
    margin-top: 66px;
  }
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="3"] .item {
    width: clamp(33.33% - 26px, (1024px - 100vw) * 1000, 50% - 20px);
    padding-bottom: 26px;
  }
}
.problem_lists[data-col="3"] .item_title {
  line-height: 1.4827586207;
  letter-spacing: 0.028em;
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="3"] .item_title {
    margin-top: 18px;
  }
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="3"] .item_body {
    padding-top: 11px;
    padding-left: 8px;
  }
}
.problem_lists[data-col="4"] {
  --icon-width: 74.74px;
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="4"] {
    gap: 62px 35px;
    margin-top: 68px;
  }
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="4"] .item {
    width: clamp(25% - 26.25px, (1024px - 100vw) * 1000, 50% - 18px);
    padding: 0 23px 28px;
  }
}
.problem_lists[data-col="4"] .item_title {
  line-height: 1.4827586207;
  letter-spacing: 0.028em;
}
@media only screen and (min-width: 768px) {
  .problem_lists[data-col="4"] .item_title {
    font-size: clamp(
        2.3rem,
        calc(2.3rem + 0.0094936709 * (100vw - 768px)),
        2.9rem
    );
    margin-top: 16px;
  }
}
.problem_lists[data-col="4"] .item_body {
  padding-top: 11px;
}
.problem_lists .item {
  width: 100%;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  background-color: var(--color-sub-1);
  border-radius: 20px;
  padding: 0 20px 36px;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item {
    width: calc(50% - 21px);
  }
}
.problem_lists .item_icon {
  width: var(--icon-width);
  aspect-ratio: 1.1678350515;
  background-color: var(--color-main-1);
  mask-image: url("./../images/common/img_frame.svg");
  mask-size: 100%;
  mask-position: center center;
  mask-repeat: no-repeat;
  margin-top: calc(-0.8562853107 * var(--icon-width) * 0.5);
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item_icon {
    position: relative;
    left: 1px;
  }
}
.problem_lists .item_icon img {
  width: 100%;
}
.problem_lists .item_title {
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.7;
  color: var(--color-main-1);
  text-align: center;
  margin-top: 10px;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item_title {
    margin-left: -4px;
    margin-right: -4px;
  }
}
.problem_lists .item_body {
  padding-top: 16px;
}
.problem_lists .item_body:has(ul) {
  padding-top: 0;
}
.problem_lists .item_body > p {
  font-weight: 400;
  line-height: 1.8421052632;
  letter-spacing: 0.02em;
  color: var(--color-txt);
}
.problem_lists .item_body > ul {
  display: flex;
  flex-direction: column;
  margin-top: 20px;
}
@media only screen and (min-width: 1025px) {
  .problem_lists .item_body > ul {
    padding-left: 30px;
  }
}
.problem_lists .item_body > ul li {
  font-weight: 700;
  line-height: 1.9047619048;
  letter-spacing: 0.05em;
  color: var(--color-txt);
  position: relative;
  padding-left: 20px;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item_body > ul li {
    padding-left: 40px;
  }
}
.problem_lists .item_body > ul li::before {
  content: "";
  width: 12px;
  aspect-ratio: 1;
  background-color: var(--color-main-1);
  border-radius: 99px;
  position: absolute;
  top: 0.65em;
  left: 0;
}
@media only screen and (min-width: 768px) {
  .problem_lists .item_body > ul li::before {
    width: 19px;
    top: 0.5em;
  }
}

.cc_section_heading {
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.07em;
  text-align: center;
  margin-top: 24px;
}
@media only screen and (min-width: 768px) {
  .cc_section_heading {
    margin-top: 48px;
  }
}
.cc_section_heading strong {
  color: var(--color-main-1);
  font-weight: inherit;
}
.cc_section_title {
  font-weight: 700;
  line-height: 1.56;
  letter-spacing: 0.07em;
  text-align: center;
  margin-top: 12px;
}
@media only screen and (min-width: 768px) {
  .cc_section_title {
    margin-top: 19px;
  }
}
@media only screen and (min-width: 768px) {
  .cc_section_title + .cc_section_leading {
    margin-top: 14px;
  }
}
.cc_section_leading {
  font-weight: 400;
  line-height: 1.85;
  letter-spacing: 0.05em;
  color: #464646;
  margin-top: 21px;
}
@media only screen and (min-width: 768px) {
  .cc_section_leading {
    text-align: center;
  }
}
.cc_section_leading strong {
  color: var(--color-main-1);
  font-weight: 800;
}

.solution_power_list {
  display: flex;
  gap: 60px 20px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 60px;
  padding-bottom: 37px;
}
@media only screen and (min-width: 768px) {
  .solution_power_list {
    gap: 120px 40px;
    margin-top: 76px;
  }
}
.solution_power_list .item {
  --cc-color: var(--color-accent-4);
  --item-bc: #c3f4fd;
  width: 100%;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  background-color: var(--item-bc);
  border-radius: 13px;
  padding: 0 16px 30px;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item {
    width: calc(33.33% - 26.6666666667px);
    width: clamp(33.33% - 26.6666666667px, (1025px - 100vw) * 1000, 50% - 20px);
    padding: 0 28px 37px;
  }
}
.solution_power_list .item:nth-child(2) {
  --cc-color: var(--color-accent-6);
  --item-bc: #dcdbff;
}
.solution_power_list .item:nth-child(3) {
  --cc-color: var(--color-accent-3);
  --item-bc: #cefdd9;
}
.solution_power_list .item_icon {
  --icon-width: 100px;
  width: var(--icon-width);
  aspect-ratio: 1.1678461538;
  position: relative;
  z-index: 0;
  margin-top: calc(-0.8562771703 * var(--icon-width) * 0.5);
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_icon {
    --icon-width: 151.82px;
  }
}
.solution_power_list .item_icon::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: var(--cc-color);
  mask-image: url("./../images/common/img_frame.svg");
  mask-size: 100%;
  mask-position: center center;
  mask-repeat: no-repeat;
}
.solution_power_list .item_title {
  font-weight: 800;
  line-height: 1.4166666667;
  letter-spacing: 0.07em;
  color: var(--color-txt);
  text-align: center;
  margin-top: 12px;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_title {
    margin-top: 21px;
  }
}
.solution_power_list .item_context {
  margin-top: 14px;
}
.solution_power_list .item_context::before {
  content: "";
  width: 100%;
  height: 2px;
  display: block;
  background-color: var(--cc-color);
  border-radius: 2px;
}
.solution_power_list .item_sub_title {
  font-weight: 800;
  line-height: 1.4615384615;
  text-align: center;
  margin-top: 16px;
}
@media only screen and (min-width: 768px) {
  .solution_power_list .item_sub_title {
    margin-top: 28px;
  }
}
.solution_power_list .item_exam {
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--color-txt);
  text-align: center;
  margin-top: 19px;
}
.solution_power_list .item_content {
  margin-top: 16px;
}
.solution_power_list .item_content p {
  font-weight: 400;
  line-height: 1.8421052632;
  letter-spacing: 0.1em;
}
.solution_power_list .item_content p + ul {
  margin-top: 16px;
}
.solution_power_list .item_content ul {
  font-weight: 700;
  line-height: 1.4705882353;
  letter-spacing: 0.03em;
  color: #fff;
  text-align: center;
  display: flex;
  gap: 8px;
  flex-direction: column;
}
.solution_power_list .item_content ul + p {
  margin-top: 16px;
}
.solution_power_list .item_content ul li {
  background-color: var(--cc-color);
  border-radius: 99px;
  padding: 7px 4px 6px;
}
.solution_core {
  margin-top: 67px;
}
.solution_core_desc {
  font-weight: 400;
  line-height: 1.85;
  letter-spacing: 0.04em;
  margin-top: 23px;
}
@media only screen and (min-width: 768px) {
  .solution_core_desc {
    text-align: center;
  }
}
.solution_core_lists {
  display: flex;
  gap: 39px 20px;
  flex-wrap: wrap;
  justify-content: center;
  counter-reset: item-counter;
  margin-top: 47px;
}
@media only screen and (min-width: 768px) {
  .solution_core_lists {
    gap: 39px 42px;
  }
}
.solution_core_lists[data-count="3"] .item:nth-child(2n) {
  --item-bc: var(--color-sub-2);
}
.solution_core_lists[data-count="3"] .item:nth-child(2n+1) {
  --item-icon-bc: var(--color-main-1);
}
.solution_core_lists:not([data-count="3"]) .item:nth-child(4n), .solution_core_lists:not([data-count="3"]) .item:nth-child(4n-3) {
  --item-bc: var(--color-sub-2);
  --item-icon-bc: var(--color-main-1);
}
.solution_core_lists .item {
  --item-bc: var(--color-sub-3);
  --item-icon-bc: var(--color-main-2);
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  background-color: var(--item-bc);
  border-radius: 13px;
  counter-increment: item-counter;
  padding: 10px 20px 20px;
}
@media only screen and (min-width: 768px) {
  .solution_core_lists .item {
    width: calc(50% - 21px);
    padding: 12px 25px 35px;
  }
}
.solution_core_lists .item_header {
  display: flex;
  gap: 10px;
  align-items: baseline;
  margin-right: -20px;
}
.solution_core_lists .item_order {
  width: 60px;
  position: relative;
  flex-shrink: 0;
  filter: drop-shadow(2px 4px 0 rgba(83, 66, 54, 0.5));
}
@media only screen and (min-width: 768px) {
  .solution_core_lists .item_order {
    width: 93px;
    height: 44px;
    top: 9px;
  }
}
.solution_core_lists .item_order::before, .solution_core_lists .item_order::after {
  content: "";
  width: 100%;
  aspect-ratio: 1.167875;
  position: absolute;
  left: 0;
  bottom: 0;
  mask-size: 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
}
.solution_core_lists .item_order::before {
  background-color: var(--item-icon-bc);
  mask-image: url("./../images/common/img_frame.svg");
  filter: drop-shadow(2px 4px 0 rgba(83, 66, 54, 0.5));
}
.solution_core_lists .item_order::after {
  background-color: #fff;
  mask-image: url("./../images/common/img_frame_border.svg");
}
.solution_core_lists .item_order_counter {
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: 0.12em;
  color: #fff;
  width: 100%;
  aspect-ratio: 1.167875;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 0;
  bottom: 0;
}
.solution_core_lists .item_order_counter::before {
  content: counter(item-counter);
}
.solution_core_lists .item_title {
  font-weight: 800;
  line-height: 1.7;
  letter-spacing: 0.03em;
  color: var(--color-txt);
}
.solution_core_lists .item_body {
  font-weight: 400;
  line-height: 1.6666666667;
  letter-spacing: 0.04em;
  color: var(--color-txt);
  margin-top: 6px;
}
.solution_core_lists .item_body strong {
  color: var(--custom-color-2);
  font-weight: 800;
}

.cc_usage {
  margin-top: 50px;
}
@media only screen and (min-width: 768px) {
  .cc_usage {
    margin-top: 68px;
  }
}
.cc_usage + .cc_section_title {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .cc_usage + .cc_section_title {
    margin-top: 69px;
  }
}
.cc_usage .list {
  display: flex;
  gap: 65px 20px;
  flex-wrap: wrap;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .cc_usage .list {
    gap: 65px 40px;
  }
}
.cc_usage .item {
  width: 100%;
  width: clamp(50% - 10px, (640px - 100vw) * 1000, 100%);
  background-color: #f4f9ff;
  border-radius: 13px;
  position: relative;
  padding: 30px 20px;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item {
    width: calc(50% - 20px);
    padding: 13px 32px 27px;
    padding-left: clamp(20px, (100vw - 1024px) * 1000, 32px);
    padding-right: clamp(20px, (100vw - 1024px) * 1000, 32px);
  }
}
.cc_usage .item:nth-child(6n+1) {
  --cc-color: var(--color-accent-1);
}
.cc_usage .item:nth-child(6n+2) {
  --cc-color: var(--color-accent-2);
}
.cc_usage .item:nth-child(6n+3) {
  --cc-color: var(--color-accent-3);
}
.cc_usage .item:nth-child(6n+4) {
  --cc-color: var(--color-accent-4);
}
.cc_usage .item:nth-child(6n+5) {
  --cc-color: var(--color-accent-5);
}
.cc_usage .item:nth-child(6n+6) {
  --cc-color: var(--color-accent-6);
}
.cc_usage .item_icon {
  width: 100px;
  max-width: 28%;
  position: absolute;
  top: -33px;
  right: -17px;
  mask-image: url("./../images/common/img_frame.svg");
  mask-size: 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_icon {
    width: 151.82px;
  }
}
.cc_usage .item_icon::before, .cc_usage .item_icon::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--cc-color);
  mask-size: 100%;
  mask-repeat: no-repeat;
  mask-position: center center;
}
.cc_usage .item_icon::before {
  z-index: -1;
  mask-image: url("./../images/common/img_frame.svg");
}
.cc_usage .item_icon::after {
  z-index: 1;
  mask-image: url("./../images/common/img_frame_border_150.svg");
}
.cc_usage .item_title {
  font-weight: 800;
  line-height: 1.3125;
  letter-spacing: 0.07em;
  color: var(--cc-color);
  border-bottom: 2px solid var(--cc-color);
  padding-right: 60px;
  padding-bottom: 21px;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_title {
    min-height: 106px;
    display: flex;
    align-items: flex-end;
    padding-right: 120px;
  }
}
.cc_usage .item_info {
  margin-top: 8px;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_info + .item_info .item_info_detail {
    min-height: 60px;
  }
}
.cc_usage .item_info_title {
  font-weight: 800;
  line-height: 2.3181818182;
  letter-spacing: 0.06em;
  color: var(--cc-color);
}
.cc_usage .item_info_detail {
  font-weight: 400;
  line-height: 1.6666666667;
  letter-spacing: 0.089em;
  color: var(--color-txt);
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_info_detail {
    margin-top: -3px;
  }
}
.cc_usage .item_tag {
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0.06em;
  color: #fff;
  width: 100%;
  height: 40px;
  background-color: var(--cc-color);
  border-radius: 99px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 20px;
}
.cc_usage .item_note {
  font-weight: 500;
  line-height: 1.6666666667;
  letter-spacing: 0.08em;
  color: var(--color-txt);
  margin-top: 11px;
}
.cc_usage .item_note a,
.cc_usage .item_note strong {
  font-weight: 900;
  color: var(--cc-color);
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media only screen and (min-width: 768px) {
  .cc_usage .item_note a:hover {
    text-decoration: none;
  }
}

.driven {
  margin-top: -15px;
}
.driven .cc_section_leading {
  color: #fff;
}
.driven .cc_note {
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .driven .cc_note {
    margin-top: 33px;
  }
}

.utilization_content {
  border-top: 2px solid #9ba2ac;
  margin-top: 20px;
  padding-top: 20px;
}
@media only screen and (min-width: 768px) {
  .utilization_content {
    margin-top: 38px;
    padding-top: 36px;
  }
}
.utilization_intro {
  font-weight: 600;
  line-height: 1.6666666667;
  letter-spacing: 0.04em;
}
@media only screen and (min-width: 768px) {
  .utilization_intro {
    text-align: center;
  }
}
.utilization_btn {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .utilization_btn {
    gap: 40px;
    margin-top: 74px;
  }
}
.utilization_btn_item {
  --cc-color: var(--color-accent-5);
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.15em;
  text-align: center;
  color: var(--cc-color);
  width: calc(50% - 2px);
  height: 40px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 99px;
  transition: 300ms ease;
  border: 2px solid var(--cc-color);
}
@media only screen and (min-width: 768px) {
  .utilization_btn_item {
    width: 220px;
    height: 50px;
    font-size: 2.4rem;
    cursor: pointer;
  }
  .utilization_btn_item:hover {
    opacity: 0.6;
  }
}
.utilization_btn_item:nth-child(1) {
  letter-spacing: 0.3em;
}
.utilization_btn_item:nth-child(2) {
  --cc-color: var(--color-accent-1);
}
.utilization_btn_item:nth-child(3) {
  --cc-color: var(--color-accent-3);
}
.utilization_btn_item.open {
  color: #fff;
  background-color: var(--cc-color);
  pointer-events: none;
}
.utilization_body {
  position: relative;
  z-index: 1;
  margin-top: 40px;
}
.utilization_body_item {
  --cc-color: var(--color-accent-5);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
  transition: all 0.35s ease-in-out;
}
.utilization_body_item.open {
  pointer-events: auto;
  opacity: 1;
  position: static;
}
.utilization_body_item:nth-child(2) {
  --cc-color: #61a5fb;
}
.utilization_body_item:nth-child(3) {
  --cc-color: var(--color-accent-3);
}
.utilization_list {
  width: 100%;
  border-bottom: 1px solid #9ba2ac;
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  padding-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  .utilization_list {
    gap: 35px 40px;
    gap: 35px clamp(20px, (100vw - 1025px) * 1000, 40px);
    padding-bottom: 70px;
  }
}
.utilization_list_item {
  width: 100%;
  padding: 0;
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item {
    width: calc(33.33% - 26.6666666667px);
  }
}
@media only screen and (min-width: 768px) {
  .utilization_list_item:nth-child(1) {
    width: clamp(33.33% - 26.6666666667px, (1025px - 100vw) * 1000, 100%);
  }
}
.utilization_list_item:nth-child(1) .item_photo {
  aspect-ratio: 2;
}
@media only screen and (min-width: 1025px) {
  .utilization_list_item:nth-child(1) .item_photo {
    aspect-ratio: 1.05;
  }
}
.utilization_list_item:nth-child(1) .item_photo img {
  object-position: 4% 10%;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item:nth-child(1) .item_photo img {
    object-position: 4% 10%;
  }
}
.utilization_list_item:nth-child(2), .utilization_list_item:nth-child(3) {
  width: calc(50% - 8px);
}
@media only screen and (min-width: 768px) {
  .utilization_list_item:nth-child(2), .utilization_list_item:nth-child(3) {
    width: clamp(33.33% - 27.3333333333px, (1025px - 100vw) * 1000, 50% - 10px);
  }
}
@media only screen and (min-width: 1025px) {
  .utilization_list_item:nth-child(2), .utilization_list_item:nth-child(3) {
    width: calc(33.33% - 27.3333333333px);
  }
}
.utilization_list_item:nth-child(4) {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item:nth-child(4) {
    display: flex;
    gap: 32px;
    align-items: flex-start;
  }
}
.utilization_list_item .item_title {
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: 0.07em;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_title {
    font-size: 2.1rem;
  }
}
.utilization_list_item .item_photo {
  overflow: hidden;
  border-radius: 10px;
  margin-top: 13px;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_photo {
    aspect-ratio: 1.05;
    border-radius: 13px;
  }
}
.utilization_list_item .item_photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.utilization_list_item .item_header {
  width: 220px;
  max-width: 100%;
  flex-shrink: 0;
  border: 1px solid #fff;
  border-radius: 10px;
  text-align: center;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
  padding-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_header {
    width: 280px;
    border-width: 2px;
    margin-left: 0;
    padding-top: 12px;
  }
}
.utilization_list_item .item_header .item_title {
  letter-spacing: 0.2em;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_header .item_title {
    margin-top: 18px;
  }
}
.utilization_list_item .item_header .item_icon {
  position: absolute;
  top: 50%;
  left: 12px;
  translate: 0 -50%;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_header .item_icon {
    position: static;
    translate: 0 0;
  }
}
.utilization_list_item .item_body {
  font-weight: 500;
  line-height: 1.6666666667;
  letter-spacing: 0.06em;
  margin-top: 16px;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_body {
    margin-top: 0;
  }
}
.utilization_list_item .item_body strong {
  color: var(--cc-color);
  font-weight: 900;
}
.utilization_list_item .item_icon {
  width: 24px;
}
@media only screen and (min-width: 768px) {
  .utilization_list_item .item_icon {
    width: 39px;
    margin-left: auto;
    margin-right: auto;
  }
}
.utilization_list_item_inner {
  height: 100%;
  position: relative;
  border-radius: 13px;
  background-color: #f4f9ff;
  padding: 37px 18px 15px 19px;
}
.utilization_list_item_icon {
  position: absolute;
  top: 0;
  right: 0%;
  height: 60px;
  width: auto;
  transform: translate(16.2px, -33px);
}
.utilization_list_item_icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.utilization_list_item_title {
  font-size: 2.2rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  line-height: 1.59375;
  border-bottom: 2px solid;
  padding-bottom: 16px;
  margin-bottom: 16.4px;
}
.utilization_list_item_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 40px;
  border-radius: 25px;
  color: #fff;
  font-size: 2rem;
  letter-spacing: 0.06em;
  font-weight: 600;
  line-height: 1.25;
  margin-bottom: 10px;
}
.utilization_info {
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .utilization_info {
    max-width: 916px;
    margin-top: 38px;
    margin-left: auto;
    margin-right: auto;
  }
}
.utilization_info_data {
  display: flex;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .utilization_info_data {
    gap: 12px;
    flex-direction: row;
  }
}
.utilization_info_data + .utilization_info_data {
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .utilization_info_data + .utilization_info_data {
    margin-top: 0;
  }
}
.utilization_info_data .item_title, .utilization_info_data .item_detail {
  line-height: 1.8421052632;
  letter-spacing: 0.108em;
}
.utilization_info_data .item_title {
  width: 100%;
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .utilization_info_data .item_title {
    width: 230px;
    flex-shrink: 0;
  }
}
.utilization_info_data .item_detail {
  font-weight: 400;
}

.p_solution_form .mv_child_inner {
  min-height: 200px;
}

/*# sourceMappingURL=solution_child.css.map */
