@charset "utf-8";
/*==================================================================

  メインビジュアル

==================================================================*/
.top_mainvisual{
/*
  background: url("../images/mv.jpg") center no-repeat;
  background-size: cover;
*/
}

.mainvisual_inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 90%;
  height: 100%;
  max-width: 1280px;
  margin: auto;
}
.mainvisual_img {
  position: relative;
  z-index: -1;
  max-height: 1084px;
  min-height: 900px;
}
.mainvisual_img img {
  object-fit: cover;
  width: 100%;
  min-height: 900px;
  
}
/* キャッチフレーズ */
.mainvisual_catch{
  text-align: center;
  position: relative;
  width: 23%;
  max-width: 293px;
  margin: auto;
  margin-top: 26vw;
}
.mainvisual_catch img {
  width: 100%;
}


.mv_catch_title {
  position: absolute;
  left: -39px;
  right: 0;
  margin: auto;
  bottom: -40px;
  text-align: center;
  width: 100%;
}


.mv_catch_list {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 1200px;
  margin: auto;
  padding-top: 3.2%;
}
.mv_catch_item {
  width: 25%;
  letter-spacing: 0.02em;
  font-family: "DS-soyokaze";
  font-size: 2.2rem;
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
}
.mv_catch_item:first-child,
.mv_catch_item:last-child {
  margin-top: 86px;
}
.mv_catch_item::before {
  position: absolute;
  left: -2%;
  top: -50px;
  background: url("../images/catch_item_bg01.png") center no-repeat;
  background-size: 100%;
  width: 104%;
  max-width: 310px;
  height: 215px;
  content: "";
  z-index: -1;
}
.mv_catch_item:nth-child(1) {
  position: relative;
  left: 7%;
}
.mv_catch_item:nth-child(2)::before {
  background-image: url("../images/catch_item_bg02.png");
}
.mv_catch_item:nth-child(3) {
  top: -5px;
}
.mv_catch_item:nth-child(3)::before {
  background-image: url("../images/catch_item_bg03.png");

}
.mv_catch_item:nth-child(4) {
  position: relative;
  right: 7.5%;
}
.mv_catch_item:nth-child(4)::before {
  background-image: url("../images/catch_item_bg04.png");
}


/*===============================================================

 タイトル
 
===============================================================*/
.tit01 {
  font-family: "DS-soyokaze";
  width: 100%;
  text-align: center;
  line-height: 0.9em;;
  font-size: 5.1rem;
  letter-spacing: 0.1em;
  z-index: 2;
  position: relative;
  
}
.tit01 span {
  display: inline-block;
  line-height: 1;
  font-size: 3.2rem;
  letter-spacing: 0.1em;
  position: relative;
  color: #ec75a8;
  text-align: center;
  padding-top: 15px;
  width: 100%;
  max-width: 399px;
  margin-bottom: 22px;
  z-index: 1;
}
.tit01 span::before {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  margin: auto;
  background: url("../images/tit01_balloon.png") top center no-repeat;
  background-size: 100%;
  width: 399px;
  height: 83px;
  content: "";
  z-index: -1;
}
.tit01 span::after {
  position: absolute;
  left: -70px;
  top: -38px;
  margin: auto;
  background: url("../images/tit01_flower.png") top center no-repeat;
  background-size: 100%;
  width: 20%;
  max-width: 46px;
  height: 48px;
  content: "";
  z-index: -1;
}
.tit01 i {
  font-size: 8.8rem;
  color: #f6af0c;
  font-style: normal;
  position: relative;
  top: 10px;
}
.tit01_en {
  line-height: 1;
  font-family: "Oleo Script", system-ui;
  font-weight: 400;
  font-size: 8.2rem;
  font-style: normal;
  color: #d4edf8;
  text-align: center;
  margin-top: -45px;
  position: relative;
  z-index: 1;
  
}
.tit01_en::before {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -69%;
  margin: auto;
  background: url("../images/tit01_bg.png") center no-repeat;
  width: 90%;
  max-width: 500px;
  height: 286px;
  background-size: 100%;
  content: "";
  z-index: -1;
}

/*===============================================================

 .top_problem

===============================================================*/

.top_problem {
  padding-top: 6.8%;

}
.top_problem .tit01 {
  max-width: 1200px;
  width: 90%;
  margin: auto;
  position: relative;
}
.top_problem .tit01::before {
  position: absolute;
  right: -95px;
  top: -125px;
  background: url("../images/problem_img02.png") top center no-repeat;
  width: 381px;
  height: 295px;
  content: "";
  background-size: 100%;

}
.top_problem_list {
  display: flex;
  flex-wrap: wrap;
  border: solid 2px rgba(246,175,2,0.42);
  background: #fefaf0;
  border-radius: 40px;
  position: relative;
  padding: 3.4% 1.6% 1.3% 2.6%;
  gap: 0 2%;
  width: 90%;
  max-width: 1200px;
  margin: auto;
  z-index: 2;
}
.top_problem_list::after {  
  position: absolute;
  left: -225px;
  top: -308px;
  background: url("../images/problem_img01.png") top center no-repeat;
  width: 40%;
  max-width: 437px;
  height: 288px;
  content: "";
  background-size: 100%;
}
.top_problem_list::before {
  position: absolute;
  top: 5px;
  left: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  border: solid 2px rgba(246,175,2,0.42);
  content: "";
   border-radius: 36px;
}
.top_problem_item {
  width: 32%;
  margin-bottom: 2.6%;
  padding-left: 40px;
  position: relative;
  z-index: 2;
    font-family: "DS-soyokaze";
  letter-spacing: 0;
  font-size: 2.4rem;
  line-height: 1.25;
}
.top_problem_item::before {
  position: absolute;
  top: 0;
  left: -4px;
  background: url("../images/check_orange.png") center no-repeat;
  width: 35px;
  height: 35px;
  background-size: 100%;
  content: "";
}
.top_problem_kazari01 {
  display: block;
  position: relative;
  z-index: 1;
  width: 100%;
  background: #fff;
  max-width: 1200px;
  margin: auto;
}
.top_problem_kazari01::before {
  position: absolute;
  left: -267px;
  bottom: -77px;
  background: url("../images/problem_img03.png") center no-repeat;
  width: 344px;
  height: 227px;
  content: "";
  background-size: 100%;
  z-index: -2;

}
.top_problem_kazari01::after {
  position: absolute;
    right: -231px;
    bottom: -51px;
  background: url("../images/problem_img04.png") center no-repeat;
  width: 356px;
  height: 288px;
  content: "";
  background-size: 100%;
  z-index: -2;

}
.top_problem_item.item_line2 {
  position: relative;
  top: -10px;
}

