@charset "UTF-8";
html {
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
}

body {
  overflow-x: hidden;
  white-space: wrap;
}

.accent_blue {
  color: #3d75ff;
}

.newline {
  display: inline-block;
}

.mt_100 {
  margin-top: 10rem;
}

.display_pc {
  display: block;
}
@media screen and (max-width: 768px) {
  .display_pc {
    display: none;
  }
}

.display_sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .display_sp {
    display: block;
  }
}

.before_after_section .container .flex_bt .ba_div .flex_bt .arrow, .before_after_section .container .h3_title, .removal_structure .container, .machine_section .container .flex_bt, .favorite_plan .container .flex_bt .detail_div .course_purpose, .favorite_plan .container .flex_bt {
  display: flex;
  justify-content: center;
  align-items: center;
}

.voice_section .container .flex_bt, .features_section .container .some_features, .before_after_section .container .flex_bt .ba_div .flex_bt, .before_after_section .container .flex_bt, .removal_structure .container .flex_bt .reason .reason_box .reason_text_bt, .removal_structure .container .flex_bt, .flow_section .container .steps, .standard_menu .container .inner .flex_bt {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.section_common {
  padding: 10rem 0;
}
@media screen and (max-width: 1000px) {
  .section_common {
    padding: 8rem 0;
  }
}
@media screen and (max-width: 768px) {
  .section_common {
    padding: 6rem 0;
  }
}
.section_common .container {
  max-width: 120rem;
  margin: auto;
}
@media screen and (max-width: 1200px) {
  .section_common .container {
    padding: 0 1.5rem;
  }
}
.section_common .container .h3_title {
  margin: 0 auto 5rem 0;
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .section_common .container .h3_title {
    font-size: 3.2rem;
    margin: 0 auto 4rem 0;
  }
}
@media screen and (max-width: 400px) {
  .section_common .container .h3_title {
    font-size: 2.8rem;
    margin: 0 auto 3rem 0;
  }
}

.main_visual .img_div {
  max-width: 100%;
}
.main_visual .img_div img {
  width: 100%;
  height: auto;
}

.catch_message {
  overflow-x: hidden;
  padding-bottom: 0;
}
.catch_message .container {
  max-width: 100rem;
}
.catch_message .container .h3_title {
  text-align: left;
  margin: 0 0 4rem 0;
}
@media screen and (max-width: 1200px) {
  .catch_message .container .h3_title {
    margin: 0 0 2rem 0;
  }
}
@media screen and (max-width: 768px) {
  .catch_message .container .h3_title {
    text-align: center;
  }
}
.catch_message .container .flex_bt {
  position: relative;
}
.catch_message .container .flex_bt .text {
  font-size: 1.8rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
  margin: 0 auto 3rem auto;
}
@media screen and (max-width: 1200px) {
  .catch_message .container .flex_bt .text {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 768px) {
  .catch_message .container .flex_bt .text {
    font-size: 1.6rem;
    text-align: center;
  }
}
@media screen and (max-width: 400px) {
  .catch_message .container .flex_bt .text {
    font-size: 1.6rem;
  }
}
.catch_message .container .flex_bt .cta_div {
  position: absolute;
  top: 50%;
  left: 85%;
  transform: translate(-50%, -50%);
  background-color: #00c300;
  width: 100%;
  margin: auto;
  max-width: 30rem;
  border-radius: 5rem;
}
@media screen and (max-width: 1200px) {
  .catch_message .container .flex_bt .cta_div {
    max-width: 61rem;
    left: 100%;
    transform: translate(-50%, -50%);
  }
}
@media screen and (max-width: 1000px) {
  .catch_message .container .flex_bt .cta_div {
    max-width: 25rem;
    left: 90%;
  }
}
@media screen and (max-width: 768px) {
  .catch_message .container .flex_bt .cta_div {
    position: unset;
    top: unset;
    left: unset;
    transform: unset;
    margin: 6rem auto;
  }
}
.catch_message .container .flex_bt .cta_div .line_cta {
  font-size: 2.6rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: white;
  padding: 1rem 0;
  text-align: center;
  display: block;
}
@media screen and (max-width: 1200px) {
  .catch_message .container .flex_bt .cta_div .line_cta {
    text-align: left;
    margin: 0 0 0 4rem;
  }
}
@media screen and (max-width: 1000px) {
  .catch_message .container .flex_bt .cta_div .line_cta {
    font-size: 2rem;
  }
}
.catch_message .container .img_div {
  margin: auto;
  height: 45rem;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 400px) {
  .catch_message .container .img_div {
    height: 30rem;
  }
}
.catch_message .container .img_div img {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .catch_message .container .img_div img {
    left: 50%;
    transform: translate(-50%, 0%);
  }
}
@media screen and (max-width: 400px) {
  .catch_message .container .img_div img {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    right: unset;
    bottom: unset;
    margin: unset;
    -o-object-fit: unset;
       object-fit: unset;
  }
}

.favorite_plan {
  background-color: #edf2fa;
}
@media screen and (max-width: 768px) {
  .favorite_plan {
    position: relative;
    z-index: -1;
  }
}
.favorite_plan .container {
  max-width: 100rem;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .h3_title {
    margin: 0 auto 6rem 0;
  }
}
.favorite_plan .container .flex_bt {
  align-items: stretch; /* 子要素の高さを親要素に合わせて伸縮させます */
  gap: 5rem;
  margin: 0 auto 10rem auto;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt {
    flex-flow: column;
  }
}
.favorite_plan .container .flex_bt:last-child {
  margin: 0 auto 0 auto;
}
.favorite_plan .container .flex_bt .img_div {
  position: relative;
  overflow: hidden;
  flex: 8;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .img_div {
    display: none;
  }
}
.favorite_plan .container .flex_bt .img_div .plan_img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 3rem;
}
.favorite_plan .container .flex_bt .detail_div {
  display: flex;
  flex: 11;
  background-color: white;
  border-radius: 3rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div {
    border-radius: 0rem 2rem 2rem 2rem;
  }
}
.favorite_plan .container .flex_bt .detail_div.detail_div_right {
  margin-right: 6rem;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div.detail_div_right {
    margin-right: unset;
  }
}
.favorite_plan .container .flex_bt .detail_div.detail_div_right .course_purpose {
  left: 100%;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div.detail_div_right .course_purpose {
    left: 0%;
  }
}
.favorite_plan .container .flex_bt .detail_div.detail_div_left {
  margin-left: 6rem;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div.detail_div_left {
    margin-left: unset;
  }
}
.favorite_plan .container .flex_bt .detail_div.detail_div_left .course_purpose {
  left: 0%;
}
.favorite_plan .container .flex_bt .detail_div .course_purpose {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: #3d75ff;
  flex-flow: column;
  position: absolute;
  top: -5%;
  transform: translate(-50%, -50%);
  background-color: #ffff00;
  width: 13.5rem;
  height: 13.5rem;
  border-radius: 10rem;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div .course_purpose {
    width: unset;
    height: unset;
    font-size: 1.6rem;
    top: -7%;
    transform: translate(0%, -50%);
    display: unset;
    padding: 1rem 1rem 3rem 1rem;
    border-radius: 1rem 1rem 0rem 0rem;
    z-index: -1;
  }
}
.favorite_plan .container .flex_bt .detail_div .course_purpose .br {
  display: block;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div .course_purpose .br {
    display: inline;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner {
  margin: 5rem;
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner {
    margin: 2rem;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .plan_name {
  font-size: 3.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin: 0 auto 2.5rem auto;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .plan_name {
    margin: 0 auto 1.5rem auto;
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .plan_name {
    font-size: 2.6rem;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .course {
  font-size: 2.6rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin: 0 auto 4.5rem auto;
  padding: 0.8rem;
  background-color: #3d75ff;
  border-radius: 5rem;
  color: white;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .course {
    margin: 0 auto 3rem auto;
  }
}
@media screen and (max-width: 768px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .course {
    margin: 0 auto 2rem auto;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .total_price {
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin: 0 auto 1rem auto;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .total_price {
    margin: 0 auto 0.5rem auto;
    font-size: 3.2rem;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .total_price .yen {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .total_price .yen {
    font-size: 1.8rem;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .special_price {
  margin: 0 auto 2rem auto;
  background-color: #ffff00;
  border-radius: 5rem;
  color: #3d75ff;
  width: 14.6rem;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .special_price {
    font-size: 1.8rem;
  }
}
.favorite_plan .container .flex_bt .detail_div .detail_inner .text_div .text {
  font-size: 1.8rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
  margin: 0;
}
@media screen and (max-width: 1000px) {
  .favorite_plan .container .flex_bt .detail_div .detail_inner .text_div .text {
    font-size: 1.6rem;
  }
}

.standard_menu {
  background-color: #edf2fa;
  padding: 0 0 10rem 0;
}
.standard_menu .container {
  max-width: 100rem;
}
.standard_menu .container .inner {
  background-color: white;
  border-radius: 2rem;
  padding: 10rem;
}
@media screen and (max-width: 1000px) {
  .standard_menu .container .inner {
    padding: 5rem;
  }
}
@media screen and (max-width: 400px) {
  .standard_menu .container .inner {
    padding: 2rem;
  }
}
.standard_menu .container .inner .h4_title {
  font-size: 3.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: white;
  background-color: #3d75ff;
  border-radius: 5rem;
  max-width: 42rem;
  margin: 0 auto 5rem auto;
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .h4_title {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 400px) {
  .standard_menu .container .inner .h4_title {
    font-size: 2.2rem;
    border-radius: 0.8rem;
    padding: 0.5rem;
  }
}
.standard_menu .container .inner .flex_bt {
  align-items: flex-start;
  gap: 3rem;
  margin: 0 0 8rem 0;
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .flex_bt {
    margin: 0 0 4rem 0;
    flex-flow: column;
    align-items: center;
  }
}
.standard_menu .container .inner .flex_bt .img_div {
  flex: 1;
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .flex_bt .img_div {
    padding: 0 5rem;
    order: 2;
  }
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .flex_bt .img_div {
    padding: unset;
  }
}
.standard_menu .container .inner .flex_bt .img_div img {
  width: 100%;
  height: auto;
}
.standard_menu .container .inner .flex_bt .menu_ul {
  flex: 1;
  margin: unset;
  padding: unset;
  gap: 5rem;
  display: flex;
  flex-flow: column;
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .flex_bt .menu_ul {
    order: 1;
    gap: 3rem;
    width: 100%;
  }
}
.standard_menu .container .inner .flex_bt .menu_ul .menu_li {
  display: flex;
  justify-content: space-between;
  background-image: repeating-linear-gradient(90deg, #6e6e6e, #6e6e6e 6px, transparent 6px, transparent 15px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 1px;
}
@media screen and (max-width: 400px) {
  .standard_menu .container .inner .flex_bt .menu_ul .menu_li {
    gap: unset;
    justify-content: space-between;
  }
}
.standard_menu .container .inner .flex_bt .menu_ul .menu_li:last-child {
  margin-bottom: unset;
}
.standard_menu .container .inner .flex_bt .menu_ul .menu_li .parts,
.standard_menu .container .inner .flex_bt .menu_ul .menu_li .price {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: right;
  line-height: 1.5;
  margin: unset;
}
@media screen and (max-width: 768px) {
  .standard_menu .container .inner .flex_bt .menu_ul .menu_li .parts,
  .standard_menu .container .inner .flex_bt .menu_ul .menu_li .price {
    font-size: 2rem;
  }
}
@media screen and (max-width: 400px) {
  .standard_menu .container .inner .flex_bt .menu_ul .menu_li .parts,
  .standard_menu .container .inner .flex_bt .menu_ul .menu_li .price {
    font-size: 1.6rem;
  }
}
.standard_menu .container .inner .flex_bt .menu_ul .menu_li .price .yen {
  font-size: 1.4rem;
  font-weight: normal;
  text-align: right;
  line-height: 1.5;
}

.flow_section {
  background-color: #3d75ff;
  padding: 10rem 0;
}
.flow_section .container {
  max-width: 100rem;
}
.flow_section .container .h3_title {
  color: white;
}
.flow_section .container .steps {
  align-items: stretch;
  gap: 12.5rem;
}
@media screen and (max-width: 1000px) {
  .flow_section .container .steps {
    gap: 5rem;
  }
}
@media screen and (max-width: 768px) {
  .flow_section .container .steps {
    flex-flow: column;
    padding: 0 5rem;
  }
}
@media screen and (max-width: 400px) {
  .flow_section .container .steps {
    padding: unset;
  }
}
.flow_section .container .steps .step_div {
  display: flex;
  flex-flow: column;
  gap: 2rem;
  flex: 1;
  width: 100%;
}
@media screen and (max-width: 400px) {
  .flow_section .container .steps .step_div {
    max-width: unset;
  }
}
.flow_section .container .steps .step_div .step_count {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  background-color: #ffff00;
  color: #3d75ff;
  margin: unset;
  border-radius: 5rem;
  padding: 0.2rem 0;
}
@media screen and (max-width: 768px) {
  .flow_section .container .steps .step_div .step_count {
    padding: 1rem 0;
  }
}
.flow_section .container .steps .step_div .step_title {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: #ffff00;
  margin: unset;
}
.flow_section .container .steps .step_div .step_icon_div {
  width: 20rem;
  height: 20rem;
  background-color: white;
  border-radius: 50rem;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: auto;
}
.flow_section .container .steps .step_div .step_icon_div .step_icon {
  max-width: 12rem;
  width: 100%;
  height: auto;
}
.flow_section .container .steps .step_div .step_text {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
  color: white;
  margin: unset;
}
@media screen and (max-width: 768px) {
  .flow_section .container .steps .step_div .step_text {
    text-align: center;
  }
}
@media screen and (max-width: 400px) {
  .flow_section .container .steps .step_div .step_text {
    text-align: justify;
  }
}

.cta_section {
  background-color: #d6f5d6;
}
.cta_section .container {
  max-width: 100rem;
}
.cta_section .container .cta_supplement_div {
  margin: 0 auto 1rem auto;
  text-align: center;
}
.cta_section .container .cta_supplement_div .cta_supplement {
  font-size: 2.6rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  margin: 0;
  position: relative;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .cta_section .container .cta_supplement_div .cta_supplement {
    font-size: 2rem;
  }
}
.cta_section .container .cta_supplement_div .cta_supplement::before, .cta_section .container .cta_supplement_div .cta_supplement::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1.5rem;
  height: 2.5rem;
  transition: all 0.2s;
  vertical-align: sub;
}
.cta_section .container .cta_supplement_div .cta_supplement::before {
  right: -2rem;
  transform: translate(-50%, -50%) rotate(20deg);
  border-right: 2px solid black;
}
.cta_section .container .cta_supplement_div .cta_supplement::after {
  left: -1rem;
  transform: translate(-50%, -50%) rotate(-20deg);
  border-left: 2px solid black;
}
.cta_section .container .cta_div {
  position: relative;
  background-color: #00c300;
  border-radius: 5rem;
  max-width: 61rem;
  margin: auto;
}
.cta_section .container .cta_div .line_cta {
  font-size: 3.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: white;
  padding: 2rem 0;
  text-align: center;
  margin: 0;
  display: block;
}
@media screen and (max-width: 768px) {
  .cta_section .container .cta_div .line_cta {
    font-size: 3rem;
  }
}
@media screen and (max-width: 400px) {
  .cta_section .container .cta_div .line_cta {
    font-size: 2.6rem;
  }
}
.cta_section .container .cta_div .line_cta::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-4.5rem, -50%) rotate(45deg);
  width: 1.5rem;
  height: 1.5rem;
  transition: all 0.2s;
  border-top: 3px solid #00c300;
  border-right: 3px solid #00c300;
  vertical-align: sub;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .cta_section .container .cta_div .line_cta::before {
    width: 1rem;
    height: 1rem;
    right: -1rem;
  }
}
@media screen and (max-width: 400px) {
  .cta_section .container .cta_div .line_cta::before {
    display: none;
  }
}
.cta_section .container .cta_div .line_cta::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-2rem, -50%);
  display: inline-block;
  width: 6rem;
  height: 6rem;
  border-radius: 5rem;
  background-color: white;
}
@media screen and (max-width: 768px) {
  .cta_section .container .cta_div .line_cta::after {
    width: 4rem;
    height: 4rem;
  }
}
@media screen and (max-width: 400px) {
  .cta_section .container .cta_div .line_cta::after {
    display: none;
  }
}
.cta_section .container .text {
  font-size: 1.8rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  margin: 2rem auto 0 auto;
}
@media screen and (max-width: 400px) {
  .cta_section .container .text {
    font-size: 1.6rem;
  }
}

.map_section {
  background-color: #edf2fa;
}
.map_section .container {
  max-width: 100rem;
  text-align: center;
}
.map_section .container .access_detail {
  margin: 5rem auto 0 auto;
}
.map_section .container .access_detail .dl {
  display: grid;
  grid-template-columns: 24rem 1fr;
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #dedede;
}
.map_section .container .access_detail .dl:last-child {
  margin: 0;
}
.map_section .container .access_detail .dt {
  font-size: 1.6rem;
  font-weight: bold;
  text-align: justify;
  line-height: 1.5;
  display: inline-flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: flex-start;
  letter-spacing: 0.2rem;
}
.map_section .container .access_detail .dd {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
  display: inline-flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: flex-start;
  letter-spacing: 0.2rem;
  margin: 0;
}
.map_section .container .access_detail .google_map {
  width: 100%;
  height: 50rem;
}
@media screen and (max-width: 400px) {
  .map_section .container .access_detail .google_map {
    height: 25rem;
  }
}
@media screen and (max-width: 768px) {
  .map_section .container .access_detail .dl {
    grid-template-columns: 12rem 1fr;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
  }
  .map_section .container .access_detail .dt {
    margin-right: 1.5rem;
  }
}

.machine_section .container .text_div {
  width: 100%;
}
.machine_section .container .text_div .text {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
}
.machine_section .container .flex_bt {
  gap: 4rem;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt {
    gap: 2rem;
  }
}
.machine_section .container .flex_bt .detail_div {
  max-width: 45rem;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div {
    max-width: unset;
    flex: 4;
  }
}
@media screen and (max-width: 400px) {
  .machine_section .container .flex_bt .detail_div {
    flex: 1;
  }
}
.machine_section .container .flex_bt .detail_div .headline .line1,
.machine_section .container .flex_bt .detail_div .headline .line2,
.machine_section .container .flex_bt .detail_div .headline .line3 {
  margin: 0;
  line-height: 1;
}
.machine_section .container .flex_bt .detail_div .headline .line1 {
  font-size: 2.6rem;
  font-weight: normal;
  text-align: left;
  line-height: 1.5;
  color: #3d75ff;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .headline .line1 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 400px) {
  .machine_section .container .flex_bt .detail_div .headline .line1 {
    font-size: 1.8rem;
  }
}
.machine_section .container .flex_bt .detail_div .headline .line2 {
  font-size: 4.8rem;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  color: black;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .headline .line2 {
    font-size: 3.5rem;
  }
}
@media screen and (max-width: 400px) {
  .machine_section .container .flex_bt .detail_div .headline .line2 {
    font-size: 2.6rem;
  }
}
.machine_section .container .flex_bt .detail_div .headline .line3 {
  font-size: 10rem;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  color: #3d75ff;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .headline .line3 {
    font-size: 5rem;
  }
}
.machine_section .container .flex_bt .detail_div .headline .line3 .marker {
  background: linear-gradient(transparent 70%, #ffff00 50%);
}
.machine_section .container .flex_bt .detail_div .machine_point {
  display: flex;
  gap: 2rem;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .machine_point {
    gap: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .machine_point {
    gap: 0.6rem;
  }
}
.machine_section .container .flex_bt .detail_div .machine_point .point {
  width: 11.5rem;
  height: 11.5rem;
  border-radius: 10rem;
  background-color: #3d75ff;
  font-size: 1.8rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  color: white;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .detail_div .machine_point .point {
    width: 8rem;
    height: 8rem;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 400px) {
  .machine_section .container .flex_bt .detail_div .machine_point .point {
    width: 6rem;
    height: 6rem;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .machine_section .container .flex_bt .img_div {
    flex: 3;
  }
}
@media screen and (max-width: 400px) {
  .machine_section .container .flex_bt .img_div {
    flex: 1;
  }
}
.machine_section .container .flex_bt .img_div img {
  width: 100%;
  height: auto;
}

.removal_structure {
  background-color: #edf2fa;
  padding-bottom: 0;
}
.removal_structure .container {
  max-width: 100rem;
  flex-flow: column;
  gap: 4rem;
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt {
    flex-flow: column;
  }
}
.removal_structure .container .flex_bt .reason {
  display: block;
  max-width: 44.6rem;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt .reason {
    max-width: unset;
  }
}
.removal_structure .container .flex_bt .reason .reason_box {
  max-width: 36.3rem;
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt .reason .reason_box {
    max-width: unset;
  }
}
.removal_structure .container .flex_bt .reason .reason_box .reason_title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: black;
  margin: 0 auto 1rem auto;
}
.removal_structure .container .flex_bt .reason .reason_box .reason_text_bt .reason_text1,
.removal_structure .container .flex_bt .reason .reason_box .reason_text_bt .reason_text2 {
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin: 0 auto 3rem auto;
}
@media screen and (max-width: 400px) {
  .removal_structure .container .flex_bt .reason .reason_box .reason_text_bt .reason_text1,
  .removal_structure .container .flex_bt .reason .reason_box .reason_text_bt .reason_text2 {
    font-size: 3rem;
  }
}
.removal_structure .container .flex_bt .reason .reason_box .reason_text_bt .reason_text2 {
  color: #3d75ff;
}
.removal_structure .container .flex_bt .reason .reason_detail {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
}
.removal_structure .container .flex_bt .img_div img {
  width: 100%;
  height: auto;
}
.removal_structure .container .flex_bt {
  align-items: flex-start;
  gap: 2rem;
}
@media screen and (max-width: 1000px) {
  .removal_structure .container .flex_bt {
    gap: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt {
    align-items: center;
  }
}
.removal_structure .container .flex_bt .method_div {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt .method_div {
    width: 100%;
  }
}
.removal_structure .container .flex_bt .method_div .method_title {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  border-radius: 5rem;
  padding: 1rem 0;
  margin: 0 auto 2rem auto;
}
.removal_structure .container .flex_bt .method_div .method_title.old {
  color: black;
  background-color: #d9d9d9;
}
.removal_structure .container .flex_bt .method_div .method_title.new {
  color: #ffff00;
  background-color: #3d75ff;
}
.removal_structure .container .flex_bt .method_div .img_div img {
  width: 100%;
  height: auto;
}
.removal_structure .container .flex_bt .method_div .method_text {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
}
.removal_structure .container .flex_bt .arrow_div {
  margin: 10rem 0 0 0;
}
@media screen and (max-width: 768px) {
  .removal_structure .container .flex_bt .arrow_div {
    margin: 5rem auto;
    transform: rotate(90deg);
  }
}

.before_after_section {
  background-color: #edf2fa;
}
.before_after_section .container {
  max-width: 100rem;
}
.before_after_section .container .h3_title .ba_text {
  margin: 0 10px; /* BEFRORE と AFTER に間隔を設ける */
}
.before_after_section .container .h3_title .triangle {
  background: #3d75ff;
  margin: 0 1.5rem;
  height: 2.5980762114rem;
  width: 3rem;
  -webkit-clip-path: polygon(50% 0, 100% 100%, 0 100%);
          clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: rotate(90deg);
}
.before_after_section .container .flex_bt {
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 2rem;
}
.before_after_section .container .flex_bt .ba_div {
  max-width: 40rem;
  width: 100%;
  background-color: white;
  border-radius: 3rem;
  padding: 3rem;
}
@media screen and (max-width: 1000px) {
  .before_after_section .container .flex_bt .ba_div {
    padding: 2rem;
  }
}
@media screen and (max-width: 1000px) {
  .before_after_section .container .flex_bt .ba_div {
    max-width: 32rem;
  }
}
@media screen and (max-width: 768px) {
  .before_after_section .container .flex_bt .ba_div {
    max-width: 27rem;
    padding: 1.8rem;
    border-radius: 2rem;
  }
}
@media screen and (max-width: 400px) {
  .before_after_section .container .flex_bt .ba_div {
    padding: 2rem;
    border-radius: 1.5rem;
  }
}
.before_after_section .container .flex_bt .ba_div h4 {
  font-size: 3.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin: 0 auto 4rem auto;
}
@media screen and (max-width: 1000px) {
  .before_after_section .container .flex_bt .ba_div h4 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 400px) {
  .before_after_section .container .flex_bt .ba_div h4 {
    font-size: 2.4rem;
    margin: 0 auto 2rem auto;
  }
}
.before_after_section .container .flex_bt .ba_div .flex_bt {
  gap: 0.5rem;
  align-items: stretch;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .arrow {
  height: 20rem;
  flex: 1;
  margin: 0 1rem;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .arrow .img {
  width: 100%;
  height: auto;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box {
  flex: 3;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box .img_div {
  width: 100%;
  height: 20rem;
  margin: auto;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 400px) {
  .before_after_section .container .flex_bt .ba_div .flex_bt .img_box .img_div {
    height: unset;
  }
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box .img_div img {
  width: 100%;
  height: auto;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box .before_after {
  font-size: 2rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  border-radius: 5rem;
  padding: 1rem 0;
  margin: 4rem 0 0 0;
}
@media screen and (max-width: 768px) {
  .before_after_section .container .flex_bt .ba_div .flex_bt .img_box .before_after {
    margin: 2rem 0 0 0;
    padding: 0.8rem 0;
    font-size: 1.4rem;
  }
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box .before_after.before {
  color: black;
  background-color: #d9d9d9;
}
.before_after_section .container .flex_bt .ba_div .flex_bt .img_box .before_after.after {
  color: #ffff00;
  background-color: #3d75ff;
}
.before_after_section .container .asterisk {
  margin: 5rem auto 0 auto;
  font-size: 1.6rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .before_after_section .container .asterisk {
    margin: 2rem auto 0 auto;
  }
}

.features_section {
  background-color: white;
  padding-bottom: 0;
}
.features_section .container {
  max-width: 100rem;
}
.features_section .container .h3_title {
  color: #3d75ff;
}
@media screen and (max-width: 768px) {
  .features_section .container .h3_title {
    font-size: 2.4rem;
  }
  .features_section .container .h3_title .newline {
    display: inline;
  }
}
.features_section .container .some_targets {
  display: flex;
  justify-content: space-between;
  gap: 3rem;
}
@media screen and (max-width: 1000px) {
  .features_section .container .some_targets {
    gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .features_section .container .some_targets {
    flex-flow: column;
  }
}
.features_section .container .some_targets .target {
  width: 100%;
  background-color: #3d75ff;
  border-radius: 5rem;
  padding: 1rem 0;
  color: #ffff00;
  margin: unset;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .features_section .container .some_targets .target {
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
  }
}
.features_section .container .h4_title {
  color: black;
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .features_section .container .h4_title {
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 400px) {
  .features_section .container .h4_title {
    font-size: 2.4rem;
  }
}
.features_section .container .some_features {
  align-items: stretch;
  gap: 3rem;
}
@media screen and (max-width: 1000px) {
  .features_section .container .some_features {
    gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .features_section .container .some_features {
    flex-flow: column;
  }
}
.features_section .container .some_features .feature_div {
  width: 100%;
  display: flex;
  flex-flow: column;
}
.features_section .container .some_features .feature_div .img_div {
  width: 100%;
  border-radius: 2rem 2rem 0 0;
  background-color: #edf2fa;
}
.features_section .container .some_features .feature_div .img_div img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.features_section .container .some_features .feature_div .text_div {
  height: 100%;
  border-radius: 0 0 2rem 2rem;
  padding: 2.5rem;
  background-color: #edf2fa;
}
@media screen and (max-width: 768px) {
  .features_section .container .some_features .feature_div .text_div {
    padding: 2rem 1.5rem 1.5rem 1.5rem;
  }
}
.features_section .container .some_features .feature_div .text_div .h5_title {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: #3d75ff;
  margin: 0 auto 2.5rem auto;
}
@media screen and (max-width: 768px) {
  .features_section .container .some_features .feature_div .text_div .h5_title {
    font-size: 2.6rem;
  }
}
.features_section .container .some_features .feature_div .text_div .text {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: justify;
  line-height: 1.5;
  color: black;
  margin: 0;
}

.ranking_section {
  background-color: white;
}
.ranking_section .container {
  max-width: 100rem;
}
.ranking_section .container .table_scroll {
  overflow-x: auto;
  white-space: nowrap;
  padding: 5rem 0 0 0;
}
@media screen and (max-width: 768px) {
  .ranking_section .container .table_scroll {
    padding: 3rem 0 0 0;
  }
}
.ranking_section .container .table_scroll table {
  width: 100%;
  margin-bottom: 1.5em;
  border-spacing: 0;
}
.ranking_section .container .table_scroll table th {
  padding: 15px 15px;
  vertical-align: middle;
  font-weight: 500;
  background: #edf2fa;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: black;
  margin: 0;
}
.ranking_section .container .table_scroll table th:nth-child(2) {
  background-color: #3d75ff;
  color: white;
  border-left: 8px solid #3d75ff;
  border-right: 8px solid #3d75ff;
  border-radius: 1rem 1rem 0 0;
}
.ranking_section .container .table_scroll table .thth {
  background: transparent !important;
}
.ranking_section .container .table_scroll table .oukan_p {
  position: relative;
}
.ranking_section .container .table_scroll table .oukan_p .img {
  position: absolute;
  top: -10%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 6rem;
  height: auto;
}
.ranking_section .container .table_scroll table *,
.ranking_section .container .table_scroll table *::before,
.ranking_section .container .table_scroll table *::after {
  box-sizing: border-box;
}
.ranking_section .container .table_scroll table td {
  padding: 15px 15px;
  vertical-align: middle;
  outline: none;
  border-left: 1px solid #edf2fa;
  border-right: 1px solid #edf2fa;
}
.ranking_section .container .table_scroll table td:nth-child(2) {
  border-left: 8px solid #3d75ff;
  border-right: 8px solid #3d75ff;
}
.ranking_section .container .table_scroll table td.king {
  border-bottom: 8px solid #3d75ff;
}
.ranking_section .container .table_scroll table td .list_contents {
  font-size: 1.5rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  color: black;
  margin: 0;
  text-align: center;
}
.ranking_section .container .table_scroll table td .list_contents.king {
  color: #3d75ff;
}
.ranking_section .container .table_scroll table td .list_contents .mark_icon {
  font-size: 2.8rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  margin: 0;
}
.ranking_section .container .table_scroll table .td_head {
  background: #edf2fa;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  color: black;
  margin: 0;
}

.voice_section {
  background-color: #edf2fa;
}
.voice_section .container {
  max-width: 100rem;
}
.voice_section .container .h3_title {
  color: black;
}
.voice_section .container .flex_bt {
  gap: 2rem;
}
@media screen and (max-width: 768px) {
  .voice_section .container .flex_bt {
    flex-flow: column;
    gap: 4rem;
  }
}
.voice_section .container .flex_bt .img_div {
  max-width: 100%;
}
.voice_section .container .flex_bt .img_div .img {
  width: 100%;
  height: auto;
}

.preparation_setion {
  background-color: white;
}
.preparation_setion .container {
  max-width: 100rem;
  text-align: center;
}
.preparation_setion .container .h3_title {
  color: black;
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 0;
  position: relative;
}
.preparation_setion .container .h3_title::before, .preparation_setion .container .h3_title::after {
  border-top: 1px solid #333;
  content: "";
  display: inline;
  flex-grow: 1;
  top: 50%;
}
.preparation_setion .container .h3_title::before {
  margin: 0 2rem 0 0;
}
.preparation_setion .container .h3_title::after {
  margin: 0 0 0 2rem;
}
.preparation_setion .container .text {
  font-size: 1.6rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.5;
  color: black;
}
.preparation_setion .container .text.mt_5 {
  margin: 5rem auto;
}
.preparation_setion .container .img_div {
  max-width: 82.5rem;
  margin: auto;
}
.preparation_setion .container .img_div .img {
  width: 100%;
  height: auto;
}

.qa_section {
  background-color: #edf2fa;
}
.qa_section .container {
  max-width: 100rem;
  text-align: center;
  /* 装飾用 */
}
.qa_section .container .h3_title {
  color: black;
}
.qa_section .container .a_header,
.qa_section .container .a_content {
  transition: background 0.3s ease;
  cursor: pointer;
  position: relative;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  background-color: white;
}
.qa_section .container .a_header .text_div .text,
.qa_section .container .a_content .text_div .text {
  padding-left: 5rem;
  padding-right: 2rem;
  position: relative;
  margin: 0;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: justify;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .qa_section .container .a_header .text_div .text,
  .qa_section .container .a_content .text_div .text {
    font-size: 1.6rem;
  }
}
.qa_section .container .a_header .text_div .text::before,
.qa_section .container .a_content .text_div .text::before {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  left: 2rem;
  color: black;
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  border-radius: 2rem;
  width: 2rem;
  height: 2rem;
  padding: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  background-color: #3d75ff;
}
@media screen and (max-width: 400px) {
  .qa_section .container .a_header .text_div .text::before,
  .qa_section .container .a_content .text_div .text::before {
    font-size: 1.6rem;
  }
}
.qa_section .container .a_header {
  margin: 4rem 0 0;
  color: black;
  padding: 1.5rem;
  border-radius: 2rem;
}
.qa_section .container .a_header.active {
  border-radius: 2rem 2rem 0 0;
}
.qa_section .container .a_header .text_div .text::before {
  content: "Q";
}
.qa_section .container .a_header::before, .qa_section .container .a_header::after {
  content: "";
  position: absolute;
  top: 1px;
  right: 1.5rem;
  bottom: 0;
  width: 12px;
  height: 2px;
  margin: auto;
  background: black;
}
.qa_section .container .a_header::after {
  transform: rotate(-90deg);
  transition: transform 0.3s;
}
.qa_section .container .a_header.active::after {
  transform: rotate(0deg);
}
.qa_section .container .a_content {
  display: none;
  color: black;
  padding: 0 1.5rem 1.5rem 1.5rem;
  border-radius: 0 0 2rem 2rem;
}
.qa_section .container .a_content .text_div {
  border-top: 1px solid #333333;
  padding: 1.5rem 0 0 0;
}
.qa_section .container .a_content .text_div .text::before {
  content: "A";
}/*# sourceMappingURL=lp.css.map */