
#purposeWrap li:not(:last-child) {
  margin-bottom: 40px;
}

#purposeWrap .purposeBox.textBox .purposeBoxIn h1{
  color:#f8b62d;
  font-weight:bold;
  font-size: 8.5vw;
  line-height: 100%;
}

#purposeWrap .purposeBox.textBox .purposeBoxIn p {
  font-size: 1.30vw;
}

#purposeWrap .purposeBox.imgBox .purposeBoxIn .purposeBoxImg {
  width: 100%;
  padding-top: 40%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 30px;
}

#topTieupWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -15px;
}

#topTieupWrap::after {
  content: "";
  display:block;
  width:30%; /* 子要素と同じ幅 */
}

#topTieupWrap .topTieupBox {
  text-align: center;
  width: 30%;
  margin-bottom: 20px;
}

#topTieupWrap .topTieupBox .topTieupBoxIn {
  background-color: #ffffff;
  border-radius: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 10px;
}

#topTieupWrap .topTieupBox .topTieupBoxIn .topTieupBoxLogo {
  width: 98%;
  border-radius: 20%;
}

#topStrengthWrap {
  margin-bottom: 80px;
}

#topStrengthWrap li {
  background-color: #ffffff;
  border-radius: 15px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding: 3% 2%;
  box-shadow: 3px 3px 3px 3px rgba(0, 0, 0, 0.2);
}

#topStrengthWrap li:not(:last-child) {
  margin-bottom: 30px;
}

#topStrengthWrap .topStrengthBox.textBox {
  width: 60%;
  display: flex;
  flex-flow: column;
  justify-content: center;
}

#topStrengthWrap .topStrengthBox.imgBox {
  width: 38%;
}

#topStrengthWrap li .topStrengthBox.imgBox .topStrengthBoxIn .topStrengthBoxImg {
  width: 100%;
  padding-top: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 20%;
}

#topStrengthWage {
  margin-bottom: 80px;
}

#topStrengthWage h3 {
 font-size: 2.6vw;
 font-weight: 600;
 letter-spacing: 0.25em;
}

#topStrengthWage h4.yLine {
  font-size: 2.9vw;
  line-height: 100%;
  margin-top: 3%;
  margin-bottom: 3%;
  letter-spacing: 0.2em;
  display: inline-block;
  position: relative;
  padding: 0 2.5%;
}

#topStrengthWage h4.yLine:before {
  position: absolute;
  content: "";
  background-color: #ffff00;
  width: 100%;
  height: 42%;
  left: 0%;
  bottom: 10%;
  z-index: -1;
}

#topStrengthWage h4.yLine span.amount {
  color: #f8b62d;
  font-size: 1.9em;
  letter-spacing: 0.4em;
}

#topStrengthWage p {
 font-size: 1.55vw;
}

#topStrengthLabels > .areaWrap .topStrengthLabelsBox.svgSP {
  display: none;
}

@media screen and (min-width: 870px) {

  #view .btCircle:before {
    top: 40px;
  }

  #purposeWrap li {
    display: flex;
    justify-content: space-between;
  }

  #purposeWrap li:nth-child(2) {
    flex-direction: row-reverse;
  }

  #purposeWrap .purposeBox.textBox {
    width: 35%;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn {
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    height: 100%;
  }

  #purposeWrap .purposeBox.imgBox {
    width: 60%;
  }

  #topTieupWrap .topTieupBox p {
    font-size: 1.6vw;
  }

  #topTieupWrap .topTieupBox:nth-last-child(1),
  #topTieupWrap .topTieupBox:nth-last-child(2):nth-child(3n+1),
  #topTieupWrap .topTieupBox:nth-last-child(2):nth-child(3n+2),
  #topTieupWrap .topTieupBox:nth-last-child(3):nth-child(3n+1){
    margin-bottom: 0;
  }

  #topStrengthWrap li {
    flex-direction: row-reverse; /* タブレット以下で縦に並べるため */
  }

  #topStrengthWage h4.yLine span.amount {
    vertical-align: super;
  }
  
  #topStrengthWage h4.yLine span.perDay {
    vertical-align: top;
  }

  #topStrengthWrap .topStrengthBox.textBox .topStrengthBoxIn p{
    font-size: 1.65vw;
  }

  #topStrengthLabels > .areaWrap {
    display: flex;
    justify-content: space-around;
   }
   
   #topStrengthLabels > .areaWrap div {
    width: 45%;
    height: 40vw;
    display: flex;
    justify-content: center;
   }
   
}

@media screen and (min-width: 1382px) {

  #purposeWrap .purposeBox.textBox .purposeBoxIn h1{
    font-size: 8.6vw;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn p{
    font-size: 1.4vw;
  }

  #topTieupWrap .topTieupBox p {
    font-size: 1.4vw;
  }

  #topStrengthWrap .topStrengthBox.textBox .topStrengthBoxIn h3{
    font-size: 2.1vw;
    font-weight: 700;
  }

  #topStrengthWrap .topStrengthBox.textBox .topStrengthBoxIn p{
    font-size: 1.25vw;
  }

  #topStrengthWage h4.yLine {
    margin-top: 1.5%;
  } 

}