.top_problem .inner01 {
  margin-top: 40px;
  position: relative;
}
.top_problem .inner01::before {
  position: absolute;
  top: -36%;
  left: 0;
  background: url("../images/top_problem_bg_left.png") top left no-repeat;
  width: 30%;
  max-width: 446px;
   height:  778px;
  background-size: 100%;
  content: ""
}
.top_problem .inner01::after{
  position: absolute;
  top: -93%;
  right: 0;
  background: url("../images/top_problem_bg_right.png") top right no-repeat;
  width: 30%;
  max-width: 453px;
   height:  789px;
  background-size: 100%;
  content: ""
}

.top_problem .inner02 {
  position: relative;
  padding-bottom: 100px;
}
.top_problem .inner02::before {
  position: absolute;
  top: -170px;
  left: 0;
  width: 100%;
  height: 979px;
  background: url("../images/top_problem_bg01.png") top center repeat-x;
  content: "";
  z-index: -2;
  
}
.top_problem .inner02::after {
  position: absolute;
  bottom: -190px;
  left: 0;
  width: 100%;
  height: 585px;
  background: url("../images/problem_bg02.png") top center repeat-x;
  content: "";
  z-index: -1;
  
}
.top_problem .inner02 .box1 {
  display: flex;
  justify-content: space-between;
  margin-top: 78px;
  position: relative;
  z-index: 1;
}
.top_problem .inner02 .box1::before {
  position: absolute;
  top: 230px;
  left: -23%;
  background: url("../images/problem_kazari.png") center no-repeat;
  width: 30%;
  max-width: 200px;
  height: 267px;
  content: "";
}
.top_problem .inner02 .box1::after {
  position: absolute;
  top: 230px;
  right: -23%;
  background: url("../images/problem_kazari.png") center no-repeat;
  width: 30%;
  max-width: 200px;
  height: 267px;
  content: "";
  transform: scale(-1,1);
}
.top_problem .inner02 .box1 > li {
    width: 46.6%;
}

.top_problem_dl_tit {
  text-align: center;
}


.top_problem_list02 .top_problem_item {
  width: 100%;
  margin-bottom: 3.4%;
  line-height: 1.45;
  
}
.top_problem_list02 .top_problem_item::before {
  background-image: url("../images/check_blue.png")
}
.top_problem_child_list.item_pink .top_problem_item::before{
background-image: url("../images/check_pink.png")
}
.top_problem_child_list {
  padding: 5.7% 5% 0.1% 10%;
  position: relative;
  min-height: 509px
}
.top_problem_child_list::before {
  position: absolute;
  left: 0;
  top: -70px;
  width: 100%;
  height: calc(100% + 100px);
  background: #e1f3fa;
  border-radius: 40px;
  content: "";
  z-index: -1;
  border: solid 2px #b9e4f3;
}
.top_problem_child_list::after {
  position: absolute;
  left: 5px;
  top: -65px;
  width: calc(100% - 10px);
  height: calc(100% + 90px);
  background: #e1f3fa;
  border-radius: 40px;
  content: "";
  z-index: -1;
  border: solid 2px #b9e4f3;
}

.top_problem_child_list.item_pink::before,
.top_problem_child_list.item_pink::after {
  background: #fbe5e4;
  border-color: #f9b7b6;
}

 .top_problem_item.item_no_check {
   position: absolute;
   bottom: -14px;
   right: 65px;
   width: auto;
 }
 .top_problem_item.item_no_check::before {
   display: none;
 }
.top_problem_table_list_wrapper {
  background: #fdeac2;
  padding-bottom: 220px;
  padding-top: 29px;
  position: relative;
  z-index: 1;
}
.top_problem_table_list_wrapper::before {
  position: absolute;
  top: 20%;
  left: 3.2%;
  background: url("../images/dot_kazari01.png") center no-repeat;
  width: 20%;
  max-width: 222px;
  height: 205px;
  content: "";
  background-size: 100%;
}
.top_problem_table_list_wrapper::after {
  position: absolute;
  top: 20.7%;
  right: 3%;
  background: url("../images/dot_kazari01.png") center no-repeat;
  width: 20%;
  max-width: 222px;
  height: 205px;
  content: "";
  transform: scale(-1,1);
  background-size: 100%;
  z-index: -1;
}
.top_problem_table_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 90%;
  max-width: 1370px;
  margin: auto;
}

.top_problem_table_item {
  width: 32.5%;
  text-align: center;
  margin-bottom: 6%;
}

.top_problem_table_item:nth-child(1),
.top_problem_table_item:nth-child(2) {
  width: 37%;
}
.top_problem_table_item:nth-child(1) {
  text-align: left
}
.top_problem_table_item:nth-child(2) {
  text-align: right
}
.top_problem_table_item:nth-child(4) {
  width: 35%
}
/*===============================================================

 .top_orth

===============================================================*/
.top_orth {
  position: relative;
  margin-top: -30px;
  z-index: 1;
  padding-bottom: 250px;
}
.top_orth::before {
  position: absolute;
  top: -33px;
  left: 0;
  width: 100%;
  background: url("../images/top_orth_bg01.png") top center no-repeat;
  background-size: 100%;
  height: 979px;
  content: "";
  z-index: -1;
}
.top_orth::after {
  position: absolute;
  top: 200px;
  left: 0;
  background: #d3f2d7;
  width: 100%;
  height: calc(100% - 200px);
  content: "";
  z-index: -2;
}
.top_orth .tit01 {
  letter-spacing: 0;
  width: 90%;
  max-width: 1200px;
  margin: auto;
}
.top_orth .tit01::before {
  position: absolute;
  top: 13px;
  left: -152px;
  background: url("../images/top_orth_img01.png") top center no-repeat;
  width: 30%;
  max-width: 339px;
  height: 379px;
  content: "";
}
.top_orth .tit01::after {
  position: absolute;
  top: 105px;
  right: -112px;
  background: url("../images/top_orth_img02.png") top center no-repeat;
   background-size: 100%;
  width: 30%;
  max-width: 296px;
  height: 363px;
  content: "";
}
.top_orth .tit01_en::before {
  top: -14px;
    background: url("../images/top_orth_tit01_bg.png") center no-repeat;
     background-size: 100%;
    width: 90%;
    max-width: 805px;
    height: 490px;
}
 .top_orth_sub_tit {
   text-align: center;
   position: relative;
   z-index: 1;
   width: 90%;
   max-width: 1200px;
   margin: 0 auto 200px;
 }

 .top_orth_sub_tit::before {
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    bottom: -166px;
    background: url("../images/top_orth_ill.png") top center no-repeat;
    background-size: 100%;
    width:90%;
    max-width: 582px;
    height: 150px;
    content: "";
 }
  .top_orth_list {
    width: 90%;
    max-width: 1200px;
    margin: auto;
    padding-top: 100px;;
  }
  .top_orth_item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10.4%;
    position: relative;
  }
  .top_orth_item::before {  
    position: absolute;
    top:-10px;
    left: calc((100vw - 1200px) /2 * -1);
    background: url("../images/top_orth_item_kazari01.png") top left no-repeat;
    width: 50%;
    max-width: 395px;
    height: 513px;
    content: "";
    background-size: 100%;
  }
  .top_orth_item:nth-child(2)::before {
    background: url("../images/top_orth_item_kazari02.png") top right no-repeat;
    left: auto;
    right: calc((100vw - 1200px) /2 * -1);
    top: -53px;
    background-size: 100%;
  }
  .top_orth_item:nth-child(3)::before {
    background-image: url("../images/top_orth_item_kazari03.png");
  }
  .top_orth_item_img {
    width: 52%;
    position: relative;
    margin-left: 10px;
    z-index: 1;
  }

  .top_orth_item_detail {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    width: 46%;
    font-family: "DS-soyokaze";
    letter-spacing: 0.1em;
    position: relative;
  }
   .top_orth_item_detail::before {
     position: absolute;
     left: -135px;
     top: 25px;
     width: 300%;
     height: calc(100% - 54px);
     background: url("../images/top_orth_item_bg.jpg") top left repeat;
     z-index: -1;
     content: "";
     border-radius: 120px;
   }
  .top_orth_item_tit {
    font-size: 4.6rem;
    line-height: 1;
    margin-bottom: 18px;
    padding-bottom: 20px;
    color: #087c47;
    background: url("../images/orth_item_tit_kazari01.png") bottom left no-repeat;
  }
  .top_orth_item_text {
    font-size: 2.4rem;
    line-height: 1.875;
    padding-bottom: 84px;
    
  }
  
  .top_orth_item:nth-child(even) {
    flex-direction: row-reverse;
  }
  
  .top_orth_item:nth-child(even) .top_orth_item_img {
    text-align: right;
    margin-left: auto;
    margin-right: 10px;
  }
  .top_orth_item:nth-child(even) .top_orth_item_detail {
    width: 49%;
  }
  .top_orth_item:nth-child(even) .top_orth_item_detail::before {
    left: auto;
    right: -120px;
    height: 104%;
    top: -2%;
  }
