@charset "UTF-8";
.top-mv {
  position: relative;
  background: #F7F7F7;
  overflow: hidden;
}
.top-mv .top-left__bg {
  position: relative;
  margin-top: 5vw;
  left: -7vw;
  transform: translate(-30vw, 30vw);
  /* 左下にオフセット */
  animation: fadeInMove 1.5s ease-out forwards;
  opacity: 0;
}
@media (max-width: 979px) {
  .top-mv .top-left__bg {
    margin-top: 45vw;
  }
}
.top-mv .top-left__bg img {
  width: 55vw;
}
@media (max-width: 979px) {
  .top-mv .top-left__bg img {
    width: 80vw;
  }
}
.top-mv .top-right__bg {
  position: absolute;
  right: -7vw;
  top: -11vw;
  transform: translate(-10vw, 10vw);
  /* 左下にオフセット */
  animation: fadeInMove 1.5s ease-out forwards;
  animation-delay: 1s;
  opacity: 0;
}
@media (max-width: 979px) {
  .top-mv .top-right__bg {
    right: -20vw;
  }
}
.top-mv .top-right__bg img {
  width: 45vw;
}
@media (max-width: 979px) {
  .top-mv .top-right__bg img {
    width: 80vw;
  }
}
.top-mv .top-mv__text img {
  position: absolute;
  left: 50%;
  top: 50vh;
  transform: translate(-50%, -50%);
  width: 800px;
  z-index: 2;
  animation: slideUp 2s ease-out forwards;
  animation-delay: 2s;
  opacity: 0;
}
@media (max-width: 979px) {
  .top-mv .top-mv__text img {
    width: 80vw;
  }
}
.top-mv .top-mv__image img {
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -30vw;
  width: 60vw;
  transform: translate(-10vw, 10vw);
  /* 左下にオフセット */
  animation: fadeInMove 1.5s ease-out forwards;
  animation-delay: 1.5s;
  opacity: 0;
}
@media (max-width: 979px) {
  .top-mv .top-mv__image img {
    width: 120vw;
    margin-left: -60vw;
    max-width: inherit;
    top: 10vw;
  }
}

