/* ==========================================================================
 *
 * 基礎コンポーネント
 *
========================================================================== */


/* ==========================================================================
 *
 * 構造定義
 *
========================================================================== */


/* section
-------------------------------------*/

.section {
  position: relative;
  padding: 40px 0 60px;
}
.section__inner {
  margin: auto;
  max-width: 768px;
  padding: 0 25px;
}
.section__head {
  margin: 0 auto 40px;
  text-align: center;
}
@media screen and (max-width:768px){
}

/* footer
-------------------------------------*/
.footer {
  padding: 90px 20px;
  background: #6C7882;
}
.footer p {
  text-align: center;
  color: #FFFFFF;
}
.footer a {
  color: #FFFFFF;
  text-decoration: underline;
}

.footer__head {
  margin-bottom: 30px;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.08em;
}
.footer__copy {
  font-size: 12px;
  letter-spacing: 0.08em;
}

/* ==========================================================================
 *
 * コンポーネント
 *
========================================================================== */
/* section-store
-------------------------------------*/
.store-slider__outer {
  overflow: hidden;
  margin-bottom: 25px;
}
.store-slider {
  overflow: visible;
}

.store-slider--harf ul {
  margin-left: -70px;
}

.store-slider .swiper-wrapper{
  transition-timing-function: linear;
  pointer-events: none;
}
.store-slider .swiper-slide {
  width: max-content;
}

.store-slider .swiper-slide img {
  width: 138px;
}
.store-slider--indent .swiper-slide img {
  transform: translate(-50%,0);
}

@media screen and (max-width: 768px) {
  .store-slider__list .slick-slide img{
    max-height: 44px;
  }
} /* end less SP */

/* suggest-block
-------------------------------------*/
.suggest-block__wrapper {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 20px;
}
.suggest-block {
  position: relative;
  overflow: hidden;

  border-radius: 5px;
  background: #73D3EB;
  border: 1px solid #73D3EB;
}
.suggest-block__head {
  display: block;
  padding: 10px 20px 10px 60px;
  color: #3D3D3D;
  font-size: 18px;
  cursor: pointer;
}
.suggest-block__head:before {
  content: "";
  display: block;
  height: 30px;
  width: 30px;

  position: absolute;
  left: 16px;
  top: 10px;
  background: #FFF;
  border: 2px solid #3D3D3D;
}
.suggest-block__head:after {
  content: "";
  display: block;
  height: 8px;
  width: 18px;
  position: absolute;
  left: 24px;
  top: 17px;

  border: 1px solid #0092CC;
  border-width: 4px 4px 0 0;
  transform: rotate(135deg);

  opacity: 0;
  transition: opacity 0.2s;
}
.suggest-block--expand .suggest-block__head:after{
  opacity: 1;
}
.suggest-block__content {
  background: #FFF;
  padding: 0px 10px 0px 50px;

  line-height: 0;
  opacity: 0;

  transition: line-height 0.4s, padding 0.4s, opacity 0.4s;
  pointer-events: none;
}
.suggest-block--expand .suggest-block__content{
  padding: 10px 10px 10px 50px;

  line-height: 2.0;
  opacity: 1;
  pointer-events: initial;
}

/* phone-slider
-------------------------------------*/
.phone-slider__outer {
  position: relative;

  height: 545px;
  width: 300px;
  margin: 0 auto;
  padding: 30px 15px 0;
  background: url(../images/phone_bg.png);
  background-size: 300px 545px;
}
.phone-slider {
  overflow: hidden;
}
.phone-slider .swiper-slide img {
  height: 484px;
  width: 268px;
}

.phone-slider__controller {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 0;
  transform: translate(0,-50%);
  width: 100%;
}
.phone-slider__button-prev,
.phone-slider__button-next {
  position: absolute;
  z-index: 1;
  top: 0;
  bottom: 0;
  margin: auto;

  height: 40px;
  width: 40px;
  background: url(../images/icon_ctrl-blue_right.svg);
  background-size: contain;
}
.phone-slider__button-prev {
  left: -10px;
  transform: rotate(180deg);
}
.phone-slider__button-next {
  right: -10px;
}

/* qa
-------------------------------------*/
.qa-item__outer {
  max-width: 768px;
  margin: 0 auto;
}
.qa-item {
  padding: 20px 0;
  border: 1px solid #5A5A5A;
  border-width: 1px 0 0;
}
.qa-item:last-child {
  border-width: 1px 0;
}
.qa-item__title {
  position: relative;
  font-size: 20px;
  font-weight: 400;
  margin-bottom: 24px;
  padding-left: 45px;
  color: #5A5A5A;
}
.qa-item__title:before {
  content: "";
  display: block;

  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0,-50%);

  height: 30px;
  width: 30px;
  background: url(../images/icon_q.svg);
  background-size: contain;
}
.qa-item__content {
}

