@charset "utf-8";

/* ---------------
  common 
------------------*/
:root {
  --spp: 24px;
  --tbp: 32px;
  --pcp: 48px;
}

.container {
  padding: 0 var(--spp);
}

.pc_only {
  display: none;
}

.anchor {
  padding-top: 80px;
  margin-top: -80px;
}

@media all and (min-width: 767px) {
  .container {
    padding: 0 var(--tbp);
  }

  .pc_only {
    display: initial;
  }

  .sp_only {
    display: none;
  }
}

@media all and (min-width: 1024px) {
  .container {
    padding: 0 var(--pcp);
  }
}

/* ---------------------
  grobal navigation
------------------------ */
@media screen and (min-width: 1024px) {
  .navigation-main {
    justify-content: end;
    padding-right: var(--pcp);
  }
}

.footer-navigation__title {
  grid-template-columns: 1fr;
}

/* ---------------------
  kv
------------------------ */
.kv {
  background-color: #f8f8f8;
}

.kv_cont {
  max-width: 740px;
  margin: 0 auto;
}

.kv_img img {
  width: 100%;
  object-fit: contain;
}

.kv_desc {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.85;
  margin: 10px 0 30px;
}

.kv_date {
  text-align: center;
  padding-bottom: 20px;
}

.kv_attention {
  margin-top: 10px;
}

@media all and (min-width: 768px) {
  .kv_attention {
    text-align: center;
  }
}

/* ---------------------
  about
------------------------ */
.about {
  padding-top: 60px;
}

.bonus_ttl {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 10px;
}

.bonus_ttl .bonus_ttl_lead {
  font-size: 16px;
  letter-spacing: 3px;
}

.about .bonus_ttl {
  margin-bottom: 60px;
}

.text_red {
  color: #DA0024;
}

.about_list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  padding: 0;
  max-width: 1300px;
  margin: 0 auto;
}

.about_item img {
  width: 100%;
  object-fit: contain;
}

@media all and (min-width: 768px) {
  .about_list {
    flex-direction: row;
  }

  .about_item {
    flex: 1;
  }
}


/* ---------------------
  bonus1
------------------------ */
.bonus1 {
  padding: 60px 0;
}

.bonus_ttl_num {
  font-size: 76px;
}

.bonus_date {
  font-size: min(4vw, 20px);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #e6e6e6;
  padding-top: 20px;
  padding-bottom: 20px;
  line-height: 1;
  margin-bottom: 0;
}

.bonus_date time {
  line-height: 1;
}

.bonus_date span {
  font-size: min(8vw, 48px);
}

.bonus_date img {
  transform: scale(0.5);
}

.bonus_cont {
  background-color: #f8f8f8;
  padding: 30px 0;
  font-size: 32px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 10px;
  flex-wrap: wrap;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 5px;
}

.bonus_cont strong {
  font-size:min(22vw, 104px);
  width: 100vw;
  transform: translate(0, 10px);
}

.bonus_attention {
  text-align: center;
  margin-bottom: 60px;
}

.product_ttl {
  text-align: center;
  font-size: 12px;
  color: #808080;
  line-height: 1.2;
  margin-bottom: 60px;
}

.product_list {
  display: flex;
  flex-direction: column;
  gap: 60px 14px;
  list-style: none;
  padding: 0;
}

.product_ttl span {
  color: #000;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 3px;
}

.product_item {
  width: 100%;
}

.product_item_ttl {
  text-align: center;
  margin-bottom: 40px;
  line-height: 1;
}

.product_item_ttl img {
  height: 20px;
  object-fit: contain;
}

.product_box {
  border-radius: 22px;
  padding-bottom: 40px;
}

.slcn .product_box {
  background-color: #DDF5FF;
}

.oneday .product_box {
  background-color: #D1F1F3;
}

.product_box_cont p {
  font-size: min(6vw, 25px);
  font-weight: 700;
  margin-bottom: 14px;
}

.product_price {
  position: relative;
  width: fit-content;
}

.product_price_off {
  position: absolute;
  bottom: 75%;
  right: calc(-1 * var(--spp) / 2);
  width: 16vw;
  max-width: 86px;
}

.product_price_num {
  max-height: 110px;
  object-fit: contain;
  object-position: center;
}