@keyframes fadeInMove {
  to {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@keyframes slideUp {
  to {
    opacity: 1;
  }
}
.s01 {
  background: #F7F7F7;
  padding: 90px 0 220px;
  position: relative;
}
@media (max-width: 979px) {
  .s01 {
    padding: 60px 0 130px;
  }
}
.s01 .img-area {
  text-align: center;
  position: relative;
  max-width: 1160px;
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 979px) {
  .s01 .img-area {
    padding: 0 20px;
  }
}
.s01 .img-area img {
  max-width: 1160px;
  width: 100%;
}
@media (max-width: 850px) {
  .s01 .img-area img {
    padding: 0 25px;
  }
}
@media (max-width: 850px) {
  .s01 .img-area:before {
    display: block;
    content: "";
    background: url(../images/bg03.png) left top no-repeat;
    background-size: 100%;
    width: 100%;
    height: 10vw;
    max-width: 800px;
    margin: 0 auto;
  }
}
.s01 .img-area .icon01 img {
  position: absolute;
  left: 140px;
  top: 200px;
  width: 66px;
}
.s01 .img-area .icon02 img {
  position: absolute;
  right: 140px;
  top: 200px;
  width: 66px;
}
@media (max-width: 850px) {
  .s01 .img-area .icon01,.s01 .img-area .icon02 {
    display: none;
  }
}
.s01 .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: -20px;
  line-height: 1;
}
@media (max-width: 979px) {
  .s01 .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}
@media (max-width: 979px) {
  .s01 .item-box-list {
    padding: 0 20px;
  }
}
@media (max-width: 850px) {
  .s01 .item-box-list:after {
    display: block;
    content: "";
    background: url(../images/bg04.png) left top no-repeat;
    background-size: 100%;
    width: 100%;
    height: 10vw;
    max-width: 800px;
    margin: 0 auto;
  }
}
.s01 .item-box-list dl {
  margin-top: 70px;
}
.s01 .item-box-list dl dt {
  text-align: center;
  font-weight: 800;
  font-size: 2.4rem;
  color: #6EDCD7;
  margin: 0 0 20px;
}
.s01 .item-box-list dl dt.pt02 {
  color: #FF96A7;
}
.s01 .item-box-list dl dd {
  font-size: 1.6rem;
  padding: 0 20px;
}
.s01 .item-box-list .icon {
  text-align: center;
  margin-top: 35px;
}
.s01 .item-box-list .icon img {
  max-width: 80px;
}
@media (max-width: 979px) {
  .s01 .item-box-list .icon {
    display: none;
  }
}

.s02 {
  background: url(../images/bg01.png) left center no-repeat #E9FAF9;
  background-size: 100%;
  padding: 90px 0 0;
  position: relative;
}
@media (max-width: 979px) {
  .s02 {
    padding: 70px 0 0;
  }
}
.s02 .ttl {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  flex-wrap: nowrap;
  font-size: 4rem;
  font-weight: 800;
  color: #6EDCD7;
}
@media (max-width: 979px) {
  .s02 .ttl {
    display: block;
    font-size: 3.2rem;
    text-align: center;
    margin: 0 0 35px;
  }
}
.s02 .ttl span {
  font-size: 1.6rem;
  color: #4B4B4B;
  font-weight: 700;
  margin-left: 30px;
}
@media (max-width: 979px) {
  .s02 .ttl span {
    font-size: 1.8rem;
    margin: 0;
    display: block;
    line-height: 1;
  }
}
.s02 .ex {
  font-size: 1.6rem;
  margin-bottom: 60px;
}
.s02 .c-faq-list {
  /* max-width: 660px; */
  margin: 0 auto;
}
@media (max-width: 979px) {
  .s02 .c-faq-list {
    /* max-width: 390px; */
    margin: 0 auto;
  }
}
.s02 .c-faq-list dl {
  background: url(../images/acc_bg.png) left top no-repeat;
  background-size: 980px;
  padding: 39px 0 0 55px;
  margin: 0 0 20px -15px;
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl {
    background: url(../images/acc_bg01_sp.png) left top no-repeat;
    background-size: 100%;
    padding: 39px 0 0 30px;
  }
}
.s02 .c-faq-list dl dt {
  background: url(../images/arrow_down.svg) right 11px top 50px no-repeat;
  background-size: 16px auto;
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl dt {
    padding-right: 50px;
    font-size: 1.4rem;
  }
}
.s02 .c-faq-list dl dt.active {
  background: url(../images/arrow_up.svg) right 11px top 50px no-repeat;
  background-size: 16px auto;
}
.s02 .c-faq-list dl dt a {
  display: block;
}
.s02 .c-faq-list dl dt span {
  display: block;
  color: #6EDCD7;
  font-size: 2.0rem;
  font-weight: 800;
  margin-bottom: 7px;
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl dt span {
    font-size: 1.8rem;
  }
}
.s02 .c-faq-list dl dd {
  padding: 20px 0 0;
  display: none;
}
.s02 .c-faq-list dl dd .in {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.s02 .c-faq-list dl dd .in .left {
  width: 180px;
  padding: 0 40px;
  text-align: center;
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl dd .in .left {
    width: 130px;
    padding: 0 20px 0 0;
  }
}
.s02 .c-faq-list dl dd .in .left img {
  max-width: 80px;
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl dd .in .left img {
    max-width: 70px;
  }
}
.s02 .c-faq-list dl dd .in .right {
  width: calc(100% - 180px);
}
@media (max-width: 979px) {
  .s02 .c-faq-list dl dd .in .right {
    width: calc(100% - 130px);
    font-size: 1.4rem;
  }
}
.s02 .digital {
  padding: 0 0 200px;
  position: relative;
}
@media (max-width: 979px) {
  .s02 .digital {
    padding: 0 0 120px;
  }
}
.s02 .digital .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: 0;
  line-height: 1;
  text-align: right;
  width: 100%;
}
@media (max-width: 979px) {
  .s02 .digital .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}
.s02 .data {
  padding: 140px 0 100px;
  position: relative;
}
@media (max-width: 979px) {
  .s02 .data {
    padding: 60px 0 150px;
  }
}
.s02 .data .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: -20px;
  line-height: 1;
  text-align: left;
  width: 100%;
}
@media (max-width: 979px) {
  .s02 .data .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}

.s03 {
  padding: 90px 0 0;
  background: url(../images/bg02.png) right center no-repeat #FFF4F6;
  background-size: 100%;
}
@media (max-width: 979px) {
  .s03 {
    padding: 70px 0 0;
  }
}
.s03 .ttl {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  flex-wrap: nowrap;
  font-size: 4rem;
  font-weight: 800;
  color: #FF96A7;
}
@media (max-width: 979px) {
  .s03 .ttl {
    display: block;
    font-size: 3.2rem;
    text-align: center;
    margin: 0 0 35px;
  }
}
.s03 .ttl span {
  font-size: 1.6rem;
  color: #4B4B4B;
  font-weight: 700;
  margin-left: 30px;
}
@media (max-width: 979px) {
  .s03 .ttl span {
    font-size: 1.8rem;
    margin: 0;
    display: block;
    line-height: 1;
  }
}
.s03 .ex {
  font-size: 1.6rem;
}
.s03 .img-area {
  margin: 50px 0;
  text-align: center;
}
.s03 .img-area img {
  max-width: 800px;
  width: 100%;
}
.s03 .joshisu {
  padding: 0 0 170px;
  position: relative;
}
@media (max-width: 979px) {
  .s03 .joshisu {
    padding: 0 0 80px;
  }
}
.s03 .joshisu .item-list dl {
  margin: 0 0 25px;
}
.s03 .joshisu .item-list dl dt {
  font-size: 1.8rem;
  color: #00505A;
  font-weight: 700;
  margin: 0 0 10px;
}
@media (max-width: 979px) {
  .s03 .joshisu .item-list dl dt {
    font-size: 1.8rem;
  }
}
.s03 .joshisu .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: 0;
  line-height: 1;
  text-align: left;
  width: 100%;
}
@media (max-width: 979px) {
  .s03 .joshisu .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}