/* ==========================================================================
 *
 * 各種セクション
 *
========================================================================== */
/* firstview */
.firstview {
  background: #73D3EB;
}
.firstview__inner {
  position: relative;
  max-width: 768px;
  padding: 70px 60px 20px;
  margin: 0 auto;
}
.firstview__lead {
  margin-bottom: 35px;
}
.firstview__logo {
  margin-bottom: 184px;
}
.firstview__user {
  position: absolute;
  top: 87px;
  right: 30px;
}
.firstview__illust {
  position: absolute;
  bottom: 142px;
  right: 84px;
}
.firstview__illust img{
  width: 270px;
}

.firstview__cta {
  max-width: 335px;
  margin: 70px auto 0;
}
.firstview__agreement{
  margin: 0 8px 8px;
  padding: 4px;
  background: rgba(255,255,255,0.2);
  font-size: 10px;
  color: #FFFFFF;
}
@media only screen and (max-width: 768px) {
  .firstview__inner {
    max-width: 375px;
    padding: 40px 20px 32px;
  }
  .firstview__lead {
    margin-bottom: 20px;
  }
  .firstview__logo {
    margin-bottom: 20px;
  }

  .firstview__user {
    position: initial;
    top: initial;
    right: initial;
  }
  .firstview__illust {
    bottom: 156px;
    right: 6px;
  }
  .firstview__illust img{
    width: 202px;
  }

  .firstview__cta {
    margin: 65px auto 0;
  }

}

.firstview__cta {
  width: 100%;
}
.firstview__cta a {
  display: block;
  margin: 0 auto;
  padding: 12px;

  background: #f1f384;
  border: #3d3d3d 2px solid;
  border-width: 2px 2px 4px;
  border-radius: 24px;

  text-align: center;
  font-size: 20px;
  color: #3d3d3d;
  font-weight: 700;
  line-height: 1;
  transition: all .3s ease-out;
}

/* store */
.section-store {
  padding: 30px 0 30px;
  background: url(../images/store_bg.png);
  background-size: 15%;
}

/* about */
.section-about {
  overflow: hidden;
}
.section-about .section__inner{
  position: relative;
  z-index: 2;
}
.section-about::after {
  content: "";
  display: block;

  position: absolute;
  z-index: 0;
  bottom: 150px;
  left: 50%;
  background: #DFF9FF;
  height: 300px;
  width: 150%;

  transform: translate(-50%,0) rotate(-25deg);
}
.section-about__list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 20px;
}

/* problem */
.section-problem {
  background: #ECECEC;
}
.section-problem__list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 20px;
}

/* merit */
.section-merit {
  background: #0092CC;
}
.section-merit__list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
@media only screen and (max-width: 768px) {
  .section-merit__list {
    flex-direction: column;
  }
}

/* register */
.section-register {
  background: #DFF9FF;
}

/* payment */
.section-payment {}
.section-payment__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 20px;

  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .section-payment__list {
    max-width: 335px;
  }
}
@media only screen and (max-width: 400px) {
  .section-payment__list li{
    max-width: 45%;
  }
}

/* qa */
.section-qa {}
.section-qa .section__head {
  margin-bottom: 30px;

  text-align: left;
  font-size: 28px;
  font-weight: 400;
  color: #5A5A5A;
}

/* fixed-cta */
.fixed-cta {
}

.fixed-cta__button {}
.fixed-cta__button a{
}

.p-fixed-cta a {
  display: block;
  margin: 0 auto;
  width: 355px;
  padding: 12px;
  background: #f1f384;
  border: #3d3d3d 2px solid;
  border-radius: 24px;
  text-align: center;
  font-size: 16px;
  color: #3d3d3d;
  font-weight: 700;
  line-height: 1;
  transition: all .3s ease-out
}

@media only screen and (min-width: 769px) {
  .p-fixed-cta {
      position:fixed;
      bottom: 60px;
      right: 40px;
      z-index: 5;
      transform: translateY(150%);

      transition: all .3s ease-out;
  }

  .p-fixed-cta :hover {
      transform: translateY(-2px)
  }

  .p-fixed-cta .p-cta-button a {
      display: flex;
      justify-content: center;
      align-items: center;
      flex-direction: column;
      gap: 8px;
      height: 120px;
      width: 120px;
      border-radius: 50%
  }

  .p-fixed-cta span {
      display: block
  }

  .p-fixed-cta span:nth-child(1) {
      font-weight: 400;
      font-size: 16px;
  }
  .p-fixed-cta span:nth-child(2) {
    font-weight: 700;
    font-size: 20px;
  }
  .p-fixed-cta span:nth-child(3) {
      font-weight: 700;
      font-size: 20px;
  }

  .p-fixed-cta.active {
    transform: translateY(0);
  }
}

@media only screen and (max-width: 768px) {
  .p-fixed-cta {
      position:fixed;
      bottom: 0;
      left: 0;
      z-index: 5;
      width: 100%;
      padding: 15px 10px 20px;
      background: rgba(255,255,255,.7);
      transform: translateY(100%);
      transition: all .3s ease-out;
  }

  .p-fixed-cta.active {
      transform: translateY(0);
  }
}