@charset "UTF-8";

.p-application .m-page-mv {
  background: url("../../../images/page/application/bg_fv_pc.png")no-repeat;
  background-size: cover;
  background-position: center;
}

.p-application .p-ttl span {
  width: 141px;
}

.p-sec01 {
    padding: 130px 0 170px;
    background: url("../../../images/page/application/bg_ptn_pc.png")no-repeat;
    background-size: 700px;
    background-position: left top;
}

.p-sec01 .heading {
  font-size: 3.6rem;
  letter-spacing: 0.05em;
  font-weight: 600;
  padding: 0 0 25px;
}

.p-sec01 .block + .block {
  padding-top: 100px;
}

.p-sec02 {
  padding: 20px 0 0;
}

.p-sec02 .inner {
  max-width: 1070px;
  margin: 0 auto;
  padding: 0 30px;
  position: relative;
}

.p-sec02 .heading {
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: 0.05em;
}

.p-sec02 .heading span {
  display: inline-block;
  padding: 0 0 15px;
  position: relative;
}

.p-sec02 .heading span::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 3px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background:  #0075C2;
}

.p-sec02 .graph {
  margin: 0 0 140px;
}

.p-slider .box img {
  width: 100%;
}

.p-sec03 {
  padding: 130px 0 150px;
}

.p-sec03 .graph {
  margin: 0 0 50px;
}

.p-sec03 .heading {
  font-size: 2.8rem;
  font-weight: 600;
  letter-spacing: 0.05em;
}


@media screen and (min-width: 768px) {

  .p-sec02 .heading {
    position: absolute;
    z-index: 1;
    top: 50px;
    left: 30px;
  }

  .p-sec03 .inner {
    display: flex;
    justify-content: space-between;
  }

  .p-sec03 .m-lead {
    width: 50%;
  }

  .p-sec03 .heading {
    width: 45%;
  }



}

@media screen and (max-width: 767px){
  .p-application .m-page-mv {
    background: url("../../../images/page/application/bg_fv_sp.png")no-repeat;
    background-size: cover;
    background-position: center;
  }

  .p-application .p-ttl span {
    width: 85px;
  }


  .p-sec01 {
    padding: 65px 0 100px;
    background: url("../../../images/page/application/bg_ptn_sp.png")no-repeat;
    background-size: 150px;
    background-position: left top;
  }

  .p-sec01 .heading {
    font-size: 2.2rem;
    letter-spacing: 0.05em;
    font-weight: 600;
    padding: 0 0 15px;
  }

  .p-sec01 .block + .block {
    padding-top: 50px;
  }

  .p-sec02 {
    padding: 50px 0 0;
  }

  .p-sec02 .heading {
    text-align: center;
    font-size: 1.5rem;
    margin: 0 0 35px;
  }

  .p-sec02 .heading span::before {
    width: 15px;
  }

  .p-sec02 .inner {
    padding: 0;
  }


  .p-sec02 .graph {
    margin: 0 0 60px;
  }

  .p-sec02 .graph img {
    width: 100%;
  }

  .p-sec03 {
    padding: 60px 0 70px;
  }

  .p-sec03 .graph {
    margin: 0 0 30px;
  }

  .p-sec03 .heading {
    font-size: 1.8rem;
    padding: 0 0 20px;
  }


}