.s03 .support {
  padding: 130px 0 100px;
  position: relative;
}
@media (max-width: 979px) {
  .s03 .support {
    padding: 70px 0 100px;
  }
}
.s03 .support .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: -20px;
  line-height: 1;
  text-align: right;
  width: 100%;
}
@media (max-width: 979px) {
  .s03 .support .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}
.s03 .support .support-box {
  margin-bottom: 70px;
}
.s03 .support .support-box:last-child {
  margin-bottom: 0;
}
.s03 .support .support-box .sub-ttl {
  text-align: center;
  font-size: 3.4rem;
  color: #00505A;
  font-weight: 800;
  margin-bottom: 25px;
}
@media (max-width: 979px) {
  .s03 .support .support-box .sub-ttl {
  text-align: center;
  font-size: 2rem;
  color: #00505A;
  font-weight: 800;
  margin-bottom: 25px;
}
}
.s03 .support .support-box .step-list dl {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  flex-wrap: nowrap;
  margin-bottom: 30px;
}
@media (max-width: 979px) {
  .s03 .support .support-box .step-list dl {
    display: block;
    margin-bottom: 45px;
    max-width: 270px;
    margin: 0 auto 45px;
    position: relative;
  }
}
.s03 .support .support-box .step-list dl dt {
  width: 204px;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  background: #00505A;
  padding: 4px 0;
  position: relative;
}
@media (max-width: 979px) {
  .s03 .support .support-box .step-list dl dt {
    width: 100%;
    font-size: 2rem;
    margin: 0 0 15px;
    position: static;
  }
}
.s03 .support .support-box .step-list dl dt:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 7px solid transparent;
  border-left: 7px solid transparent;
  border-top: 15px solid #00505A;
  border-bottom: 0;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  position: absolute;
}
@media (max-width: 979px) {
  .s03 .support .support-box .step-list dl dt:after {
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 15px solid #00505A;
    margin-top: 10px;
  }
}
.s03 .support .support-box .step-list dl dd {
  padding-left: 45px;
}
@media (max-width: 979px) {
  .s03 .support .support-box .step-list dl dd {
    padding: 0;
    text-align: center;
  }
}
.s03 .support .support-box .step-list dl:last-child dt:after {
  display: none;
}
@media (max-width: 979px) {
  .s03 .support .support-box .plan-list {
    max-width: 270px;
    margin: 0 auto 45px;
  }
}

.s04 {
  background: #F7F7F7;
  padding: 90px 0 150px;
  position: relative;
}
@media (max-width: 979px) {
  .s04 {
    padding: 70px 0 50px;
  }
}
.s04 .company-list {
  gap: 30px 115px;
}
@media (max-width: 979px) {
  .s04 .company-list {
    gap: 50;
  }
}
.s04 .company-list .item h3 {
  font-size: 1.8rem;
  font-weight: 700;
  border-bottom: 1px solid #ccc;
  margin: 0 0 12px;
  padding: 0 0 8px;
}
@media (max-width: 979px) {
  .s04 .company-list .item h3 {
    font-size: 2.2rem;
  }
}
.s04 .company-list .item p {

}
@media (max-width: 979px) {
  .s04 .company-list .item p {
    font-size: 1.6rem;
  }
}
.s04 .company-list .item p i {
  margin-left: 4px;
}
.s04 .company-list .item p i img {
  width: 10px;
}
.s04 .company-list .item p a {
  color: #0089D2;
}
.s04 .map {
  text-align: center;
  margin-top: 45px;
}
.s04 .map img {
  max-width: 410px;
}
.s04 .u-sub-ttl {
  font-size: 16rem;
  color: #fff;
  font-weight: 800;
  position: absolute;
  left: 0;
  bottom: 0;
  line-height: 1;
  text-align: left;
  width: 100%;
}
@media (max-width: 979px) {
  .s04 .u-sub-ttl {
    font-size: 7rem;
    bottom: -10px;
  }
}