.p-bg {
  background: #d7eaf8;
  padding: 8rem 0 0;
}
@media screen and (max-width: 767px) {
  .p-bg {
    padding: 3.75rem 0 0;
  }
}

.p-mv {
  margin: 0 0 6rem;
}
@media screen and (max-width: 767px) {
  .p-mv {
    padding: 0 1.9rem;
    margin: 0 0 5rem;
  }
}
.p-mv__wrap {
  max-width: 93.5rem;
  margin: 0 auto;
}
.p-mv__profile {
  position: relative;
  margin: -7rem 3.6rem 0 auto;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-mv__profile {
    margin: -7.2rem auto 0;
  }
}

.p-principles-head {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  gap: 1.5rem;
  max-width: 93.5rem;
  margin: 0 auto;
  padding: 0 0 5.6rem;
}
@media screen and (max-width: 767px) {
  .p-principles-head {
    flex-flow: column;
    align-items: flex-start;
    padding: 0 1.9rem;
    margin: 0 auto 4.4rem;
  }
}
.p-principles-head__en {
  width: 11.7rem;
  line-height: 0;
}
.p-principles-head__ttl {
  font-size: 3.6rem;
  font-weight: 900;
  line-height: 1;
  color: #308ddb;
}
.p-principles-head__small {
  font-size: 3rem;
}
.p-principles-block {
  background: #fff;
}
.p-principles-block__wrap {
  position: relative;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  max-width: 93.5rem;
  gap: 0 5rem;
  margin: 0 auto;
  padding: 7.3rem 0;
}
@media screen and (max-width: 767px) {
  .p-principles-block__wrap {
    flex-flow: column;
    gap: 3rem 0;
    padding: 2rem 1.9rem 5rem;
  }
}
.p-principles-block__wrap::before {
  content: "";
  position: absolute;
  top: -2rem;
  left: 14rem;
  width: 5rem;
  height: 2.4rem;
  background: #fff;
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}
.p-principles-block__img {
  display: block;
  width: 38rem;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .p-principles-block__img {
    width: 100%;
  }
}

