/********************************************************

Main Visual

********************************************************/
.mvArea .mainLogo {
  position: absolute;
  z-index: 2;
  top: 41px;
  left: 50%;
  transform: translateX(-50%);  
}
@media screen and (max-width: 767px) {
  .mvArea .mainLogo {
    width: 140px;
    height: auto;
  }
}
/********************************************************

wtPoint

********************************************************/
.wtPointArea {
  padding-top: 80px;
  padding-bottom: 80px;
  /* background: url(../img/bg_wt-point.png) no-repeat center top / cover; */
  background: #c8defb;
  position: relative;
  z-index: 10;
}
.wtPointBox {
  padding: 74px 57px 89px;
  position: relative;
  z-index: 2;
}
.wtPointBox::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  margin: auto;
  background: url(../img/bg_wt-point-cont.svg) no-repeat center center / 100% 100%;
  filter: drop-shadow(5px 5px 9px rgba(103, 118, 142, 0.15));
  opacity: 0.9;
  content: '';
}
.wtPointTtlBox {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;
  width: fit-content;
  margin: 0 auto 46px;
}
.wtPointTtlBox::before {
  display: block;
  position: absolute;
  top: 100px;
  left: -307px;
  width: 280px;
  height: 160px;
  margin: auto;
  background: url(../img/img_wt-point-crystal-01.svg) no-repeat center center / 100%;
  content: '';
}
.wtPointTtlBox::after {
  display: block;
  position: absolute;
  top: -63px;
  right: -226px;
  width: 223px;
  height: 206px;
  margin: auto;
  background: url(../img/img_wt-point-crystal-02.svg) no-repeat center center / 100%;
  content: '';
}
.wtPointTtl__top {
  margin: 0 0 13px 0;
}
.wtPointTtl {
  color: #2865B5;
}
.wtPointTtl__txt01 {
  display: block;
  font-size: 43px;
  text-align: center;
  line-height: 1.2;
}
.wtPointTtl__txt02 {
  display: block;
  font-size: 57px;
  text-align: center;
  line-height: 1.1;
}
.wtPointList {
  display: flex;
  flex-wrap: wrap;
  gap: 60px 60px;
  overflow: hidden;
}
.wtPointList__item {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  width: calc((100% - 60px) / 2);
  position: relative;
}
.wtPointList__item:nth-of-type(2n + 1)::before {
  display: block;
  position: absolute;
  top: 0;
  right: -30px;
  width: 1px;
  height: calc(100% + 62px);
  border-right: dashed 1px #A7C2E6;
  content: "";
}
.wtPointList__item:nth-of-type(2n + 1)::after {
  display: block;
  position: absolute;
  top: -30px;
  left: 0;
  width: 250%;
  height: 1px;
  margin: auto;
  border-top: dashed 1px #A7C2E6;
  content: "";
}
.wtPointList__i {
  margin: 0 0 15px 0;
}
.wtPointList__iImg {

}
.wtPointList__ttl {
  margin: 0 0 17px 0;
  color: #B5285E;
  font-size: 25px;
}
.wtPointList__imgBox {
  border-radius: 21px;
  overflow: hidden;
  filter: drop-shadow(4px 4px 0px rgba(216, 236, 253, 1));
}
.wtPointList__img {

}
.wtPointList__txt {
  margin-top: 15px;
  color: #435162;
  font-size: 18px;
  line-height: 1.72;
}

.wtPoint__deco {
  position: absolute;
}

.wtPoint__deco.snow01 {
  width: 185px;
  right: -70px;
  top: 200px;
  z-index: -2;
}
.wtPoint__deco.snow02 {
  width: 220px;
  left: -100px;
  top: 55%;
  z-index: -2;
}
.wtPoint__deco.snow03 {
  width: 300px;
  right: -140px;
  bottom: -50px;
  z-index: -2;
}
.wtPoint__deco.crystal03 {
  left: 20%;
  bottom: -40px;
}
.wtPoint__deco.crystal04 {
  right: 0;
  bottom: 30px;
}

@media screen and (max-width: 767px) {
  .wtPointArea {
    padding-top: 50px;
    padding-bottom: 50px;
    background: url(../img/bg_wt-point.png) no-repeat center top / cover;
    position: relative;
    z-index: 10;
  }
  .wtPointBox {
    padding: 50px 15px 70px;
    position: relative;
    z-index: 2;
  }
  .wtPointBox::before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    margin: auto;
    background: url(../img/bg_wt-point-cont.svg) no-repeat center center / 130% 100%;
    filter: drop-shadow(5px 5px 9px rgba(103, 118, 142, 0.15));
    opacity: 0.9;
    content: '';
  }
  .wtPointTtlBox {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: relative;
    width: fit-content;
    margin: 0 auto 32px;
  }
  .wtPointTtlBox::before {
    display: block;
    position: absolute;
    top: 60px;
    left: -117px;
    width: 130px;
    height: 131px;
    margin: auto;
    background: url(../img/img_wt-point-crystal-01.svg) no-repeat center center / 100%;
    content: '';
  }
  .wtPointTtlBox::after {
    display: block;
    position: absolute;
    top: -63px;
    right: -136px;
    width: 143px;
    height: 156px;
    margin: auto;
    background: url(../img/img_wt-point-crystal-02.svg) no-repeat center center / 100%;
    content: '';
  }
  .wtPointTtl__top {
    margin: 0 0 13px 0;
    height: 34px;
  }
  .wtPointTtl {
    color: #2865B5;
  }
  .wtPointTtl__txt01 {
    display: block;
    font-size: 22px;
    text-align: center;
    line-height: 1.3;
  }
  .wtPointTtl__txt02 {
    display: block;
    font-size: 32px;
    text-align: center;
    line-height: 1.2;
  }
  .wtPointList {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 50px 60px;
    overflow: hidden;
  }
  .wtPointList__item {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    width: auto;
    position: relative;
  }
  .wtPointList__item:nth-of-type(2n + 1)::before {
    display: block;
    position: absolute;
    top: 0;
    right: -30px;
    width: 1px;
    height: calc(100% + 62px);
    border-right: dashed 1px #A7C2E6;
    content: "";
  }
  .wtPointList__item + .wtPointList__item::after {
    display: block;
    position: absolute;
    top: -24px;
    left: 0;
    width: 250%;
    height: 1px;
    margin: auto;
    border-top: dashed 1px #A7C2E6;
    content: "";
  }
  .wtPointList__item:nth-of-type(2n + 1)::after {
    display: block;
    position: absolute;
    top: -24px;
    left: 0;
    width: 250%;
    height: 1px;
    margin: auto;
    border-top: dashed 1px #A7C2E6;
    content: "";
  }
  .wtPointList__i {
    margin: 0 0 10px 0;
  }
  .wtPointList__iImg {
    width: 80px;
  }
  .wtPointList__ttl {
    margin: 0 0 12px 0;
    color: #B5285E;
    font-size: 20px;
    text-align: center;
  }
  .wtPointList__imgBox {
    border-radius: 21px;
    overflow: hidden;
    filter: drop-shadow(4px 4px 0px rgba(216, 236, 253, 1));
  }
  .wtPointList__img {

  }
  .wtPointList__txt {
    margin-top: 15px;
    color: #435162;
    font-size: 16px;
    line-height: 1.72;
  }

  .wtPoint__deco {
    position: absolute;
  }

  .wtPoint__deco.snow01 {
    width: 185px;
    right: -70px;
    top: 200px;
    z-index: -2;
  }
  .wtPoint__deco.snow02 {
    width: 220px;
    left: -100px;
    top: 55%;
    z-index: -2;
  }
  .wtPoint__deco.snow03 {
    width: 300px;
    right: -140px;
    bottom: -50px;
    z-index: -2;
  }
  .wtPoint__deco.crystal03 {
    left: 20%;
    bottom: -30px;
    width: 80px;
  }
  .wtPoint__deco.crystal04 {
    right: 0;
    bottom: 30px;
    width: 50px;
  }

}