.top_orth_item:nth-child(1) .top_orth_item_tit   {
    background: url("../images/orth_item_tit_kazari01.png") bottom left repeat-x;
}
.top_orth_item:nth-child(2) .top_orth_item_tit {
   color: #58a7dc;
  background-image: url("../images/orth_item_tit_kazari02.png");
}
.top_orth_item:nth-child(3) .top_orth_item_tit {
  color: #f6af0c;
  background-image: url("../images/orth_item_tit_kazari03.png");
}
  


/*===============================================================

 .top_merit

===============================================================*/
.top_merit {
  position: relative;
  z-index: 2;
}
.top_merit::before {
  position: absolute;
  top: -357px;
  left: 0;
  background: url("../images/top_merit_bg.jpg") top center no-repeat;
  background-size: 100%;
  width: 100%;
  height: 2240px;
  content: "";
  z-index: -1;
}
.top_merit::after {
  position: absolute;
    bottom: 233px;
    right: -90px;
  background: url("../images/top_merit_content_ill04.png") top center no-repeat;
  background-size: 100%;
  width: 314px;
  height: 312px;
  content: "";
  z-index: -1;
}
.top_merit .tit01 {
  max-width: 1200px;
  margin: 0 auto 297px;
}
.top_merit .tit01::before {
  position: absolute;
  left: -120px;
  top: -346px;
  background: url("../images/top_merit_ill_left.png") top left no-repeat;
  width:  60%;
  max-width: 672px;
  height: 497px;
  content: "";
  background-size: 100%;
}
.top_merit .tit01::after {
  position: absolute;
  right: -165px;
  top: -269px;
  background: url("../images/top_merit_ill_right.png") top left no-repeat;
  width:  60%;
  max-width: 434px;
  height: 380px;
  content: "";
  background-size: 100%;
}

.tit01 span.top_merit_tit01 {
  color: #333;
  line-height: 1;
   font-size: 3.9rem;
  white-space: nowrap;
  margin-top: -16px;
  letter-spacing: 0;
}
.tit01 span.top_merit_tit01::before {
  background: url("../images/top_merit_tit_mark.png") top left no-repeat;
  left: -73px;
  right: auto;
  top: 34px;
  width: 71px;
  height: 51px;
}
.tit01 span.top_merit_tit01::after {
  background: url("../images/top_merit_tit_mark.png") top left no-repeat;
  right: -83px;
  top: 34px;
  transform: scale(-1, 1);
  left: auto;
  width: 71px;
  height: 51px;
  max-width: 71px;
}

.tit01 span.top_merit_tit01 i {
  color: #24bbef;
 font-size: 6.8rem;
 
}
.top_merit_tit_ja {
position: relative;
display: block;
line-height: 1;

text-shadow:
  2px 2px 2px #fff, -2px -2px 2px #fff,
  -2px 2px 2px #fff,  2px -2px 2px #fff,
  2px 0 2px #fff, -2px  0 2px #fff,
  0 2px 2px #fff,  0 -2px 2px #fff,
  2px 2px 2px #fff, -2px -2px 2px #fff,
  -2px 2px 2px #fff,  2px -2px 2px #fff,
  2px 0 2px #fff, -2px  0 2px #fff,
  0 2px 2px #fff,  0 -2px 2px #fff,
  2px 2px 2px #fff, -2px -2px 2px #fff,
  -2px 2px 2px #fff,  2px -2px 2px #fff,
  2px 0 2px #fff, -2px  0 2px #fff,
  0 2px 2px #fff,  0 -2px 2px #fff,
  2px 2px 2px #fff, -2px -2px 2px #fff,
  -2px 2px 2px #fff,  2px -2px 2px #fff,
  2px 0 2px #fff, -2px  0 2px #fff,
  0 2px 2px #fff,  0 -2px 2px #fff;
  
}

.top_merit_tit_ja::before {
  position: absolute;
  top: -9px;
  left: 0;
  right: 0;
  margin: auto;
  background: url("../images/merit_item_bg_tit.png") top center no-repeat;
  width: 100%;
  height: 122px;
  content: "";
  z-index: -1;
}
.top_merit_tit_ja::after {
  position: absolute;
  top:-260px;
  left: 0;
  right: 0;
  margin: auto;
  background: url("../images/top_merit_tit_bg.png") top center no-repeat;
  width: 100%;
  height: 490px;
  content: "";
  z-index: -2;
}