.p-faq + .p-faq {
  margin-top: 9rem;
}
@media screen and (max-width: 767px) {
  .p-faq + .p-faq {
    margin-top: 6rem;
  }
}
.p-faq__block {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.p-faq__block--question {
  margin: 0 0 4rem;
}
@media screen and (max-width: 767px) {
  .p-faq__block--question {
    margin: 0 0 2rem;
  }
}
.p-faq__block--question .p-faq__txt {
  font-size: 2.8rem;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding-top: 1rem;
}
@media screen and (max-width: 767px) {
  .p-faq__block--question .p-faq__txt {
    font-size: 2.6rem;
    line-height: 1.5;
    letter-spacing: 0.05em;
    padding-top: 0.2rem;
  }
}
@media screen and (min-width: 768px) {
  .p-faq__block--question .p-faq__txt--long {
    width: calc(100% - 6rem + 1em);
    margin-right: -1em;
  }
}
.p-faq__en {
  width: 6rem;
  font-size: 6rem;
  line-height: 1;
  font-weight: 700;
  color: #308ddb;
}
@media screen and (max-width: 767px) {
  .p-faq__en {
    width: 4rem;
    font-size: 4rem;
  }
}
.p-faq__txt {
  width: calc(100% - 6rem);
  line-height: 2.25;
  letter-spacing: 0.12em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-faq__txt {
    width: calc(100% - 4rem);
    line-height: 1.9;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
  }
}
.p-faq__notes {
  display: block;
  font-size: 1.2rem;
}
@media screen and (max-width: 767px) {
  .p-faq__notes {
    font-size: 1rem;
  }
}

.p-step {
  max-width: 93.5rem;
  margin: 0 auto;
  padding: 8rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .p-step {
    padding: 5.2rem 1.9rem 6rem;
  }
}
.p-step-head {
  margin: 0 0 1.4rem;
}
@media screen and (max-width: 767px) {
  .p-step-head {
    margin: 0 0 1.6rem;
  }
}
.p-step-head__en {
  width: 7.5rem;
  line-height: 0;
  margin: 0 0 1.2rem;
}
@media screen and (max-width: 767px) {
  .p-step-head__en {
    margin: 0 0 0.9rem;
  }
}
.p-step-head__ttl {
  font-size: 2.8rem;
  line-height: 1;
  color: #308ddb;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.p-step-image {
  position: relative;
  background: #fff;
  padding: 4.5rem 6rem 5rem;
  margin: 0 0 9.8rem;
}
@media screen and (max-width: 767px) {
  .p-step-image {
    padding: 3rem 1.8rem 2.7rem;
    margin: 0 0 6rem;
  }
}
.p-step-image-list {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
}
.p-step-image-list__item {
  width: 33.3333333333%;
}
.p-step-image-list__item--middle .p-step-image-list__txt {
  height: 22rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__item--middle .p-step-image-list__txt {
    height: 19.5rem;
  }
}
.p-step-image-list__item--now .p-step-image-list__txt {
  height: 27rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__item--now .p-step-image-list__txt {
    height: 23rem;
  }
}
.p-step-image-list__ttl {
  position: relative;
  font-weight: 700;
  color: #308ddb;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1;
  letter-spacing: 0.1em;
  padding: 0 0 1.2rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__ttl {
    font-size: 1rem;
  }
}
.p-step-image-list__ttl::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: calc(100% - 0.6rem);
  height: 0.2rem;
  background: #308ddb;
}
.p-step-image-list__ttl::after {
  content: "";
  position: absolute;
  bottom: -0.4rem;
  right: 0;
  width: 0.9rem;
  height: 1rem;
  background: #308ddb;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}
.p-step-image-list__num {
  font-size: 2.8rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__num {
    font-size: 1.5rem;
  }
}
.p-step-image-list__num--now {
  font-size: 2.2rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__num--now {
    font-size: 1.3rem;
  }
}
.p-step-image-list__txt {
  background: #F7FBFE;
  line-height: 2;
  letter-spacing: 0.12em;
  padding: 3.2rem 3.5rem;
}
@media screen and (max-width: 767px) {
  .p-step-image-list__txt {
    font-size: 1.2rem;
    line-height: 1.6;
    letter-spacing: 0.04em;
    padding: 1.6rem 0.8rem;
  }
}
.p-step-image__img {
  position: absolute;
  bottom: 0;
  right: 5rem;
  width: 15rem;
}
@media screen and (max-width: 767px) {
  .p-step-image__img {
    right: 1.5rem;
    width: 7.5rem;
  }
}

.p-schedule {
  padding: 8rem 0 8rem;
}
@media screen and (max-width: 767px) {
  .p-schedule {
    visibility: visible;
    padding: 0 0 4.5rem;
  }
}
.p-schedule__wrap {
  max-width: 93.5rem;
  margin: 0 auto;
}
.p-schedule__slider {
  position: relative;
  background: #fff;
  padding: 5rem 0;
}
@media screen and (max-width: 767px) {
  .p-schedule__slider {
    padding: 3rem 0 9.5rem 0;
  }
}
.p-schedule__slider .splide__track {
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .p-schedule__slider .splide__track {
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 0 0 1.9rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .p-schedule__slider .splide__track::-webkit-scrollbar {
    display: none;
  }
}
.p-schedule__inner {
  margin-left: max(2rem, (100% - 93.5rem) / 2);
  width: 110rem;
}
@media screen and (max-width: 1240px) {
  .p-schedule__inner {
    width: 93.5rem;
  }
}
@media screen and (max-width: 767px) {
  .p-schedule__inner {
    width: 100%;
    margin: 0;
    padding: 0 1.9rem 0 0;
  }
}
.p-schedule-head {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  margin: 0 0 3rem;
}
@media screen and (max-width: 767px) {
  .p-schedule-head {
    padding: 0 1.9rem;
    margin: 0 0 3rem;
  }
}
.p-schedule-head__en {
  width: 8.7rem;
  line-height: 0;
  margin: 0 0 1.2rem;
}
.p-schedule-head__ttl {
  font-size: 2.8rem;
  line-height: 1;
  color: #308ddb;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.p-schedule-head__btns {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  gap: 0 2rem;
}
@media screen and (max-width: 767px) {
  .p-schedule-head__btns {
    display: none;
  }
}
.p-schedule-head__btn {
  position: relative;
  left: auto;
  right: auto;
  width: 13rem;
  height: 3.2rem;
  background: #fff;
  border: 1px solid #308ddb;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-align: center;
  border-radius: 2rem;
  transition: 0.3s;
  transform: none;
}
.p-schedule-head__btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -2rem;
  width: 4rem;
  height: 0.4rem;
  background: url(../img/persons/icn_arrow.svg) 0 0/100% 100% no-repeat;
  margin-top: -0.2rem;
  transition: 0.3s;
}
.p-schedule-head__btn:disabled {
  pointer-events: none;
}
.p-schedule-head__btn--next::before {
  left: auto;
  right: -2rem;
  transform: scale(-1, 1);
}
@media (any-hover: hover) {
  .p-schedule-head__btn:hover {
    background: #308ddb;
    color: #fff;
  }
  .p-schedule-head__btn:hover::before {
    filter: brightness(0) invert(1);
  }
}
.p-schedule-slide__item {
  width: 33rem;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__item {
    width: 23rem;
  }
}
.p-schedule-slide__head {
  position: relative;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0 2rem;
  padding: 0 0 3.2rem;
  margin: 0 0 3.5rem;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__head {
    gap: 0 1rem;
    padding: 0 0 1.6rem;
    margin: 0 0 2rem;
  }
}
.p-schedule-slide__head::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0.2rem;
  background: #308ddb;
}
.p-schedule-slide__head::after {
  content: "";
  position: absolute;
  bottom: -0.9rem;
  left: 0;
  width: 1.8rem;
  height: 2rem;
  background: #308ddb;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__head::after {
    bottom: -0.4rem;
    width: 0.9rem;
    height: 1rem;
  }
}
.p-schedule-slide__icn {
  width: 3rem;
  height: auto;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__icn {
    width: 2.5rem;
  }
}
.p-schedule-slide__time {
  font-size: 2.8rem;
  letter-spacing: 0.05em;
  line-height: 1;
  font-weight: 700;
  color: #308ddb;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__time {
    font-size: 1.8rem;
  }
}
.p-schedule-slide__ttl {
  font-size: 2.4rem;
  line-height: 1.6;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin: 0 0 0.6rem;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__ttl {
    font-size: 1.6rem;
  }
}
.p-schedule-slide__txt {
  letter-spacing: 0.12em;
  padding: 0 6rem 0 0;
}
@media screen and (max-width: 767px) {
  .p-schedule-slide__txt {
    font-size: 1.2rem;
    padding: 0 4rem 0 0;
  }
}
.p-schedule-guide {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-schedule-guide {
    display: block;
    pointer-events: none;
    position: absolute;
    bottom: 6rem;
    left: 50%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    flex-flow: column;
    gap: 0.8rem 0;
    width: 11rem;
    height: 9rem;
    background: rgba(62, 58, 57, 0.7);
    border-radius: 0.5rem;
    transform: translateX(-50%);
    transition: 0.3s;
  }
  .p-schedule-guide.is-hidden {
    opacity: 0;
  }
}
.p-schedule-guide__icn {
  width: 4rem;
  margin-right: 1.3rem;
  animation: scheduleGuideSwipe 1.8s ease-in-out infinite;
}
.p-schedule-guide__txt {
  color: #fff;
  font-size: 1rem;
  line-height: 1;
  font-weight: 500;
}
.p-schedule-bar {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-schedule-bar {
    display: block;
    pointer-events: none;
    position: absolute;
    bottom: 2.5rem;
    left: 50%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 31rem;
    height: 1rem;
    border-radius: 0.5rem;
    transform: translateX(-50%);
  }
  .p-schedule-bar.is-hidden {
    opacity: 0;
  }
}
.p-schedule-bar__arrow {
  display: block;
  width: 0.8rem;
  height: 1rem;
  background: rgba(62, 58, 57, 0.7);
}
.p-schedule-bar__arrow--next {
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}
.p-schedule-bar__arrow--prev {
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
}
.p-schedule-bar__track {
  position: relative;
  display: block;
  width: calc(100% - 3.2rem);
  height: 1rem;
}
.p-schedule-bar__thumb {
  position: absolute;
  top: 0;
  left: 0;
  height: 1rem;
  border-radius: 2rem;
  background: rgba(62, 58, 57, 0.7);
}
.p-schedule__btn {
  width: 23rem;
  height: 3.2rem;
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  margin: 8rem auto 0;
}
@media screen and (max-width: 767px) {
  .p-schedule__btn {
    width: calc(100% - 7.4rem);
    height: 3.85rem;
    font-size: 1.6rem;
    margin: 5rem auto 0;
  }
}
.p-schedule__btn a {
  position: relative;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  border: 1px solid #308ddb;
  border-radius: 5rem;
  background: #fff;
  color: #308ddb;
  padding: 0 0 0.2rem;
}
@media (any-hover: hover) {
  .p-schedule__btn a:hover {
    background: #308ddb;
    color: #fff;
    opacity: 1;
  }
  .p-schedule__btn a:hover::before {
    filter: brightness(0) invert(1);
  }
}
.p-schedule__btn a:focus-visible, .p-schedule__btn a:active {
  background: #308ddb;
  color: #fff;
  opacity: 1;
}
.p-schedule__btn a:focus-visible::before, .p-schedule__btn a:active::before {
  filter: brightness(0) invert(1);
}
@media screen and (max-width: 767px) {
  .p-schedule__btn a {
    border: 1px solid #fff;
    background: #3064db;
    color: #fff;
  }
}
.p-schedule__btn a::before {
  content: "";
  position: absolute;
  top: 1.1rem;
  right: -2rem;
  width: 4rem;
  height: 0.4rem;
  background: url(../img/persons/icn_arrow.svg) 0 0/100% 100% no-repeat;
  transform: scale(-1, 1);
}
@media screen and (max-width: 767px) {
  .p-schedule__btn a::before {
    filter: brightness(0) invert(1);
  }
}
@media screen and (max-width: 767px) {
  .p-schedule__btn a::before {
    width: 4.8rem;
    height: 0.48rem;
  }
}

@keyframes scheduleGuideSwipe {
  0% {
    transform: translateX(0);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  30% {
    transform: translateX(1.2rem);
    opacity: 1;
  }
  50% {
    transform: translateX(-1.2rem);
    opacity: 1;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
  90% {
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 0;
  }
}