/********************************************************

go

********************************************************/
.go {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
  z-index: 5;
  margin: 0 0 -80px 0;
  padding: 33px 15px 63px;
  background-size: auto auto;
  background-color: rgba(40, 101, 181, 1);
  background-image: repeating-linear-gradient(90deg, transparent, transparent 15px, rgba(255, 255, 255, 0.05) 15px, rgba(255, 255, 255, 0.05) 30px );
  clip-path: polygon(0 0, 100% 0, 100% 82%, 50% 100%, 0 82%);
}
.go__topTxt {
  margin: 0 0 5px 0px;
  color: #FFFFFF;
  font-size: 28px;
  text-align: center;
  position: relative;
}
.go__topTxt::before,
.go__topTxt::after {
  display: block;
  position: absolute;
  left: -26px;
  bottom: 5px;
  width: 14px;
  height: 32px;
  background: url(../img/ico_go-top-text-deco.svg) no-repeat center center / 100%;
  content: '';
}
.go__topTxt::after {
  left: auto;
  right: -26px;
  transform: rotateY(180deg);
}
.go__mainTxt {
  color: #fff;
  font-size: 45px;
  line-height: 1.244;
  text-align: center;
}
.txt-yellow {
  color: #FFE48B;
}
@media screen and (max-width: 767px) {
  .go {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
    z-index: 5;
    margin: 0 0 -80px 0;
    padding: 33px 15px 50px;
    background-size: auto auto;
    background-color: rgba(40, 101, 181, 1);
    background-image: repeating-linear-gradient(90deg, transparent, transparent 15px, rgba(255, 255, 255, 0.05) 15px, rgba(255, 255, 255, 0.05) 30px );
    clip-path: polygon(0 0, 100% 0, 100% 82%, 50% 100%, 0 82%);
  }
  .go__topTxt {
    margin: 0 0 12px 0px;
    color: #FFFFFF;
    font-size: 16px;
    text-align: center;
    position: relative;
  }
  .go__topTxt::before,
  .go__topTxt::after {
    display: block;
    position: absolute;
    left: -26px;
    bottom: 0px;
    width: 12px;
    height: 28px;
    background: url(../img/ico_go-top-text-deco.svg) no-repeat center center / 100%;
    content: '';
}
  .go__topTxt::after {
    left: auto;
    right: -26px;
    transform: rotateY(180deg);
  }
  .go__mainTxt {
    color: #fff;
    font-size: 26px;
    line-height: 1.4;
    text-align: center;
  }
  .txt-yellow {
    color: #FFE48B;
  }
}

/**********************************************************

world

***********************************************************/
.worldArea {
  position: relative;
  padding-top: 100px;
  padding-bottom: 200px;
  background-color: #FFF;
}
.worldArea .sec-inner {
  position: relative;
  z-index: 6;
}

.worldBg {
  width: 100%;
  max-width: 1400px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 5;
}

.worldTtl {
  max-width: 552px;
  height: auto;
  margin: 0 auto 80px;
}

.worldList {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 -50px -100px;
}

.worldList__item {
  width: 33.3333333333%;
  margin: 0 -18px;
}

.worldBtmTriangle {
  margin-bottom: -200px;
  margin-right: -30px;
  margin-left: -30px;
  position: relative;
  z-index: 5;
  overflow: hidden;
}

.worldBtmTriangle-style {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 200px 50vw 0 50vw;
  border-color: #fff transparent transparent transparent;
}

@media screen and (max-width: 767px) {
  .worldArea {
    position: relative;
    padding-top: 50px;
    padding-bottom: 110px;
  }
  .worldBg {
    width: 100%;
    max-width: 1400px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 5;
  }
  .worldTtl {
    margin: 0 0 30px 0;
    position: relative;
    z-index: 8;
    color: #2865B5;
    font-size: 6vw;
    text-align: center;
    line-height: 1.1;
  }
  .worldTtl .big01 {
    font-size: calc(6vw + 10px);
  }
  .worldTtl .big02 {
    font-size: calc(6vw + 16px)
  }
  .worldList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 -36px -60px;
  }
  .worldList__item {
    width: 50%;
    margin: 0 -14px;
  }
  .worldBtmTriangle {
    margin-bottom: -100px;
    margin-right: -15px;
    margin-left: -15px;
    position: relative;
    z-index: 5;
    overflow: hidden;
  }
  .worldBtmTriangle-style {
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 100px 50vw 0 50vw;
    border-color: #fff transparent transparent transparent;
  }
}


/**********************************************************

benefitsArea

***********************************************************/
.benefitsArea {
  background-color: #A5DBEA;
  padding-top: 130px;
  padding-bottom: 80px;
  position: relative;
  z-index: 12;
}

.bg-wave {
  position: absolute;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 15px;
  background: url("../img/bg_wave-blue.svg") repeat-x center / contain;
}

.bg-wave.bg-top {
  top: -14px;
}

.bg-wave.bg-bottom {
  background-image: url("../img/bg_wave-blue.svg");
  bottom: -61px;
}

.benefitsTtlBox {
  display: flex;
  justify-content: center;
  margin: 0 0 74px 0;
}

.benefitsTtl__mainTxt {
  position: relative;
}

.benefitsTtl__subTxtImg {
  position: absolute;
  top: -55px;
  left: -80px;
}

.benefitsList {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 74px 38px;
}

.benefitsList__item {
  width: calc( 100% / 2 - 19px );
  padding: 0 20px;
}

.benefitsList__itemInner {
  padding: 14px 30px 36px;
  background-color: #fff;
  border-radius: 15px;
  position: relative;
  z-index: 0;
}
.benefitsList__itemInner::after {
  display: block;
  position: absolute;
  top: -36px;
  right: 0;
  left: 0;
  z-index: -1;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background-color: #fff;
  margin: auto;
  content: "";
}
.benefitsList__item:nth-of-type(2) .benefitsList__itemInner {
  height: 100%;
}