.top_merit_list {
  display: flex;
  flex-wrap: wrap;
  width: 90%;
  max-width: 1200px;
  margin: auto;
  justify-content: space-between;
  position: relative;
}
.top_merit_list::before {
  position: absolute;
  left: -108px;
  top: -266px;
  background: url("../images/top_merit_content_kazari01.png") top left no-repeat;
  width:30%;
  max-width: 224px;
  height: 206px;
  content: "";
  background-size: 100%;
}
.top_merit_list::after {
  position: absolute;
  right: -108px;
  top: -246px;
  background: url("../images/top_merit_content_kazari02.png") top left no-repeat;
  width:30%;
  max-width: 224px;
  height: 206px;
  content: "";
  background-size: 100%;
}
.top_merit_item {
  width: 31.66%;
  margin-bottom: 7%;
  position: relative;
}
.top_merit_item:nth-child(1)::before {
  position: absolute;
  left: -270px;
  top: 74px;
  background: url("../images/top_merit_content_ill01.png") center no-repeat;
  width: 224px;
  height: 453px;
  content: "";
  baseline-shift: 100%;
}
.top_merit_item:nth-child(3)::before {
  position: absolute;
right: -274px;
    top: 298px;
  background: url("../images/top_merit_content_ill02.png") center no-repeat;
  width: 224px;
  height: 206px;
  content: "";
  baseline-shift: 100%;
}
.top_merit_item:nth-child(4)::before {
  position: absolute;
left: calc((100vw - 1200px + 150px) / 2 * -1);
  top: -24px;
  background: url("../images/top_merit_content_ill03.png") center no-repeat;
  width: 314px;
  height: 312px;
  content: "";
  baseline-shift: 100%;
  z-index: -1;
}

.top_merit_item img {
  min-width: 412px;
  margin-left: -13%;
}



.top_merit_item_tit {
  text-align: center;
  font-size: 3.1rem;
  letter-spacing: 0.1em;
  font-family: "DS-soyokaze";
  line-height: 1.45;
  color: #24bbef;
  margin-top:7.7%;
  margin-bottom: 8%;
}
.top_merit_item_tit span {
  white-space: nowrap;
  left: -7%;
  position: relative;
}

.top_merit_item_text {
  font-size: 1.6rem;
  letter-spacing: 0.06em;
  line-height: 2.5;
  position: relative;
  height: 240px;
  z-index: 2;
  padding: 5% 8.7%;
  background: #f0f9fe;
  border-radius: 40px;
}

.top_merit_item_text::before  {
  position: absolute;
  top: 0;
  left:0;
  right: 0;
 background: #f0f9fe;
  width: 100%;
  height: 100%;
  content: "";
  z-index: -1;
  background-size: 100%;
  border-radius: 40px;
}
.top_merit_item_text::after {
  position: absolute;
  top: 20px;
  left:-15px;
  right: 0;
  background: url("../images/merit_item_bg_dot.png") center no-repeat;
  width: 100%;
  height: 100%;
  content: "";
  z-index: -2;
  background-size: 100%;
  border-radius: 40px;
}

.top_merit_item:nth-child(2),
.top_merit_item:nth-child(5){
  margin-top: -62px;
}


.top_merit_item:nth-child(even) .top_merit_item_tit {
  color: #f6af0c;
}
.top_merit_item:nth-child(even) .top_merit_item_text::before {
  background:#fef1d8;
}
.top_merit_item:nth-child(even) .top_merit_item_text::after {
  background-image: url("../images/merit_item_bg_dot02.png");
}

/*===============================================================

 .top_cv

===============================================================*/
.top_cv {
  padding-top: 90px;
  position: relative;
  padding-bottom: 563px;
  background: url("../images/cv_bg.jpg") bottom -28px  center no-repeat;
  background-size: 100%;
  z-index: 1;
}
.top_cv::before {
  position: absolute;
  top: -66px;
  left: 2.2%;
  background: url("../images/cv_bg_left.png") top left no-repeat;
  width: 30%;
  background-size: 100%;
  max-width: 393px;
  height: 676px;
  content: "";
  z-index: 2;
}
.top_cv::after {
  position: absolute;
  top: -28px;
  right: 0;
  background: url("../images/cv_bg_right.png") top left no-repeat;
  width: 30%;
  background-size: 100%;
  max-width:400px;
  height: 641px;
  content: "";
   z-index: 2;
}
.top_cv.item_02 {
  padding-top: 65px;
  padding-bottom: 300px;
  background-position: bottom -15vw center;
}
.top_cv.item_02::before {
  top: -90px;
}
.top_cv.item_02::after {
  top: -53px;
}

.top_cv .box1{
  display: flex;
  justify-content: space-between;
  background: #72c0d5;
  border-radius: 27.5px;
  position: relative;
  z-index: 3;
}
.top_cv .box1::before {
  position: absolute;
  right: -20px;
  bottom: -30px;
  background: url("../images/cv_dot.png") bottom right no-repeat;
  width: 30%;
  max-width: 132px;
  height: 136px;
  content: "";
  z-index: 2;
  background-size: 100%;
}