.product_link_btn {
  text-decoration: none;
  display: inline-block;
  background-color: #fff;
  border-radius: 999px;
  border: 1px solid #E6E6E6;
  text-align: center;
  padding: .25em 1em;
  transition: .3s;
}

.product_link_btn:hover {
  background-color: #000;
  color: #fff;
  border: 1px solid #000;
}

.product_link_btn + .product_link_btn {
  margin-left: 5px;
}



@media all and (min-width: 768px) {
  .bonus1 {
    padding: 60px 0;
  }

  .bonus_date {
    flex-direction: row;
    justify-content: center;
  }

  .bonus_date img {
    transform: scale(1);
  }

  .bonus_cont {
    margin-bottom: 18px;
  }

  .bonus_attention_br {
    display: none;
  }

  .product_box_cont p {
    font-size: min(3vw, 25px);
  }
}

@media all and (min-width: 1024px) {
  .bonus_cont strong {
    width: auto;
  }

  .bonus_cont_br {
    display: none;
  }

  .product_item_ttl img {
    height: 31px;
  }

  .product_box {
    padding-bottom: 60px;
  }

  .product_list {
    flex-direction: row;
    align-items: stretch;
    max-width: 1300px;
    margin: 0 auto;
  }
}


/* ---------------------
  bonus2
------------------------ */
.bonus_cont:has(.bonus_cont_b2) {
  margin-bottom: 60px;
}

.bonus_cont_tl {
  display: block;
  text-align: left;
}

.bonus_cont_b2 strong {
  position: relative;
}

.bonus_cont_b2 strong img {
  position: absolute;
  bottom: 100%;
  right: 0;
  width: calc(100% - 210px);
}

.product_list_b2 {
  justify-content: center;
  margin-bottom: 60px;
}

@media all and (min-width: 1024px) {
  .bonus_cont_b2 {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .bonus_cont_b2 strong img {
    width: 160px;
  }

  .bonus_cont_b2 strong {
    width: auto;
  }

  .bonus_cont_tl_br {
    display: none;
  }

  .product_list_b2 .product_item {
    max-width: 648px;
  }
}

/* ---------------------
  teiki
------------------------ */
.teiki {
  padding-top: 60px;
  padding-bottom: 60px;
  background-color: #f8f8f8;
  text-align: center;
}

.teiki_ttl {
  font-size: 25px;
  margin-bottom: 30px;
  font-weight: 700;
  line-height: 2.5;
}

.teiki_desc {
  font-size: 23px;
  font-weight: 700;
  margin-bottom: 30px;
}

.teiki_plan {
  background-color: #fff;
  border-radius: 15px;
  padding: 25px;
  max-width: 780px;
  margin: 0 auto 15px;
}

.teiki_plan_desc {
  margin-bottom: 15px;
  font-size: 16.5px;
}

.teiki_plan_desc strong {
  font-weight: 700;
  font-size: 21px;
  line-height: 1.25;
  position: relative;
}

.teiki_plan_desc strong span {
  font-size: 32px;
}

.sarani.teiki_plan_desc {
  padding-top: 80px;
}

.sarani.teiki_plan_desc strong img {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-100%, -100%);
  height: 70px;
}

.teiki_attention {
  max-width: 780px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  text-align: left;
  font-size: 12px;
}

@media all and (min-width: 768px) {
  .sarani.teiki_plan_desc {
    padding-top: 0;
  }

  .sarani.teiki_plan_desc strong img {
    top: 50%;
    left: 0;
    transform: translate(-100%, -68%);
  }
}

/* ---------------------
  howto
------------------------ */
.howto {
  padding-top: 60px;
}

.howto_ttl {
  text-align: center;
  font-weight: 700;
  font-size: 24px;
  margin-bottom: 60px;
  letter-spacing: 3px;
}

.howto_list {
  list-style: none;
  margin-bottom: 60px;
}

.howto_list li + li {
  margin-top: 15px;
}

.howto .bonus_cont {
  margin-bottom: 15px!important;
}

.howto .howto_cont {
  max-width: 800px;
  margin: 20px auto;
}

.howto_list {
  padding: 0;
}

@media all and (min-width: 768px) {
  .howto_list {
    display: flex;
    justify-content: center;
  }

  .howto_list li {
    max-width: 370px;
  }

  .howto_list li + li {
    margin-top: 0;
  }
}