.benefitsList__ttlNum {
  margin: 0 0 16px 0;
  color: #009ECB;
  text-align: center;
  font-weight: bold;
  font-size: 20px;
  position: relative;
}
.benefitsList__ttlNum::before {
  display: block;
  position: absolute;
  top: -24px;
  right: 0;
  left: 0;
  z-index: 20;
  width: 48px;
  height: 15px;
  margin: auto;
  background: url(../img/icon_star.svg) no-repeat top left;
  content: "";
}

.benefitsList__ttlNum-count {
  font-size: 23px;
}

.benefitsList__ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 51px;
  padding: 0 10px;
  margin: 0 -50px;
  background-color: #FFDA76;
  color: #009ECB;
  text-align: center;
  font-weight: bold;
  font-size: 22px;
  position: relative;
}
.benefitsList__ttl::before, .benefitsList__ttl::after {
  display: block;
  position: absolute;
  bottom: -16px;
  width: 0;
  height: 0;
  border-style: solid;
  content: "";
}
.benefitsList__ttl::before {
  left: 0;
  border-width: 0 20px 16px 0;
  border-color: transparent #BF8D06 transparent transparent;
}
.benefitsList__ttl::after {
  right: 0;
  border-width: 16px 20px 0 0;
  border-color: #BF8D06 transparent transparent transparent;
}
.benefitsList__imgBox {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 160px;
  padding-top: 10px;
}
.benefitsList__txt {
  font-size: 16px;
  text-align: center;
  line-height: 1.5;
}
.benefitsList__txt-asterisk {
  font-size: 13px;
}
.benefitsList__note {
  margin-top: 24px;
  color: #4696AC;
  text-align: right;
}
.benefitsList__noteTxt {
  display: block;
  font-size: 14px;
  padding-left: 1em;
  text-indent: -1em;
}
.benefitsList__noteTxt + .benefitsList__noteTxt {
  margin-top: 4px;
}
.aboutLogbook {
  max-width: 784px;
  border: 3px #FFF solid;
  border-radius: 15px;
  padding: 30px 25px 30px 280px;
  margin: 60px auto 0;
  position: relative;
}
.aboutLogbook:before, 
.aboutLogbook:after {
  content: "";
  position: absolute;
  display: block;
}
.aboutLogbook:before {
  width: 60px;
  height: 60px;
  background: #A5DBEA;
  top: -10px;
  left: -10px;
}
.aboutLogbook:after {
  width: 76px;
  height: 70px;
  background: url(../img/img_question.png) no-repeat center / contain;
  top: -30px;
  left: -38px;
}
.aboutLogbook .img {
  position: absolute;
  bottom: 0;
  left: 10px;
}
.aboutLogbook .txtBox .answer {
  margin-top: 20px;
}
.aboutLogbook .txtBox .question,
.aboutLogbook .txtBox .answer {
  font-size: 1.6rem;
  font-weight: bold;
  position: relative;
  padding-left: 40px;
}
.aboutLogbook .txtBox .question:before,
.aboutLogbook .txtBox .answer:before {
  content: "";
  width: 33px;
  height: 31px;
  display: block;
  position:absolute;
  left: 0;
}
.aboutLogbook .txtBox .question:before {
  background: url(../img/ico_q.png) no-repeat center / contain;
}
.aboutLogbook .txtBox .answer:before {
  background: url(../img/ico_a.png) no-repeat center / contain;
}
.aboutLogbook .txtBox .desc {
  font-size: 1.4rem;
  padding-left: 40px;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .benefitsArea {
    padding-top: 90px;
    padding-bottom: 50px;
    position: relative;
  }
  .bg-wave {
    width: 100%;
    height: 15px;
  }
  .benefitsTtlBox {
    display: flex;
    justify-content: center;
    margin: 0 0 54px 0;
  }
  .benefitsTtl__mainTxt {
    position: relative;
  }
  .benefitsTtl__subTxtImg {
    position: absolute;
    top: -45px;
    left: -150px;
    right: 0;
    margin: auto;
    width: 220px;
  }
  .benefitsTtl__mainTxtImg {
    height: 70px;
  }
  .benefitsList {
    gap: 30px 10px;
  }
  .benefitsList__item {
    width: calc(100% / 2 - 5px);
    padding: 0;
  }
  .benefitsList__item:last-child {
    margin-bottom: 0;
  }
  .benefitsList__itemInner {
    padding: 6px 15px 15px;
    background-color: #fff;
    border-radius: 10px;
    position: relative;
    z-index: 0;
  }
  .benefitsList__itemInner::after {
    top: -20px;
    width: 80px;
    height: 80px;
  }
  .benefitsList__item:nth-of-type(2) .benefitsList__itemInner {
    height: 100%;
  }
  .benefitsList__ttlNum {
    margin: 0 0 11px 0;
    font-size: 16px;
  }
  .benefitsList__ttlNum::before {
    display: block;
    position: absolute;
    top: -15px;
    right: 0;
    left: 0;
    z-index: 20;
    width: 36px;
    height: 15px;
    margin: auto;
    background: url(../img/icon_star.svg) no-repeat top left;
    background-size: 100%;
    content: "";
  }
  .benefitsList__ttlNum-count {
    font-size: 18px;
  }
  .benefitsList__ttl {
    height: 52px;
    margin: 0 -15px;
    font-size: 16px;
    line-height: 1.2;
  }
  .benefitsList__ttl::before, .benefitsList__ttl::after {
    content: normal;
  }
  .benefitsList__imgBox {
    height: 100px;
    padding-top: 0;
  }
  .benefitsList__img.private {
    height: 50px;
  }
  .benefitsList__img.car {
    height: 40px;
  }
  .benefitsList__img.noAdd {
    height: 70px;
  }
  .benefitsList__img.book {
    height: 50px;
  }
  .benefitsList__txt {
    font-size: 14px;
    text-align: left;
  }
  .benefitsList__note {
    text-align: left;
  }
  .benefitsList__noteTxt {
    font-size: 1.2rem;
  }
  .aboutLogbook {
    max-width: 100%;
    padding: 20px 15px 0 15px;
    margin: 40px 20px 0;
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
  }
  .aboutLogbook:before {
    width: 60px;
    height: 60px;
    top: -10px;
    right: -10px;
    left: auto;
  }
  .aboutLogbook:after {
    width: 60px;
    height: 56px;
    top: -25px;
    right: -20px;
    left: auto;
  }
  .aboutLogbook .img {
    position: relative;
    bottom: auto;
    left: auto;
    margin-top: 15px;
    text-align: center;
  }
  .aboutLogbook .img img {
    width: 200px;
  }
  .aboutLogbook .txtBox .answer {
    margin-top: 8px;
  }
  .aboutLogbook .txtBox .question,
  .aboutLogbook .txtBox .answer {
    padding-left: 28px;
  }
  .aboutLogbook .txtBox .question:before,
  .aboutLogbook .txtBox .answer:before {
    content: "";
    width: 23px;
    height: 22px;
  }
  .aboutLogbook .txtBox .desc {
    padding-left: 0;
    margin-top: 8px;
  }
}
/**********************************************************

get

***********************************************************/
.getArea {
  padding: 60px 80px 66px;
  background: url(../img/bg_get.jpg) no-repeat center center;
  background-size: cover;
}