@media screen and (max-width: 870px) {

  #view #viewBox #viewTitle {
    font-size: 5.5vw;
    line-height: 125%;
  }

  #view #viewBottom {
    font-size: 4.5vw;
  }

  .secTitleWrap .secTitle {
    align-items: baseline;  /* マークと見出しの高さ合わせ */
  }

  .secTitleWrap .secTitle .secTitleText {
    font-size: 4.3vw;
  }
  .secTitleWrap .secTitleCopy {
    font-size: 2.9vw;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn {
    display: flex;
    margin-bottom: 10px;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn h1{
    font-size: 11.5vw;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn p{
    font-size: 3.0vw;
    margin-left: 5%;
  }

  #topTieupWrap .topTieupBox {
    width: 48%;
  }

  #topTieupWrap .topTieupBox p {
    font-size: 2.5vw;
  }

  #topStrengthWrap li {
    flex-flow: column;
    align-items: center;
  }

  #topStrengthWrap li .topStrengthBox.textBox .topStrengthBoxIn h3 {
    text-align: center;
    font-size: 4.0vw;
  }

  #topStrengthWrap li .topStrengthBox.textBox .topStrengthBoxIn p br,#topStrengthWage p br {
    display: none;
  }

  #topStrengthWrap .topStrengthBox.textBox {
    width: 80%;
  }
  
  #topStrengthWrap .topStrengthBox.textBox p {
   font-size: 3.1vw;
  }

  #topStrengthWrap .topStrengthBox.imgBox {
    width: 80%;
  }

  #topStrengthWrap li .topStrengthBox.imgBox .topStrengthBoxIn .topStrengthBoxImg {
    margin-top: 2%;
   margin-bottom: 2%; 
  }

  #topStrengthWage {
    margin: 0 auto 80px;
  }

  #topStrengthWage h3 {
    font-size: 4.5vw;
    letter-spacing: 0.2em;
  }

  #topStrengthWage h4.yLine {
    padding: 0 3.5%;
    font-size: 4.0vw;
  }

  #topStrengthWage h4.yLine span.amount {
    font-size: 2.35em;
    letter-spacing: 0.2em;
    vertical-align: super;
  }

  #topStrengthWage h4.yLine span.perDay {
    font-size: 1.35em;
    letter-spacing: 0.3em;
    vertical-align: super;
  }

  #topStrengthWage p {
    text-align: left;
    font-size: 3.3vw;
    width: 72%;
    margin: 0 auto;
  }

   #topStrengthLabels > .areaWrap div {
    width: 100%;
   }
   
   #topStrengthLabels > .areaWrap .topStrengthLabelsBox.svgHP {
    display: none;
  }

  #topStrengthLabels > .areaWrap .topStrengthLabelsBox.svgSP {
    display: block;
  }

}

@media screen and (max-width: 426px) {

  #view #viewBox #viewTitle {
    font-size: 7.5vw;
    line-height: normal;
  }

  #view #viewBottom {
    font-size: 5.5vw;
  }

  .secTitleWrap .secTitle .secTitleText {
    font-size: 6.2vw;
  }
  .secTitleWrap .secTitleCopy {
    font-size: 4.5vw;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn h1 {
    font-size: 16.0vw;
  }

  #purposeWrap .purposeBox.textBox .purposeBoxIn p {
    font-size: 4.5vw;
    margin-left: 5%;
  }

  #topTieupWrap .topTieupBox .topTieupBoxIn {
    border-radius: 30px;
  }

  #topTieupWrap .topTieupBox {
    width: 49%;
  }

  #topTieupWrap .topTieupBox p {
    font-size: 4.5vw;
  }

  #topStrengthWrap {
    margin-bottom: 40px;
  }

  #topStrengthWrap li .topStrengthBox.textBox .topStrengthBoxIn h3 {
    font-size: 6.5vw;
  }

  #topStrengthWrap .topStrengthBox.textBox p {
    font-size: 5.5vw;
  }

  #topStrengthWage {
    width: 95%;
    margin: 0 auto 40px;
  }

  #topStrengthWage h3 {
    font-size: 7.0vw;
    letter-spacing: 0.2em;
  }

  #topStrengthWage h4.yLine {
    padding: 0 1.5%;
    font-size: 10.0vw;
  }

  #topStrengthWage h4.yLine span.amount {
    font-size: 1.05em;
    letter-spacing: 0.2em;
  }

  #topStrengthWage h4.yLine span.perDay {
    font-size: 1.05em;
    letter-spacing: 0.2em;
  }

  #topStrengthWage p {
    text-align: left;
    font-size: 5.0vw;
    font-weight: bold;
    width: 80%;
  }

}