/*-----------------------
TOP注意書き
------------------------*/
.p-result {
    text-align: center;
    padding-top: 3.6rem;
    border: 2px solid #e7355c;
    padding: 2rem;
    background: #FFEDED;
    width: 90%;
    margin: 2rem auto;
}

/*-----------------------
kv
------------------------*/
.p-kv--user {
}

.p-kv--user__img {
  max-width: 1366px;
  margin: auto;
}

@media screen and (max-width: 992px) {
  .p-kv:after {
    top: 114px;
  }
}
@media screen and (max-width: 768px) {
  .p-kv:after {
    top: 88px;
  }
}

/*-----------------------
申し込み期間
------------------------*/
.p-top {
  background-color: var(--sub);
  position: relative;
}

.p-top p {
  color: var(--main-user);
  font-size: 3rem;
  align-items: center;
  padding: 0.5rem;
}

.p-top p.flex {
  display: inline-flex;
}

.p-top:after {
  content: "";
  position: absolute;
  background-size: contain;
  background-repeat: repeat-x;
  background-image: url("/img/top-bg__top.png");
  top: 0;
  padding: 100px 0;
  width: 100%;
}

.p-top p.t-red {
  color: var(--red);
}

.p-top__overview {
  width: 70%;
  margin: auto;
  padding: 3rem 0;
}

@media screen and (max-width: 768px) {
  .p-top .c-box {
    padding: 1rem;
  }

  .block_500 {
    display: block;
  }

  .p-top {
    padding-bottom: 20px;
  }

  .p-top p {
    font-size: 3rem;
  }

  .p-top:after {
    padding: 60px 0;
  }
  .p-top .flex {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .p-top__overview {
    width: 80%;
  }
}

/*-----------------------
お申し込みの流れ
------------------------*/
.p-flow .p-flow__steps {
  display: flex;
}

.p-flow .p-flow__steps .step_desc{
    border-top: 2px solid rgba(35, 24, 21, 0.5);
}

.p-flow .c-box .step_img {
  max-width: 300px;
  width: 70%;
  margin: 2rem auto 0;
}

.p-flow .c-box .step_img img {
  width: 100%;
}

.p-flow .p-big_purchase_btn {
  background-image: url("/img/purchase_btn_bg.png");
  background-repeat: no-repeat;
  background-size: 100%;
  color: #FFF23F;
  font-size: 4rem;
  line-height: calc(78px + 3.8rem);
  padding: 2rem;
  width: 682px;
  height: 157px;
  display: block;
  margin: auto;
  position: relative;
}
.p-flow .p-big_purchase_btn:before {
  background-image: url("/img/purchase_btn_deco_01.png");
  left: 20px;
}
.p-flow .p-big_purchase_btn:after {
  background-image: url("/img/purchase_btn_deco_02.png");
  right: 20px;
}
.p-flow .p-big_purchase_btn:after,
.p-flow .p-big_purchase_btn:before{
  position: absolute;
  content: "";
  width: 62px;
  height: 79px;
  background-size: contain;
  background-repeat: no-repeat;
  top: 50%;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}

@media screen and (max-width: 768px) {
  .p-flow {
    padding-bottom: 20px;
  }

  .p-flow .c-box .step_img {
    max-width: 200px;
    width: 90%;
  }

  .p-flow .c-box .step_img2 {
    max-width: 180px;
    width: 80%;
  }

  .step_desc {
    font-size: 2.4rem;
  }
  .p-flow .c-base_btn .c-btn_shadow.c-base_btn--main-user {
    background-image: url("/img/purchase__btn__cover.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right;
    color: var(--yellow);
    max-width: 330px;
    width: 100%;
    font-size: 3rem;
  }
  .p-flow .p-big_purchase_btn {
    width: 100%;
  }
}

@media screen and (max-width: 600px) {
  .p-flow .p-big_purchase_btn {
    height: 82px;
    line-height: calc(20px + 3rem);
    font-size: 3rem;
  }
  .p-flow .p-big_purchase_btn:after, .p-flow .p-big_purchase_btn:before {
    width: 32px;
    height: 49px;
  }
  .p-flow .p-big_purchase_btn:before {
    left: 10px;
  }
  .p-flow .p-big_purchase_btn:after {
    right: 10px;
  }
  .p-flow .p-flow__steps {
    display: block;
  }
}

/*-----------------------
利用方法
------------------------*/
.p-howto .c-flow__step--2col .c-flow__step__img {
  padding: 0 1rem;
}
.p-recommend__title {
  color: var(--degital);
  font-size: 2.8rem;
  margin-top: 4rem;
}
.p-recommend__list {
  display: flex;
  margin-top: 2rem;
  justify-content: space-between;
}
.p-recommend__list__item {
  font-size: 2rem;
}
.p-flow__tel a {
  font-size: 3rem;
}
.p-recommend__list__item__img {
  width: 30%;
}

@media screen and (max-width: 768px) {
  .p-recommend__list {
    display: block;
  }
  .p-recommend__list__item {
    margin-bottom: 2rem;
  }
  .p-recommend__list__item:last-of-type {
    margin-bottom: 0;
  }

  .p-recommend__list__item__img {
    width: 60%;
    margin: auto;
  }

}

/*-----------------------
使えるお店について
------------------------*/
.p-available {
  color: var(--text);
  padding-bottom: 60px;
}

.c-table th {
  border: 2px solid var(--main-user);
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-available {
    color: var(--text);
    padding-bottom: 0;
  }
}

/*-----------------------
注意事項
------------------------*/
.p-note .note_box {
  border: 1px solid #231815;
  text-align: left;
  padding: 3rem 2rem;
}

.p-note .note_box .note_box_title {
  font-size: 2.8rem;
}
.p-note .note_box .note_box_text {
  font-size: 1.6rem;
  font-weight: normal;
}
.p-note .note_box .note_box_text li {
  line-height: 2;
  font-weight: 600;
}
.p-note a {
  text-decoration: underline solid #58abf2;
  color: #58abf2;
}

@media screen and (max-width: 768px) {
  .p-note .note_box {
    margin-bottom: 0;
  }
}


/*-----------------------
事業者の方はこちら
------------------------*/
.c-section__bg--company {
  background: var(--bg-sub);
}

.p-company__title {
  color: var(--sub);
  font-size: 2.8rem;
}

.p-company--msg {
  font-size: 2.4rem;
  margin-top: 6rem;
}

/*-----------------------
お知らせ
------------------------*/
.p-news__wrapper {
  margin-bottom: 50px;
  padding: 4rem;
}

/* kvのDL禁止 */
.no_dl{
  pointer-events: none;
  -webkit-touch-callout:none;
  -webkit-user-select:none;
  -moz-touch-callout:none;
  -moz-user-select:none;
  user-select:none;
}