.top_cv_detail {
  width: 53%;
  text-align: center;
  padding: 5.3% 0 4.5% 4.4%;
  
}
.top_cv_tit {
  margin-bottom: 30px;
}
.top_cv_img{
  width: 46.5%;
  position: relative;
}
.top_cv_img::before {
  position: absolute;
  top: -37px;
  left: -12px;
  background: url("../images/cv_flower.png") top left no-repeat;
  background-size: 100%;
  width: 34%;
  max-width: 168px;
  height: 258px;
  content: "";
}
.top_cv_btn a {
  transition: 0.15s ease-out;
}
.top_cv_btn a:hover {
  opacity: 0.8;
}
.top_cv_kazari {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
.top_cv_kazari::before {
  position: absolute;
  bottom: 152px;
  left: 0;
  background: url("../images/reef_left.png") bottom left no-repeat;
  background-size: 100%;
  width: 35%;
  max-width: 428px;
  height: 346px;
  content: "";
  z-index: -1
}
.top_cv_kazari::after {
  position: absolute;
  bottom: 177px;
  right: 0;
  background: url("../images/reef_right.png") bottom left no-repeat;
  background-size: 100%;
  width: 35%;
  max-width: 479px;
  height: 346px;
  content: "";
  z-index: -1
}
/*===============================================================

 .top_support

===============================================================*/
.top_support {
  text-align: center;
  margin-top: -240px;
  position: relative;
  z-index: 1;
  padding-bottom: 260px;
}
.top_support::before {
  position: absolute;
  top: -80px;
  left: 0;
  background: url("../images/sup_bg01.png") top center no-repeat;
  background-size: 100%;
  width: 100%;
  height: 2000px;
  content: "";
  z-index: -1;
}
.top_support::after{
  position: absolute;
  top:1600px;
  left: 0;
  background: url("../images/sup_bg02.png") top center repeat-y;
  background-size: 100%;
  width: 100%;
  height: calc(100% - 1000px);
  content: "";
  z-index: -1;
}
.top_support_tit {
  padding: 0 5%;
  margin: auto;
  position: relative;
}
.top_support_tit ::before {
  position: absolute;
  left: 0;
  bottom: 9%;
  background: url("../images/sup_leef_left.png") top left no-repeat;
  background-size: 100%;
  width: 30%;
  max-width: 289px;
  height: 239px;
  content: "";
}
.top_support_tit ::after {
  position: absolute;
  right: 0;
  bottom: 18%;
  background: url("../images/sup_leef_right.png") top left no-repeat;
  background-size: 100%;
  width: 30%;
  max-width: 355px;
  height: 239px;
  content: "";
}

.top_support_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 90%;
  max-width: 1200px;
  margin: auto;
  padding-top: 42px;
}
.top_support_item {
  margin-bottom: 80px;
  font-family: "DS-soyokaze";
  position: relative;
  z-index: 1;
}
.top_support_item:nth-child(1)::before {
  position: absolute;
  bottom: 0;
  left: calc((100vw - 1220px) / 2 * -1);
  background: url("../images/sup_kazari_left.png") top left no-repeat;
  background-size: 100%;
  width: 100%;
  max-width: 358px;
  height: 406px;
  content: "";
  z-index: -1;
}
.top_support_item:nth-child(4)::before {
  position: absolute;
  top: 100px;
  right: calc((100vw - 1220px) / 2 * -1);
  background: url("../images/sup_kazari_right.png") top left no-repeat;
  background-size: 100%;
  width: 100%;
  max-width: 340px;
  height: 321px;
  content: "";
  z-index: -1;
}
.top_support_item_detail  {
  width: 84%;
  position: relative;
  z-index: 1;
  margin-left: auto;
  padding: 3.6% 6.8% 5% 5.1%;
  min-height: 240px;
}
.top_support_item_detail::before {
  position: absolute;
  top: -40px;
  left: 0;
  background: url("../images/sup_balloon_green.png") top center no-repeat;
  width: 100%;
  height: calc(100% + 50px);
  content: "";
  z-index: -1;
}
.top_support_item_tit {
  letter-spacing: 0.1em;
  font-size: 2.6rem;
  color: #127f17;
  background: rgba(128,197,131,0.22);
  border-radius: 20px;
  padding: 0.7%;
  margin-bottom: 4.4%;
}
.top_support_item_tit.item_ls0 {
  letter-spacing: 0
}
.top_support_item_text {
  letter-spacing: 0.1em;
  font-size: 2.2rem
}
.top_support_item.item_yellow .top_support_item_tit{
  color: #bd7724;
  background: rgba(239,199,98,0.22);
}
.top_support_item.item_yellow .top_support_item_detail::before {
  background-image: url("../images/sup_balloon_yelllow.png");
}
.top_support_item:nth-child(2n) {
  margin-top: 60px;
}



/*===============================================================

 .top_flow

===============================================================*/
.top_flow {
  position: relative;
  z-index: 1;
  padding-bottom: 220px;
}
.top_flow::before {
  position: absolute;
  top: 210px;
  left: 0;
  background: url("../images/flow_bg.jpg") top center repeat;
  width: 100%;
  height: calc(100% - 210px);
  content: "";
  z-index: -1;
}
.top_flow::after {
  position: absolute;
  top: 147px;
  left: 0;
  background: url("../images/flow_wave.png") top left repeat-x;
  width: 100%;
  height: 75px;
  content: "";
  z-index: -1;
}
.top_flow_tit {
  text-align: center;
  margin-top: -200px;
}
.top_flow_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 90%;
  margin: 2% auto;
  max-width: 1200px;
  overflow: hidden;
}
.top_flow_item {
  width: 31.5%;
  text-align: left;
  position: relative;
  margin-bottom: 4%;
}
.top_flow_item:nth-child(1),
.top_flow_item:nth-child(4) {
  left: -10px;
}
.top_flow_item:nth-child(3n) {
  right: -10px;
}
.top_flow_item_text {
  position: absolute;
  left: 0;
  bottom: 12%;
  font-family: "DS-soyokaze";
  font-size: 4.0rem;
  letter-spacing: 0.04em;
  text-align: center;
  width: 100%;
  line-height: 0.7;
  color: #2abfdb;
  
}
.top_flow_item:nth-child(2) .top_flow_item_text {
  color: #f6ad04;
}
.top_flow_item:nth-child(3) .top_flow_item_text {
  color: #c2b30c;
}
.top_flow_item:nth-child(4) .top_flow_item_text {
  color: #9ddb82;
}
.top_flow_item:nth-child(5) .top_flow_item_text {
  color: #64b770;
}
.top_flow_item:nth-child(6) .top_flow_item_text {
  color: #f0a8b1;
  margin-bottom: -4%;
}
.top_flow_item_text span.item_small01 {
  font-size: 3.3rem;
}
.top_flow_item_text span.item_small02 {
  font-size: 2.2rem;
}

.top_flow_item:not(:last-child)::before {
  position: absolute;
  right: -12%;
  top: 66%;
  background: url("../images/flow_arrow01.png") center no-repeat;
  width: 45px;
  height: 26px;
  content: "";
}
.top_flow_item:nth-child(2)::before {
  background-image: url("../images/flow_arrow02.png")
}
.top_flow_item:nth-child(3)::before {
  background-image: url("../images/flow_arrow03.png")
}
.top_flow_item:nth-child(4)::before {
  background-image: url("../images/flow_arrow04.png")
}
.top_flow_item:nth-child(5)::before {
  background-image: url("../images/flow_arrow05.png")
}
.top_flow_btn_list {
  width: 90%;
  max-width: 1200px;
  margin: -46px auto 0;
}
.top_flow_btn_item {
  text-align: right;
  margin-bottom: 2.7%;
}
.top_flow_btn_item a {
  transition: 0.15s ease-out;
}
.top_flow_btn_item a:hover {
  opacity: 0.7;
}
/*===============================================================

 .top_price

===============================================================*/
.top_price {
  padding-top: 3.3%;
  position: relative;
  z-index: 1;
  
}
.top_price::before {
  position: absolute;
  top: -224px;
  left: 0;
  background: url("../images/price_cloud.png") top center no-repeat;
  background-size: 100%;
  width: 100%;
  height: 1000px;
  content: "";
  z-index: -1;
}
.top_price .tit01::before {
  position: absolute;
  top: -100px;
  left: 0;
  background: url("../images/reef_left.png") bottom left no-repeat;
  background-size: 100%;
  width: 35%;
  max-width: 428px;
  height: 346px;
  content: "";
  z-index: -1
}
.top_price .tit01::after {
  position: absolute;
  top: -100px;
  right: 0;
  background: url("../images/reef_right.png") bottom left no-repeat;
  background-size: 100%;
  width: 30%;
  max-width: 479px;
  height: 346px;
  content: "";
  z-index: -1
}
.top_price .tit01 i {
  font-size: 7.6rem
}