.getTtl {
  display: flex;
  justify-content: center;
  margin: 0 0 44px 0;
}

.getCont {
  width: 100%;
  max-width: 836px;
  margin: 0 auto;
}

.getCont__note {
  margin-top: 15px;
  text-align: right;
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .getArea {
    padding: 50px 15px 50px;
    background: url(../img/bg_get.jpg) no-repeat center center;
    background-size: cover;
  }
  .getTtl {
    display: flex;
    justify-content: center;
    margin: 0 0 24px 0;
  }
  .getTtl__img {
    width: 180px;
  }
  .getCont {
    width: 100%;
    max-width: 836px;
    margin: 0 auto;
  }
  .getCont__note {
    margin-top: 12px;
    text-align: right;
    color: #fff;
    font-size: 12px;
  }
}
/**********************************************************

flow

***********************************************************/
.flowArea {
  padding-bottom: 0;
  overflow: hidden;
}
.flowArea .sec-inner {
  max-width: inherit;
}

.bellTtl {
  position: relative;
  margin: 74px 0 90px;
}
.bellTtl::before {
  display: block;
  position: absolute;
  top: -76px;
  right: 0;
  left: 0;
  width: 58px;
  height: 64px;
  margin: auto;
  background: url(../img/icon_bell.svg) no-repeat top left;
  background-size: 100%;
  content: "";
}

.bellTtl__en {
  display: flex;
  justify-content: center;
  margin: 0 0 21px 0;
}

.bellTtl__ja {
  display: flex;
  justify-content: center;
}

.flowList {
  margin: -40px -90px 0;
}

.flowList__item {
  padding: 70px 90px 90px;
  background: linear-gradient(123deg, rgb(255, 244, 255) 0%, rgb(253, 253, 235) 100%);
  box-shadow: 0px 4px 5px 0px rgba(35, 39, 95, 0.1);
  position: relative;
}
.flowList__item::before {
  display: block;
  position: absolute;
  bottom: -12px;
  left: 0;
  right: 0;
  z-index: 10;
  width: 100%;
  height: 68px;
  margin: auto;
  background: url(../img/bg_flow-arrow-gra.png) no-repeat center center;
  background-size: 2560px 46px;
  content: "";
}
.flowList__item:nth-of-type(2n) {
  padding-top: 10px;
  padding-bottom: 40px;
  background-image: none;
  background-color: #fff;
}
.flowList__item:nth-of-type(2n)::before {
  bottom: -60px;
  height: 100px;
  background: url(../img/bg_flow-arrow-white.png) no-repeat center center;
  background-size: 2560px 88px;
}
.flowList__item:first-child {
  padding-top: 50px;
}
.flowList__item:last-child {
  /* padding-bottom: 50px; */
  box-shadow: none;
}
/* .flowList__item:last-child::before {
  display: none;
} */