.top_price_inner {
  position: relative;
  text-align: center;
  margin-top: 50px;
  padding-top: 115px;
  background: url("../images/price_bg_top.png") top 13px center no-repeat, url("../images/price_bg_bottom.png") bottom center no-repeat;
  background-size: 100%;

  padding-bottom: 12%;
  z-index: 2;
}
.top_price_inner::before {
  position: absolute;
  left: 0;
  top: -13px;
  background: url("../images/white_wave.png") bottom left repeat-x;
  width: 100%;
  height: 60px;
  content: "";
}
.top_price_inner::after {
  position: absolute;
  left: 0;
  bottom: -33px;
  background: url("../images/white_wave.png") bottom left repeat-x;
  width: 100%;
  height: 60px;
  content: "";
  transform: scale(-1, -1)
}

.top_price_tit_cap {
  font-size: 2.4rem;
  letter-spacing: 0;
  font-family: "DS-soyokaze";
  text-align: center;
  position: relative;
  z-index: 1;
  line-height: 1;
}
.top_price_sub_tit {
  display: inline-block;
  font-size: 4.8rem;
  letter-spacing: 0.1em;
  font-family: "DS-soyokaze";
  text-align: center;
  position: relative;
  z-index: 1;
  line-height: 1;
  margin-bottom: 5.4%;
}
.top_price_sub_tit::before {
  position: absolute;
  top: -46px;
  left: -66px;
  right: 0;
  margin: auto;
  background: url("../images/price_sub_tit_bg.png") center no-repeat;
  background-size: 100%;
  width: 287px;
  height: 141px;
  content: "";
  z-index: -1;
}

.top_price_list {
  width: 90%;
  max-width: 891px;
  margin: auto;
  position: relative;
  z-index: 2;
  
}

.top_price_item {
  display: flex;
  font-family: "DS-soyokaze";
  justify-content: space-between;
  background: url("../images/price_item_bg_orange.png") center no-repeat;
  background-size: cover;
  border-radius: 40px;
  height: 152px;
  margin-bottom: 30px;
  padding: 2%;
  border-bottom: solid 10px #f6af0c;
}
.top_price_item_tit {
  font-size: 5.3rem;
  letter-spacing: 0;
  color: #e4a20b;
  text-shadow:2px 2px 0 #fff,-2px 2px 0 #fff,2px -2px 0 #fff,-2px -2px 0 #fff;
  width: 54%;
  padding-top: 1%;
}
.top_price_item_num {
  font-size: 5.0rem;
  width: 45%;
  letter-spacing: 0;
  padding-top: 1%;
  padding-left: 2%;
  background: #fff;
  border-radius: 20px;
   color: #e4a20b;
}

.top_price_item_num span {
  font-size: 2.8rem;
}