.flowList__itemBox {
  display: flex;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

.flowList__imgBox {
  width: 490px;
}

.flowList__cont {
  width: 600px;
  margin-top: 20px;
}

.flowList__num {
  margin: 0 0 28px 0;
  padding: 5px 40px;
  height: 62px;
  color: #fff;
  background: url(../img/bg_flow-list-num.svg) no-repeat center right;
  background-size: cover;
  font-weight: bold;
  font-size: 30px;
}

.flowList__ttl {
  margin: 0 0 10px 0;
  padding: 0 0 0 40px;
  font-size: 34px;
  color: #2789cf;
  font-weight: bold;
}

.flowList__txt {
  padding: 0 0 0 40px;
  font-size: 16px;
  line-height: 1.8;
}

.marker-yellow {
  background: linear-gradient(transparent 50%, #fff5a5 50%);
}

@media screen and (max-width: 767px) {
  .flowArea {
    padding-bottom: 60px;
    overflow-x: hidden;
  }
  .bellTtl {
    position: relative;
    margin: 45px 0 50px;
  }
  .bellTtl::before {
    display: block;
    position: absolute;
    top: -46px;
    right: 0;
    left: 0;
    width: 30px;
    height: 44px;
    margin: auto;
    background: url(../img/icon_bell.svg) no-repeat top left;
    background-size: 100%;
    content: "";
  }
  .bellTtl__en {
    display: flex;
    justify-content: center;
    margin: 0 0 16px 0;
  }
  .bellTtl__enImg {
    height: 14px;
  }
  .bellTtl__ja {
    display: flex;
    justify-content: center;
  }
  .bellTtl__jaImg {
    max-width: 340px;
    width: 100%;
  }
  .flowList {
    margin: 0px -15px -40px;
  }
  .flowList__item {
    display: block;
    padding: 50px 17px 65px;
  }
  .flowList__item::before {
    display: block;
    position: absolute;
    bottom: -16px;
    left: 0;
    right: 0;
    z-index: 10;
    width: 100%;
    height: 68px;
    margin: auto;
    background: url(../img/bg_flow-arrow-gra.png) no-repeat center center;
    background-size: 2000px 36px;
    content: "";
  }
  .flowList__item:nth-of-type(2n) {
    padding-bottom: 18px;
    padding-top: 2px;
  }
  .flowList__item:nth-of-type(2n)::before {
    bottom: -60px;
    height: 100px;
    background: url(../img/bg_flow-arrow-white.png) no-repeat center center;
    background-size: 2000px 74px;
  }
  .flowList__item:first-child {
    padding-top: 34px;
  }
  .flowList__item:last-child {
    /* padding-bottom: 30px; */
  }
  .flowList__itemBox {
    display: block;
  }
  .flowList__imgBox {
    width: auto;
  }
  .flowList__cont {
    width: auto;
    margin-top: 20px;
  }
  .flowList__num {
    margin: 0 0 8px 0;
    padding: 5px 20px;
    height: 50px;
    color: #fff;
    background: url(../img/bg_flow-list-num.svg) no-repeat center right;
    background-size: cover;
    font-weight: bold;
    font-size: 24px;
  }
  .flowList__num .flowList__num-congratulations {
    margin-top: -4px;
  }
  .flowList__ttl {
    margin: 0 0 10px 0;
    padding: 0 0 0 0;
    font-size: 24px;
    color: #2789cf;
    font-weight: bold;
  }
  .flowList__txt {
    padding: 0 0 0 0;
    font-size: 14px;
    line-height: 2;
  }
}

/********************************************************

getRateArea

********************************************************/
.getRateArea {
  background-size: auto auto;
  background-color: rgba(255, 255, 255, 1);
  background-image: repeating-linear-gradient(0deg, transparent, transparent 18px, rgba(242, 245, 195, 1) 18px, rgba(242, 245, 195, 1) 19px );
}
.getRateBox {

}
.getRate__ttl {
  margin: 0 0 40px 0;
  display: flex;
  justify-content: center;
}
.getRate__ttlImg {

}
.getRateCont {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  padding: 30px 50px;
  border: solid 3px #2F2F2F;
  background-color: #fff;
  border-radius: 18px;
  position: relative;
}
.getRateCont + .getRateCont {
  margin-top: 30px;
}
.getRateCont__ttl {
  margin: 0 0 21px 0;
  font-size: 32px;
  text-align: center;
  font-weight: bold;
  line-height: 1.468;
}
.marker-yellow {
  background:linear-gradient(transparent 60%, #FFFB8E 60%);
}
.getRateContList {
  padding: 0 0 0 18px;
  counter-reset : number ;
}
.getRateContList__item {
  font-size: 24px;
  position: relative;
  font-weight: bold;
  color: #434343;
  padding: 0 0 0 30px;
}
.getRateContList__item::before {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 9px;
  left: 0;
  width: 24px;
  height: 24px;
  background-color: #2789CF;
  color: #fff;
  font-size: 16px;
  text-align: center;
  border-radius: 50%;
  margin: auto;
  counter-increment: number 1;
  content: counter(number);
  padding: 0px 0 1px;
  box-sizing: border-box;
}
.getRateContList__item + .getRateContList__item {
  margin-top: 9px;
}

.getRateCont.blue {
  border-color: #2789CF;
  background-color: #F2FDFF;
}
.getRateCont.blue::before {
  display: block;
  position: absolute;
  top: -15px;
  right: -13px;
  width: 90px;
  height: 89px;
  margin: auto;
  background: url(../img/img_get-rate-face.svg);
  content: '';
}
.getRateCont.blue .getRateCont__ttl {
    color: #2789CF;
}
.getRateCont.blue .getRateContList__item::before {
  background-color: #2789CF;
}


.getRateCont.green {
  border-color: #01BAAF;
  background-color: #F7FFFD;
}
.getRateCont.green::before {
  display: block;
  position: absolute;
  top: -70px;
  left: -66px;
  width: 152px;
  height: 158px;
  margin: auto;
  background: url(../img/img_get-rate-light.svg);
  content: '';
}
.getRateCont.green .getRateCont__ttl {
  color: #01BAAF;
}
.getRateCont.green .getRateContList__item::before {
  background-color: #01BAAF;
}

@media screen and (max-width: 767px) {
  .getRateArea {
    padding-top: 70px;
    padding-bottom: 70px;
    background-size: auto auto;
    background-color: rgba(255, 255, 255, 1);
    background-image: repeating-linear-gradient(0deg, transparent, transparent 18px, rgba(242, 245, 195, 1) 18px, rgba(242, 245, 195, 1) 19px );
  }
  .getRateBox {

  }
  .getRate__ttl {
    margin: 0 0 20px 0;
    display: flex;
    justify-content: center;
  }
  .getRate__ttlImg {
    max-width: 380px;
  }
  .getRateCont {
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
    padding: 30px 15px;
    border: solid 2px #2F2F2F;
    background-color: #fff;
    border-radius: 12px;
    position: relative;
  }
  .getRateCont + .getRateCont {
    margin-top: 30px;
  }
  .getRateCont__ttl {
    margin: 0 0 18px 0;
    font-size: 20px;
    text-align: center;
    font-weight: bold;
    line-height: 1.468;
  }
  .marker-yellow {
    background:linear-gradient(transparent 60%, #FFFB8E 60%);
  }
  .getRateContList {
    padding: 0 0 0 0;
    counter-reset : number ;
  }
  .getRateContList__item {
    font-size: 16px;
    position: relative;
    font-weight: bold;
    color: #434343;
    padding: 0 0 0 26px;
  }
  .getRateContList__item::before {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 4px;
    left: 0;
    width: 20px;
    height: 20px;
    background-color: #2789CF;
    color: #fff;
    font-size: 14px;
    text-align: center;
    border-radius: 50%;
    margin: auto;
    counter-increment: number 1;
    content: counter(number);
    padding: 0px 0 1px;
    box-sizing: border-box;
  }
  .getRateContList__item + .getRateContList__item {
    margin-top: 9px;
  }

  .getRateCont.blue {
    border-color: #2789CF;
    background-color: #F2FDFF;
  }
  .getRateCont.blue::before {
    display: block;
    position: absolute;
    top: -15px;
    right: -13px;
    width: 60px;
    height: 59px;
    margin: auto;
    background: url(../img/img_get-rate-face.svg);
    background-size: 100%;
    content: '';
  }
  .getRateCont.blue .getRateCont__ttl {
      color: #2789CF;
  }
  .getRateCont.blue .getRateContList__item::before {
    background-color: #2789CF;
  }


  .getRateCont.green {
    border-color: #01BAAF;
    background-color: #F7FFFD;
  }
  .getRateCont.green::before {
    display: block;
    position: absolute;
    top: -60px;
    left: -36px;
    width: 102px;
    height: 98px;
    margin: auto;
    background: url(../img/img_get-rate-light.svg);
    background-size: 100%;
    content: '';
  }
  .getRateCont.green .getRateCont__ttl {
    color: #01BAAF;
  }
  .getRateCont.green .getRateContList__item::before {
    background-color: #01BAAF;
  }
}

/**********************************************************

campaignArea

***********************************************************/
.campaignArea {
  position: relative;
  z-index: 1;
}
.campaignArea .sec-inner {
  position: relative;
  z-index: 5;
  background: url(../img/img_mv-human-001.svg) no-repeat bottom 240px left 0px, url(../img/img_mv-human-002.svg) no-repeat top 20px right 0px;
}
.campaignArea .mvFirstCome {
  margin-bottom: 30px;
  padding: 4px 0;
}
.campaignArea .mvFirstCome__num {
  color: #ffe943;
  font-size: 27px;
}
.campaignArea .mvPrice__txt--after::after {
  background-image: url(../img/txt_campaign-price-point.svg);
}

@media screen and (max-width: 767px) {
  .campaignArea {
    position: relative;
    z-index: 1;
  }
  .campaignArea .sec-inner {
    position: relative;
    z-index: 5;
    background: none;
  }
  .campaignArea .mvFirstCome {
    margin-bottom: 30px;
    padding: 5px 0;
  }
  .campaignArea .mvFirstCome__num {
    color: #ffe943;
    font-size: 22px;
  }
  .campaignArea .mvPrice__txt--after::after {
    background-image: url(../img/txt_campaign-price-point.svg);
  }
}
/**********************************************************

contactArea

***********************************************************/
.contactArea {
  padding: 15px 20px;
  background-color: #E53874;
  position: relative;
  z-index: 2;
}
.contactArea .sec-inner {
  max-width: 1280px;
}
.contactArea .contactLink {
  width: auto;
  height: 76px;
  padding: 0 70px 0 40px;
  font-size: 21px;
}
.contactArea .contactLink::before {
  top: 2px;
  bottom: 0;
  right: 22px;
  width: 24px;
  height: 20px;
  margin: auto;
  background-size: 100%;
  content: "";
}
.contactOuter {
  border-radius: 10px;
  background-image: linear-gradient(-45deg, #ffffff 25%, #FEFAFB 25%, #FEFAFB 50%, #ffffff 50%, #ffffff 75%, #FEFAFB 75%, #FEFAFB 100%);
  background-size: 50px 50px;
  position: relative;
}
.contact__imgBox {
  position: absolute;
  bottom: -44px;
  left: 0;
  width: 480px;
}
.contact__imgBox.men {
  position: absolute;
  bottom: -17px;
  left: 0;
  width: 550px;
}
.contact__cont {
  width: calc(100% - 400px);
  margin: 0 0 0 auto;
  padding: 35px 40px 35px 0;
}
.contact__ttl {
  margin: 0 0 20px 0;
  font-size: 38px;
  font-weight: bold;
  text-align: center;
}
.contact__ttl span.inner {
  position: relative;
  display: inline-block;
  padding-left: 105px;
}
.contact__ttl span.inner:before {
  content: '';
  width: 99px;
  height: 98px;
  background: url(../img/ico_free.svg) no-repeat center / contain;
  display: block;
  position: absolute;
  left: 0;
  top: 12px;
}
.contact__ttl span.highlight {
  color: #E53874;
}
.contactBox {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.contactBox .lead {
  font-size: 2.2rem;
  margin-top: 20px;
  text-align: center;
}
.contactArea .contactBox .lead {
 color: #303743;
}

@media screen and (max-width: 1200px) {
  .contactArea {
    padding: 15px 15px;
    background-color: #E53874;
    position: relative;
    z-index: 2;
  }
  .contactArea .sec-inner {
    max-width: 1280px;
  }
  .contactOuter {
    display: flex;
    flex-direction: column;
    border-radius: 10px;
    background-image: linear-gradient(-45deg, #ffffff 25%, #FEFAFB 25%, #FEFAFB 50%, #ffffff 50%, #ffffff 75%, #FEFAFB 75%, #FEFAFB 100%);
    background-size: 50px 50px;
    position: relative;
  }
  .contact__imgBox {
    display: flex;
    justify-content: center;
    order: 2;
    position: static;
    width: auto;
  }
  .contact__imgBox.men {
    position: static;
    width: auto;
  }
  .contact__img {
    max-width: 420px;
    margin-bottom: -36px;
    margin-right: -110px;
  }
  .contact__imgBox.men .contact__img {
    margin-right: -60px;
    margin-bottom: -12px;
  }
  .contact__cont {
    order: 1;
    width: auto;
    margin: 0 0 0 0;
    padding: 30px 20px;
  }
  .contact__ttl {
    margin: 0 0 28px 0;
    font-size: 36px;
    font-weight: bold;
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .contactArea {
    padding: 15px 15px;
    background-color: #E53874;
    position: relative;
    z-index: 2;
  }
  .contactArea .sec-inner {
    max-width: 1280px;
  }
  .contactArea .contactLink {
    width: auto;
    height: 60px;
    padding: 0 55px 0 25px;
    border-radius: 50px;
    position: relative;
    font-size: 18px;
    font-weight: bold;
  }
  .contactArea .contactLink::before {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 23px;
    width: 22px;
    height: 18px;
    margin: auto;
    background-size: 100%;
    content: "";
  }
  .contactOuter {
    display: flex;
    flex-direction: column;
    border-radius: 10px;
    background-image: linear-gradient(-45deg, #ffffff 25%, #FEFAFB 25%, #FEFAFB 50%, #ffffff 50%, #ffffff 75%, #FEFAFB 75%, #FEFAFB 100%);
    background-size: 50px 50px;
    position: relative;
  }
  .contact__imgBox {
    display: flex;
    justify-content: center;
    order: 2;
    position: static;
    width: auto;
  }
  .contact__imgBox.men {
    position: static;
    width: auto;
  }
  .contact__img {
    max-width: 270px;
    margin-bottom: -24px;
    margin-right: -20px;
  }
  .contact__imgBox.men .contact__img {
    margin-right: -40px;
    margin-bottom: -9px;
  }
  .contact__cont {
    order: 1;
    width: auto;
    margin: 0 0 0 0;
    padding: 30px 20px 10px;
  }
  .contact__ttl {
    margin: 0 0 28px 0;
    font-size: 25px;
    font-weight: bold;
    text-align: center;
  }
  .contact__ttl span.inner {
    padding-left: 78px;
  }
  .contact__ttl span.inner:before {
    width: 72px;
    height: 71px;
    top: 5px;
  }
  .contactBox .lead {
    font-size: 1.6rem;
    margin-top: 15px;
    line-height: 1.8;
  }
}
/**********************************************************

reasonArea

***********************************************************/
.reasonArea {
  padding-top: 100px;
  padding-bottom: 100px;
  background: url(../img/bg_reason.jpg) no-repeat bottom center/cover;
}

.reasonList__item {
  display: flex;
}
.reasonList__item + .reasonList__item {
  margin-top: 60px;
}

.reasonList__imgBox {
  display: flex;
  width: 50%;
  overflow: hidden;
  border-radius: 10px 0 0 10px;
}
.reasonList__item:nth-of-type(2n) .reasonList__imgBox {
  order: 2;
  border-radius: 0 10px 10px 0;
}

.reasonList__img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.reasonList__cont {
  width: 50%;
  padding: 30px 30px;
  position: relative;
  background-color: #fff;
  border-radius: 0 10px 10px 0;
}
.reasonList__item:nth-of-type(2n) .reasonList__cont {
  order: 1;
  border-radius: 10px 0 0 10px;
}

.reasonList__num {
  position: absolute;
  top: 30px;
  left: 40px;
  font-size: 103px;
  color: #eaeaea;
  line-height: 1;
}

.reasonList__ttl {
  margin: 20px 0 20px 0;
  font-size: 32px;
  font-weight: bold;
  color: #268ccf;
  position: relative;
  z-index: 1;
  line-height: 1.4;
}

.reasonList__txt {
  font-size: 16px;
  line-height: 2;
  position: relative;
}

.comparisonTtl {
  margin-top: 90px;
  color: #107aad;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 41px;
  line-height: 1.317073171;
  font-weight: 900;
  text-align: center;
}
.comparisonTtl .highlight {
  background: linear-gradient(transparent 70%, #fff96e 0%);
}

.comparisonTable {
  margin: 49px auto 0;
}
.comparisonTable img {
  width: 105.1818182%;
  height: auto;
  max-width: 105.1818182%;
  margin: 0 -2.5909091%;
  position: relative;
  right: -0.8181818%;
}

.pcOnly {
  display: block;
}

.spOnly {
  display: none;
}

@media screen and (max-width: 767px) {
  .reasonArea {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .reasonList__item {
    display: block;
  }
  .reasonList__item + .reasonList__item {
    margin-top: 40px;
  }
  .reasonList__imgBox {
    width: auto;
    overflow: hidden;
    border-radius: 10px 10px 0 0;
  }
  .reasonList__item:nth-of-type(2n) .reasonList__imgBox {
    order: 2;
    border-radius: 10px 10px 0 0;
  }
  .reasonList__cont {
    width: auto;
    padding: 20px 20px;
    position: relative;
    background-color: #fff;
    border-radius: 0 0 10px 10px;
  }
  .reasonList__item:nth-of-type(2n) .reasonList__cont {
    order: 1;
    border-radius: 0 0 10px 10px;
  }
  .reasonList__num {
    position: absolute;
    top: 10px;
    left: 40px;
    font-size: 103px;
    color: #eaeaea;
    line-height: 1;
  }
  .reasonList__ttl {
    margin: 10px 0 15px 0;
    font-size: 22px;
    font-weight: bold;
    color: #268ccf;
    position: relative;
    z-index: 1;
    line-height: 1.4;
  }
  .reasonList__txt {
    font-size: 14px;
    line-height: 1.8;
  }
  .comparisonTtl {
    margin-top: 50px;
    color: #107aad;
    font-size: 24px;
  }
  .comparisonTable {
    margin: 25px auto 0;
  }
  .comparisonTable img {
    width: calc(100% + 30px);
    max-width: calc(100% + 30px);
    margin: 0 -15px;
    right: 0;
  }
  .pcOnly {
    display: none;
  }
  .spOnly {
    display: block;
  }
}

/*―――――――――――――――――――――――――――――――――――――――――――――
/* specialArea
――――――――――――――――――――――――――――――――――――――――――――――*/
/* ▼通常 */
.specialArea {
  margin: 20px -30px -80px;
  padding: 150px 90px 140px;
  background: url(../img/bg_special.png) no-repeat center center / 100% 100%;
}

.special__ttl {
  color: #107AAD;
  font-weight: bold;
  text-align: center;
  font-size: 32px;
  margin: 0 0 34px 0;
}
.special__ttl span {
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: 100% 46%;
  background-image: repeating-linear-gradient( -45deg, #D9EFFF , #D9EFFF 2px, transparent 2px, transparent 5px );
}
.special__ttl strong {
  color: #46A7DB;
  font-size: 41px;
}
.special__leadBox {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 0 20px;
  margin: 0 0 28px 0;
}
.special__leadImgBox:nth-child(2) {
  margin-top: -10px;
}
.special__leadImg {
  width: 221px;
}
.specialCont {
  display: flex;
  justify-content: center;
  gap: 0 48px;
}
.specialCont__item {
  padding: 12px 12px;
  border-radius: 13px;
  background: linear-gradient(140deg, rgba(183,255,249,1) 0%, rgba(131,204,255,1) 100%);
}
.specialCont__itemInner {
  height: 100%;
  padding: 39px 32px 18px;
  border-radius: 13px;
  background-color: #fff;
}
.specialCont__ttl {
  display: flex;
  justify-content: center;
  margin: 0 0 25px 0;
}
.specialCont__ttlImg {

}
.specialCont_photoBox {
  margin: 0 0 22px 0;
  border-radius: 13px;
  overflow: hidden;
}
.specialCont__photo {

}
.specialCont__txt {
  font-size: 16px;
  line-height: 2;
}
.specialCont__txt a {
  color: #107AAD;
  text-decoration: underline;
}
.specialCont__txt a:hover {
  text-decoration: none;
  opacity: 1;
}
.marker--yellow {
  background:linear-gradient(transparent 20%, #F7FFCB 20%);
}

@media screen and (max-width: 1100px) {
  .specialArea {
    margin: 20px -60px 0;
    padding: 140px 50px 130px;
  }
  .specialCont {
    display: flex;
    justify-content: center;
    gap: 0 20px;
  }
}

@media screen and (max-width: 767px) {
  .specialArea {
    margin: -40px -50px 0px;
    padding: 130px 50px 40px;
    background: url(../img/bg_special.png) no-repeat top center / 200% 100%;
  }
  .special__ttl {
    text-align: center;
    font-size: 20px;
    margin: 0 0 30px 0;
  }
  .special__ttl span {
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: 100% 46%;
    background-image: repeating-linear-gradient( -45deg, #D9EFFF , #D9EFFF 2px, transparent 2px, transparent 5px );
  }
  .special__ttl strong {
    font-size: 28px;
  }
  .special__leadBox {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 0 10px;
    margin: 0 0 20px 0;
  }
  .special__leadImgBox:nth-child(1) {
    margin: 0;
  }
  .special__leadImgBox:nth-child(2) {
    margin-top: -10px;
  }
  .special__leadImgBox:nth-child(3) {
    margin: 0;
  }
  .special__leadImg {
    width: 100%;
    max-width: 175px;
  }
  .specialCont {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px 0px;
  }
  .specialCont__item {
    padding: 8px 8px;
    border-radius: 13px;
  }
  .specialCont__itemInner {
    height: 100%;
    padding: 30px 15px 30px;
    border-radius: 13px;
  }
  .specialCont__ttl {
    display: flex;
    justify-content: center;
    margin: 0 0 15px 0;
  }
  .specialCont__ttlImg {

  }
  .specialCont_photoBox {
    margin: 0 0 15px 0;
    border-radius: 13px;
    overflow: hidden;
    aspect-ratio: 438/223;
  }
  .specialCont__photo {

  }
  .specialCont__txt {
    font-size: 15px;
    line-height: 1.8;
  }
  .marker--yellow {
  }
}


/**********************************************************

voiceArea

***********************************************************/
.voiceArea {
  padding-bottom: 0;
  background: rgb(245, 251, 255);
  background: linear-gradient(156deg, rgb(245, 251, 255) 0%, rgb(218, 245, 253) 100%);
}

.voiceList__item {
  display: flex;
}
.voiceList__item + .voiceList__item {
  margin-top: 20px;
}

.voiceList__imgBox {
  width: 331px;
  margin-top: 20px;
}
.voiceList__item:nth-of-type(2n) .voiceList__imgBox {
  order: 2;
}

.voiceList__item:nth-of-type(2n) .voiceList__cont {
  order: 1;
}

.voiceList__name {
  margin: 0 0 -10px 100px;
  color: #278acf;
}
.voiceList__item:nth-of-type(2n) .voiceList__name {
  margin-left: 60px;
}

.voiceList__name-main {
  font-size: 38px;
  font-weight: bold;
}

.voiceList__name-age {
  margin: 0 0 0 14px;
  font-size: 21px;
  font-weight: bold;
}

.voiceList__txtBox {
  display: flex;
  justify-content: center;
  align-items: center;
}
.voiceList__item:nth-of-type(2n) .voiceList__txtBox {
  order: 2;
}

.voiceList__txt {
  font-size: 20px;
  line-height: 1.9;
}
.voiceList__item:nth-of-type(2n) .voiceList__txt {
  margin: 0 20px 0 0;
}

.voiceList__txt-yellow {
  background: linear-gradient(transparent 60%, #ff6 60%);
}

.voiceBtmImgBox {
  margin: 45px -80px 0;
}

.voiceBtmImg {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .voiceArea {
    padding-bottom: 0;
    background: rgb(245, 251, 255);
    background: linear-gradient(156deg, rgb(245, 251, 255) 0%, rgb(218, 245, 253) 100%);
  }
  .voiceList__item {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .voiceList__item + .voiceList__item {
    margin-top: 40px;
  }
  .voiceList__imgBox {
    max-width: 230px;
    width: 100%;
    margin-top: 0;
  }
  .voiceList__item:nth-of-type(2n) .voiceList__imgBox {
    order: 1;
  }
  .voiceList__cont {
    flex: 1;
    margin-top: 15px;
  }
  .voiceList__item:nth-of-type(2n) .voiceList__cont {
    order: 2;
  }
  .voiceList__name {
    margin: 0;
    text-align: center;
    color: #278acf;
    line-height: 1;
  }
  .voiceList__item:nth-of-type(2n) .voiceList__name {
    margin-left: 0;
  }
  .voiceList__name-main {
    font-size: 22px;
  }
  .voiceList__name-age {
    margin: 0 0 0 14px;
    font-size: 16px;
  }
  .voiceList__txtBox {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .voiceList__item:nth-of-type(2n) .voiceList__txtBox {
    order: 2;
  }
  .voiceList__txt {
    margin: 0 -15px 0;
    font-size: 20px;
    line-height: 1.9;
  }
  .voiceList__item:nth-of-type(2n) .voiceList__txt {
    margin: 0 -15px 0;
  }
  .voiceList__txt-yellow {
    background: linear-gradient(transparent 60%, #ff6 60%);
  }
  .voiceBtmImgBox {
    margin: 45px -15px 0;
  }
  .voiceBtmImg {
    width: 100%;
  }
}
/**********************************************************

faqArea

***********************************************************/
.faqArea {
  padding: 94px 30px 123px;
  background: linear-gradient(145deg, #efffff, #def2ff);
}

.faqList {
  margin-top: -25px;
}
.faqList li {
  padding: 32px 38px 30px 90px;
  background: #fff;
  position: relative;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
}
.faqList li:before {
  content: "";
  width: 13px;
  height: 100%;
  background: linear-gradient(to top, #0fd1c1, #278acf);
  position: absolute;
  top: 0;
  left: 0;
}
.faqList li + li {
  margin-top: 25px;
}
.faqList li .question {
  color: #0073ba;
  font-size: 20px;
  line-height: 1.4;
  font-weight: 600;
  position: relative;
}
.faqList li .question:before {
  content: "Q";
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  display: inline-block;
  position: absolute;
  left: -40px;
  top: -10px;
}
.faqList li .answer {
  margin-top: 26px;
  font-size: 16px;
  line-height: 1.75;
  position: relative;
}
.faqList li .answer:before {
  content: "A";
  color: #0fd0c1;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 600;
  font-size: 30px;
  display: inline-block;
  position: absolute;
  left: -37px;
  top: -15px;
}

@media screen and (max-width: 767px) {
  .faqArea {
    padding: 50px 15px 50px;
  }
  .faqArea .bellTtl__jaImg {
    max-width: 220px;
  }
  .faqList {
    margin-top: -15px;
  }
  .faqList li {
    padding: 25px 20px 23px 55px;
  }
  .faqList li:before {
    width: 7px;
  }
  .faqList li .question {
    font-size: 18px;
  }
  .faqList li .question:before {
    font-size: 24px;
    left: -30px;
    top: -5px;
  }
  .faqList li .answer {
    margin-top: 20px;
    font-size: 14px;
  }
  .faqList li .answer:before {
    font-size: 26px;
    left: -28px;
    top: -13px;
  }
}
/**********************************************************

accessArea

***********************************************************/
.accessMap {
  margin: 0 0 20px 0;
  position: relative;
}
.accessMap iframe {
  width: 100%;
  height: 800px;
}

.boardImg {
  position: absolute;
  right: 0;
  bottom: 0;
}

.accessList {
  display: flex;
  justify-content: space-between;
  margin: 0 0 40px 0;
}

.accessList__item {
  width: 248px;
  margin: 0 5px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0px 3px 6px 0px rgba(103, 103, 103, 0.1);
  background-color: #fff;
}

.accessList__station {
  padding: 15px 15px;
  background: rgb(2, 119, 232);
  background: linear-gradient(128deg, rgb(2, 119, 232) 0%, rgb(0, 177, 208) 100%);
  color: #fff;
}

.accessList__station-cat {
  margin: 0 0 2px 0;
  font-size: 13px;
  text-align: center;
}

.accessList__station-name {
  font-size: 22px;
  text-align: center;
  font-weight: bold;
}

.accessList__walk {
  padding: 15px 15px;
  font-size: 16px;
  text-align: center;
}

.accessList__walk-num {
  font-size: 18px;
}

.accessMainTxt {
  font-size: 18px;
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .accessArea .bellTtl__jaImg {
    height: 25px;
  }
  .accessMap {
    margin: 0 0 20px 0;
    position: relative;
  }
  .accessMap iframe {
    width: 100%;
    height: 500px;
  }
  .boardImg {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 180px;
  }
  .accessList {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 -8px 20px;
    width: auto;
  }
  .accessList__item {
    width: calc(50% - 16px);
    margin: 0 8px 15px;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0px 3px 6px 0px rgba(103, 103, 103, 0.1);
    background-color: #fff;
  }
  .accessList__station {
    padding: 10px 10px;
    background: rgb(2, 119, 232);
    background: linear-gradient(128deg, rgb(2, 119, 232) 0%, rgb(0, 177, 208) 100%);
    color: #fff;
  }
  .accessList__station-cat {
    margin: 0 0 0px 0;
    font-size: 12px;
    text-align: center;
  }
  .accessList__station-name {
    font-size: 16px;
    text-align: center;
    font-weight: bold;
  }
  .accessList__walk {
    padding: 10px 10px;
    font-size: 16px;
    text-align: center;
  }
  .accessList__walk-num {
    font-size: 16px;
  }
  .accessMainTxt {
    font-size: 15px;
    line-height: 1.7;
  }
}
/**********************************************************

gallery

***********************************************************/
.galleryArea {
  padding: 86px 0;
  background-color: #f2f7f7;
}

.gallerySlider__item {
  padding: 0 15px;
}

.gallerySlider__img {
  width: 509px;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

.gallerySisaBox {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 50;
  pointer-events: none;
}

.gallerySisaLeft {
  width: 250px;
}

.gallerySisaright {
  width: 218px;
}

@media screen and (max-width: 767px) {
  .galleryArea {
    padding: 50px 0;
    background-color: #f2f7f7;
  }
  .gallerySlider:hover {
    cursor: pointer;
  }
  .gallerySlider__item {
    padding: 0 8px;
  }
  .gallerySlider__img {
    width: 300px;
  }
  .gallerySisaBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
  }
  .gallerySisaLeft {
    width: 100px;
  }
  .gallerySisaright {
    width: 100px;
  }
}/*# sourceMappingURL=pr_style.css.map */