.top_price_item_num span i {
  font-size: 2.4rem;
  font-style: normal;
  position: relative;
  left: -10px;
}
.top_price_item:nth-child(2) {
  background-image: url("../images/price_item_bg_green.png");
  border-color: #3fa76c;
}
.top_price_item:nth-child(2) .top_price_item_tit,
.top_price_item:nth-child(2) .top_price_item_num{
  color: #3fa76c;
}
.top_price_item:nth-child(3) {
  background-image: url("../images/price_item_bg_blue.png");
  border-color: #0baad5;
}
.top_price_item:nth-child(3) .top_price_item_tit,
.top_price_item:nth-child(3) .top_price_item_num{
  color: #0baad5;
}
.top_price_text {
  text-align: center;
  color: #595656;
  font-size: 3.2rem;
  letter-spacing: 0.04em;
  font-family: "DS-soyokaze";
  line-height: 1.6;
  margin-bottom: 5%;
  position: relative;
  z-index: 2;
}
.top_price_card_list {
  display: flex;
  justify-content: center;
  width: 90%;
  max-width: 888px;
  margin: auto;
  padding: 1.8%;
  background: #fff;
  border-radius: 40px;
  gap: 0 3.3%;
  position: relative;
  z-index: 2;
}
.top_price_bg_kazari {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.top_price_bg_kazari::before {
  position: absolute;
  left: 0;
  top: 10%;
  background: url("../images/price_ill_left.png") top left no-repeat;
  background-size: 100%;
  width: 21%;
  max-width: 471px;
  height: 988px;
  content: "";
  z-index: -1;
}
.top_price_bg_kazari::after{
  position: absolute;
  right: 0;
  top: 10%;
  background: url("../images/price_ill_right.png") top left  no-repeat;
  background-size: 100%;
  width: 21%;
  max-width: 313px;
  height: 1157px;
  content: "";
   z-index: -1;
}
/*==================================================================================================================

  PCブレイクポイント

==================================================================================================================*/

@media screen and (min-width:1920px) {
  .mainvisual_catch{
    margin-top: 530px;
  }
  .mv_catch_title {
    bottom: -40px;
  }
}
@media screen and (max-width:1830px) {
  .mainvisual_catch{
    margin-top: 25vw;
  }

}
@media screen and (max-width:1750px) {
  .mainvisual_catch{
    margin-top:22vw;
  }

}
@media screen and (max-width:1600px) {
  .nav_wrap{
    top: 890px;
  }
  .mainvisual_catch{
    margin-top:365px;
  }
}
@media screen and (max-width:1200px) {
  .top_orth_item:nth-child(even)::before {
    right: -5%;
    width: 24%;
  }
  .top_orth_item:nth-child(odd)::before {
    left: -5%;
    width: 24%;
  }
  .top_merit_item:nth-child(4)::before {
    left: -150px !important;
  }
  
  .top_support_item:nth-child(1)::before {
   left: -36%;
  }
  .top_support_item:nth-child(4)::before {
   right: -54%;
  }
}

/*==================================================================================================================

  スマホ

==================================================================================================================*/
@media screen and (max-width:640px) {
  #wrapper, html, body{
    min-height:500px;
  }

  /*==================================================================

    メインビジュアル（スマホ）

  ==================================================================*/
  .mainvisual_inner {
    width: 100%;
    overflow: hidden;
  }
  .mainvisual_img {
    height:310px;
    min-height: 310px;
  }
  .mainvisual_img img {
    min-height: 310px;
  }
  .mainvisual_catch {
    margin-top:0;
    position: absolute;
    bottom: 34vw;
    left: 0;
    right:0;
    margin: auto;
    width: 40%;
  }
  .mainvisual_catch::before {
    width: 20%;
    background-size: 100%;
    top: -70px;
  }
  .mv_catch_title {
    bottom: -39px;
    width: 103%;
    max-width: 444px;
    left: -10px;
  }
  .mv_catch_list {
    
    width: 130%;
    flex-wrap: nowrap;
    justify-content: center;
    position: absolute;
    bottom: 40px;
    margin-left: -4%;
  }
  .mv_catch_item {
    width: 24%;
        font-size: 2.5vw;
        line-height: 1.3;
        height: 19vw;
        letter-spacing: -0.12em;
        padding-top: 5px;
  }
  .mv_catch_item::before {
    background-position: top center;
    width: 102%;
    left: -7%;
    top: -10px;
  }
  .mv_catch_item:first-child, .mv_catch_item:last-child {
    margin-top: 0;
  }
  .mv_catch_item:nth-child(1) {
    top: 46px;
    left: 1%;
    z-index: 3;
  }
  .mv_catch_item:nth-child(2) {
    z-index: 2;
    left: -9%
  }
  .mv_catch_item:nth-child(2)::before {
    left: -2%
  }
  .mv_catch_item:nth-child(3) {
    left: -10%
  }
  .mv_catch_item:nth-child(4) {
    top: 40px;
    right: 18%;
  }
  .mv_catch_item:nth-child(4)::before {
    left: -1%
  }

  /*==================================================================

    .タイトル（スマホ）

  ==================================================================*/
  .tit01 {
    font-size:2.8rem;
    letter-spacing: -0.1em !important;
    width: 95% !important;
    
    
  }
  .tit01 i {
    font-size: 4rem;
    top: 3px;
  }
  .tit01 span {
    font-size: 2.2rem;
    letter-spacing: 0.05em;
  }
  .tit01 span::before {
    width: 85%;
    margin: auto;
  }
  .tit01_en {
    font-size: 5rem;
    margin-top: -28px;
    margin-bottom: 10px;
    line-height: 0.9
  }
  /*==================================================================

    .top_problem（スマホ）

  ==================================================================*/
  .top_problem .tit01::before {
    width: 50%;
    max-width: 100%;
    right: -15%;
    top: -85px;
  }
  .top_problem_list {
    display: block;
    padding: 25px 20px 20px 25px;
    z-index: 2
  }
  .top_problem_list::after {
    left: -14%;
    top: -238px;
    z-index: -1;
  }
  .top_problem_item {
    width: 100%;
    font-size: 2rem;
    letter-spacing: -0.03em;
    padding-left: 33px;
    line-height: 1.3;
    margin-bottom: 14px;
  }
  .top_problem_item::before {
    width: 25px;
    height: 25px;
  }
  .top_problem_item.item_line2   {
    top: 0;
  }
  .top_problem .inner01 {
    padding-bottom: 100px;
  }
  .top_problem_kazari01::before{
    bottom: -180px;
    left: -5%;
    width: 45%;
    background-size: 100%;
  }
  .top_problem_kazari01::after{
    bottom: -199px;
    right: -5%;
    width: 45%;
    background-size: 100%;
  }
  .top_problem .inner02 {
    padding-bottom: 80px;
  }
 .top_problem .inner02::after {
    background-size: cover;
    top: auto;
    bottom: -20px;
    height: 195px;
  }  

  .top_problem .inner02 .box1 {
    display: block;
    z-index: 1;
    margin-top: 40px;
  }
  .top_problem .inner02 .box1 > li {
    width: 100%
  }
  .top_problem .inner02 .box1::after {
    top: -200px;
    background-size: 100%;
    z-index: -1;
  }
  .top_problem .inner02 .box1::before {
    bottom: -100px;
    background-size: 100%;
    z-index: -1;
  }
  
  .top_problem_child_list {
    min-height: auto;
    padding: 25px 20px 20px 25px;
  }
  .top_problem_list02 {
    margin-bottom: 70px;
  }
  .top_problem_list02 .top_problem_item {
    line-height: 1.3;
    margin-bottom: 15px;
  }
  .top_problem_list02 .top_problem_item br {
     display: none
  }
  .top_problem_item.item_no_check {
    right: 22px;
  }
  .top_problem_table_list {
    width: 94%;
  }
  .top_problem_table_list_wrapper {
    padding-top: 0;
    padding-bottom: 70px;
  }
  .top_problem_table_list_wrapper::before {
    left: -5%;
      width: 27%;
  }
  .top_problem_table_list_wrapper::after {
    right: -5%;
    top: 23%;
    width: 27%;
  }
  
  .top_problem_table_list {
    display: block;
  }
  .top_problem_table_item {
    width: 100% !important;
    margin-bottom: 50px;
    
  }
  .top_problem_table_item:nth-child(3) {
  position: relative;
  left: -4%
  }
  .top_problem_table_item:last-child {
    position: relative;
    right: -6%;
  }
  .top_orth_item_img {
    width: 70%;
    margin: auto !important;
  }
  .top_orth_item_detail {
    width: 95% !important;
    padding-top: 20px;
  }
  .top_orth_item_detail::before {
    top:0;
    left: -6%;
    width: 114% !important;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 60px;
    border-bottom-right-radius:  60px;
     height: 100%;
  }
  .top_orth_item:nth-child(odd)::before,
  .top_orth_item:nth-child(even)::before{
    width: 43%
  }
  .top_orth_item:nth-child(even) .top_orth_item_detail::before {
    right: -6%;
    width: 114% !important;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 60px;
    border-bottom-left-radius: 60px;
    height: 100%
  }
   .top_orth_item:nth-child(even) .top_orth_item_detail {
     margin-left: auto;
   }
   .top_orth_item:nth-child(2) .top_orth_item_tit {
     height: 1.5em;
   }
  .top_orth_item_tit {
    font-size: 3.6rem;
    letter-spacing: 0em;
    display: inline-block
  }
  .top_orth_item_text {
    font-size: 1.9rem;
    letter-spacing: -0.08em;
    line-height: 1.6;
    padding-bottom: 40px;
  }
  
  
  
  
  /*==================================================================

    .top_orth（スマホ）

  ==================================================================*/
  .top_orth {
    padding-top: 30px;
    padding-bottom: 110px;
  }
  .top_orth .tit01_en {
    font-size: 4rem;
  }
  .top_orth_sub_tit {
    margin-bottom: 40px;
  }
  .top_orth::before {
    background-size: 130%
  }
  .top_orth_item {
    display: block;
  }
  
  
  /*==================================================================

    .top_merit（スマホ）

  ==================================================================*/
  .top_merit {
    padding-top: 17px;
  }
  .top_merit::before {
    top: -63px;
    background-size: 120%;
  }
  .top_merit .tit01::after {
    top: -119px;
  }
  .top_merit .tit01::before {
    top: -100px
  }
  .top_merit .tit01 {
    margin-bottom: 70px;
  }
  .top_merit_tit_ja::after {
    top: -114px;
    width: 120%;
    max-width: 130%;
    left: -10%;
    background-size: 100%
  }
  .tit01 span.top_merit_tit01 {
    font-size: 3rem;
  }
  .tit01 span.top_merit_tit01 i {
    font-size: 3.7rem;
  }
  .top_merit_tit_ja::before {
    background-size: 100%;
    width: 54%;
    letter-spacing: 0.1em;
  }
  .top_merit_list {
    display: block;
  }
  .top_merit_item {
    width: 100%;
    margin-bottom: 50px;
    margin-top: 0 !important;
  }
  .top_merit_item img {
    width: 90%;
    margin: auto;
    min-width: 100%
  }
  .top_merit_item_tit {
    font-size: 2.6rem;
    margin-top: 16px;
    margin-bottom: 15px;
   letter-spacing:  0.03em;
  }
  .top_merit_item_text {
    line-height: 1.9;
    font-size: 1.5rem;
    padding: 24px 20px;
    height: auto;
  }

  .top_merit_item:nth-child(5) .top_merit_item_tit {
    font-size: 2.4rem
  }
  .top_merit_item:nth-child(5) .top_merit_item_tit span {
    left: 0;
  }
  
  
  
  
  
  /*==================================================================

    . top_cv（スマホ）

  ==================================================================*/
   .top_cv {
     padding-top: 40px;
     z-index: 1;
     padding-bottom: 140px;
    background-size: 130%
   }
   .top_cv::before {
     width: 35%;
     left: 0
   }
  .top_cv::after {
     width: 35%;
   }
  .top_cv .box1 {
    display: block;
    padding-top: 10px;
    overflow: hidden;
  }
  
  .top_cv_kazari {
    bottom: -84px;
  }
  .top_cv_detail {
    width: 100%;
    padding: 20px 14px;
    position: relative;
    z-index: 2;
  }
  .top_cv_img {
    width: 90%;
    display: block;
    margin: -55px auto 0;
    position: relative;
    z-index: 1;
    height: 240px;

  }
  .top_cv_img::before {
    width: 26%;
    top: auto;
    bottom: -9px;
    left: -15%;
    background-position: bottom center;
    transform: rotate(-45deg)
  }
  .top_cv_tit {
    margin-bottom: 20px;
  }
  .top_cv_btn a:hover {
    opacity: 1;
  }
  
  
  .top_cv.item_02 {
    padding-bottom: 65px;

  }
  /*==================================================================

    . top_support（スマホ）

  ==================================================================*/
  .top_support {
    padding-bottom: 0px;
    margin-top: 0;
  }
  .top_support::after {
    top: 40px;
    height: calc(100% - 40px);
    background-size: 200%
  }
  .top_support::before {
    background-size: 165%
  }
  .top_support_tit {
    width: 124%;
    padding: 0;
    position: relative;
    left: -12%
  }
  .top_support_tit ::after {
    bottom: -52%;
  }
  .top_support_tit ::before {
    bottom: -51%
  }
  .top_support_list {
    width: 93%;
    padding-bottom: 110px;
  }
  .top_support_item {
   margin-bottom: 50px;
  }
  .top_support_item:nth-child(2n) {
    margin-top: 0;
  }
  .top_support_item:nth-child(1)::before {
    width: 40%;
    left: -20%;
  }
  .top_support_item_detail {
    width: 100%;
    margin: auto;
    min-height:49vw;
  }
  .top_support_item_detail::before {
    background-size: 100%;
  }
  .top_support_item_tit {
    font-size: 2rem;
  }
  
  .top_support_item_text {
    font-size: 1.8rem;
  }
  
  
  /*==================================================================

    .  top_flow（スマホ）

  ==================================================================*/
  .top_flow {
    padding-bottom: 80px;
  }
  .top_flow::before {
    background-size: 200%;
    top: 107px;
    z-index: 2;
    height: calc(100% - 87px)
  }
  .top_flow::after {
    background-size: 166%;
    top:88px;
  
}
  .top_flow_tit {
    width: 70%;
    margin: auto;
    position: relative;
    z-index: 3;
    margin-top: -100px;
  }
  .top_flow_list {
    width: 80%;
    margin: auto;
    position: relative;
    z-index: 3
  }
  .top_flow_item {
    width: 100%;
    left: 0 !important
    
  }
  .top_flow_item_text {
    font-size: 2.7rem;
    bottom: 13%;
  }
  .top_flow_item:not(:last-child)::before {
    transform: rotate(90deg);
     right: 3%;
    top: 104%;
    width: 37px;
    background-size: 100%;
  }
  .top_flow_btn_list {
    margin-top: 20px;
  }
  
  .top_flow_item_text span.item_small02 {
    font-size: 1.8rem;
    display: block;
    padding-top: 10px;
  }
  .top_flow_item:nth-child(6) .top_flow_item_text {
    margin-bottom: -2%;
  }
  .top_flow_item_text span.item_small01 {
    font-size: 2.2rem;
  }
  
  
  /*==================================================================

    .  top_price（スマホ）

  ==================================================================*/
  .top_price {
  padding-top: 30px;
  }
  .top_price::before {
    background-size: 120%;
    top: -45px;
  }
  .top_price .tit01::after {
    background-position: bottom right;
    top: -140px;
  }
  .top_price .tit01:before {
    background-position: bottom left;
    top: -120px;
  }
  .top_price .tit01 {  
    width: 100% !important;
    z-index: 3;
  }
  .top_price .tit01 i {
    font-size: 5.4rem;
    padding-top: 10px;
    display: block;
  }
  .top_price .tit01_en {
    font-size: 4.2rem;
    margin-top: -45px;
  }
  .top_price .tit01_en::before {
    display: none;
  }
  .top_price_tit_cap {
    font-size: 2rem;
    margin-top: 5px;
    position: relative;
    z-index: 3;
  }
  .top_price_inner {
    margin-top: 20px;
  }
  .top_price_inner::before {
    background-size: 200%;
    top: -33px;
  }
  .top_price_sub_tit {
    font-size: 3.8rem;
  }
  .top_price_item {
    display: block;
  }
  .top_price_item_tit {
    width: 100%;
    font-size: 3rem;
  }
  .top_price_item_num {
    width: 90%;
    margin: auto;
    font-size: 2.8rem;
  }
  
  .top_price_text {
    font-size: 1.9rem;
  }
  .top_price_bg_kazari::before{
    width: 28%;
    opacity: 0.7;
  }
  .top_price_bg_kazari::after {
    width: 28%;
    opacity: 0.7;
  }
  .top_price_card_list {
    flex-wrap: wrap;
    gap: 0 5%;
    width: 90%;
    margin: auto;
    padding: 30px;
    margin-bottom: 20px;
  }
   .top_price_card_item {
     width: 19%;
     margin-bottom: 12px;
   }
  .top_price_inner::after {
    background-size: 200%;
    bottom: -45px;
  }
  
  
}
