body {
  font-family: "Zen Maru Gothic", sans-serif;
  line-height: normal;
  color: var(--txt);
  min-width: 320px;
  margin-bottom: 160px!important;
}

:root {
  /* fonts */
  --font-rounded-mplus-1c: "M PLUS Rounded 1c";
  --font-noto-sans-jp: "Noto Sans JP";
  --font-size-xl: 20px;
  --font-size-4xl-9: 23.9px;
  /* Colors */
  --white: #fff;
  --txt: #3D3937;

  --color-black: #000;
  --color-lemonchiffon: #fff6E5;
  --color-yellow: #FFB432;
  --color-lemon: #FFFCF4;
  --color-orange: #FF8400;
  --color-beige: #F9F4F1;
  --color-red: #D62D26;
  --color-crimson: #D00E31;
  --color-pink: #FF5765;
  --color-skyblue: #B2C3EF;
  --color-blue: #406AD6;
  --color-navy: #002DC3;

  --btn-yellow: #F7E885;

  /* Paddings */
  --padding-5xl: 24px;
  --padding-xl: 20px;

  /* Border radiuses */
  --br-10xs: 3px;
  --br-100xl-4: 119.4px;
  --br-81xl: 100px;
  --br-3xs: 10px;
  --br-sm: 14px;
  --br-mini: 15px;
}

button {
  display: block;
  margin: auto;
  width: 100%;
}
img {
  width: 100%;
}
.pc {
  display: none;
}
.sp {
  display: block;
}
p a{
  text-decoration: underline;
}

footer{
  margin-top: 50px;
}

label{
  cursor: pointer;
}

.asterisk{
  font-size: 0.7em;
  vertical-align: top;
}

.inner {
  padding: 0 16px;
  margin: auto;
}
.fv {
  width: 100%;
}
.fv_bg {
  width: 100%;
  height: auto;
  text-align: center;
}
#main_fv {
  height: 100%;
  width: 100%;
  display: block;
  margin: 0 auto;
}
#main_fv img {
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
.parent-end_entry{
  padding: 75px 0 25px;
  text-align: center;
  font-weight: bold;
  color: var(--color-crimson);
  font-size: var(--font-size-4xl-9);
}
@media screen and (max-width: 768px) {
  .parent-end_entry{
    font-size: var(--font-size-xl);
  }
}
.parent {
  margin: 25px auto 0;
  background-color: var(--white);
  font-size: 1rem;
  text-align: center;
}
.parent .round_btn{
  margin-top: 20px;
}
.entry-chkboxWrap {
  font-weight: 500;
  font-size: 14px;
  text-align: center;
}
input[type="checkbox"] {
  margin: 0 10px 3px 0;
}
input[type="checkbox"] {
  position: relative;
  width: 16px;
  height: 16px;
  border: 1px solid var(--color-yellow);
  vertical-align: -5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 3px;
}
input[type="checkbox"]:checked {
  background: var(--color-yellow);
}
input[type="checkbox"]:checked:before {
  position: absolute;
  top: 1px;
  left: 4px;
  transform: rotate(50deg);
  width: 6px;
  height: 11px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  content: '';
}
.fv_btn.round_btn {
  background-color: #a7a7a7;
  pointer-events: none;
}
.fv_btn.entry-btnStyle_checked {
  background-color: #F0642D;
  pointer-events: auto;
}

.btn {
  border-radius: 9999px;
  width: min(100%, 296px);
  height: 64px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.25;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.btn::after {
  content: "";
  display: block;
  width: 21px;
  height: 21px;
  background: url(../public/btn_arrow_ye.svg) center / contain no-repeat;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}

/* ボタン */
.round_btn {
  display: block;
  width: min(100%, 296px);
  height: 64px;
  margin: 18px auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--white);
  font-size: 20px;
  font-weight: 500;
  font-style: normal;
  text-align: center;
  background: #F0642D;
  border-radius: 100px;
  position: relative;
}
.round_btn span {
  display: block;
}
.round_btn .txt {
  text-align: center;
}

.round_btn .small {
  font-size: 0.6em;
}
.round_btn .icon-dl,.round_btn .icon-or {
  position: absolute;
  width: 21px;
  height: 21px;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}
.round_btn .icon-or {
  background: url(../public/btn_arrow_or.svg) top right / contain no-repeat;
}
.round_btn .icon-dl {
  background: url(../public/btn_arrow_dl.svg) top right / contain no-repeat;
}


.wave--up{
  position: relative;
  top: 2px;
}
.wave--down{
  position: relative;
  bottom: 2px;
}
.wave--down img,.wave--up img{
  display: block;
}

.overview{
  margin-top: 20px;
  padding: 11px 0 30px;
  background: rgba(250, 239, 210, .3);
}
.overview_ttl{
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.overview_content{
  margin: 20px auto 0;
  padding: 0 30px;
  width: min(100%, 700px);
}
.overview_content > p{
  font-size: 14px;
  font-weight: bold;
  line-height: 1.8;
}
.overview_content > p + p{
  margin-top: 15px;
}
.overview_content > p span{
  color: var(--color-pink);
}

.step_head{
  margin-top: 36px;
  font-size: 24px;
  color: #F0642D;
  text-align: center;
  line-height: 1.01;
  background: var(--white);
  font-weight: bold;
}
.step{
  margin-top: 30px;
  padding: 90px 10px 30px;
  background: var(--color-blue);
}
.step_lists{
  margin: 0 auto 0;
  display: flex;
  flex-direction: column;
  gap: 150px;
}
.step_list{
  margin: 0 auto;
  padding: 80px 10px 35px;
  width: clamp(300px, 85%, 450px);
  border-radius: 30px;
  background: var(--white);
  font-weight: bold;
  position: relative;
}
.step_list + .step_list::after{
  content: "";
  display: block;
  width: 53px;
  height: 71px;
  background: url(../public/arrow_orange_down.svg) center / contain no-repeat;
  position: absolute;
  top: -145px;
  left: 50%;
  transform: translateX(-50%);
}
.step_list::before{
  content: "";
  display: block;
  width: 140px;
  height: 140px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.step_list.step_list01::before{
  background: url(../public/step_entry.svg) center / contain no-repeat;
}
.step_list.step_list02::before{
  background: url(../public/step_form.svg) center / contain no-repeat;
}
.step_ttl{
  margin: 0 auto;
  width: fit-content;
  font-size: 24px;
  text-align: center;
  line-height: 1.5;
}
.step_txt{
  margin-top: 10px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}
.step_list .entry-chkboxWrap{
  margin-top: 13px;
}
.step_list .round_btn{
  margin-top: 15px;
}
.step_txt--large{
  font-size: 21px;
}
.step_txt--yelow{
  color: var(--color-yellow);
}

.step_note{
  margin-top: 10px;
  font-size: 10px;
  text-align: center;
}
.step_list02 ul{
  margin-top: 13px;
  display: flex;
  gap: 7px;
}
.step_list02 li{
  width: 100%;
  height: 77px;
  border-radius: 10px;
  background: var(--color-beige);
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 12px;
}
.step_list03 .step_txt{
  padding: 20px 0 30px;
}


.entry_step{
  padding: 0 13px;
}
/* アコーディオン */
.entry_step .dl_accordion {
  clear: both;
  margin: 0 auto;
  width: min(100%, 480px);
  padding: 0;
}
/* アコーディオンボタン */
.entry_step .dl_accordion-btn {
  position: relative;
  outline: initial;
  margin: 30px auto 0;
  color: var(--color-blue);
  font-weight: bold;
  text-align: center;
  background: #fff;
  border: 1px solid var(--color-blue);
  border-radius: 25.5px;
  width: 85%;
  font-size: 16px;
  padding: 6px 0;
}  
.entry_step .dl_accordion-btn .inn {
  position: absolute;
  width: 16px;
  height: 16px;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
}
.entry_step .dl_accordion-btn .inn .line {
  position: absolute;
  display: inline-block;
  background-color: var(--color-blue);
  height: 3.5px;
  left: 0;
  width: 100%;
  transition: 0.3s;
}
.entry_step .dl_accordion-btn .inn .line:nth-of-type(1) {
  top: 50%;
  transform: rotate(90deg);
}
.entry_step .dl_accordion-btn .inn .line.line:nth-of-type(2) {
  top: 50%;
}
.entry_step .dl_accordion-btn .inn .line:nth-of-type(1) {
  opacity: 0;
}
.entry_step .dl_accordion-btn.active .inn .line:nth-of-type(1) {
  opacity: 1;
}
.entry_step .dl_accordion .dl_toggle {
  margin: -25px auto 0;
  background: var(--color-lemon);
  border-radius: 12px;
  padding: 0 32px;
}
.entry_step .dl_accordion .dl_toggle .dl_toggle-item {
  margin: 0 auto;
  padding: 50px 0 30px;
}
.entry_step .txt__item {
  font-size: 20px;
  font-weight: bold;
  position: relative;
}
.entry_step .txt__item + .txt__item {
  margin-top: 107px;
}
.entry_step .txt__item + .txt__item::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 45px solid transparent;
  border-left: 45px solid transparent;
  border-top: 32px solid #F0642D;
  border-bottom: 0;
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
}
.entry_step .txt__item img{
  width: 83%;
  margin: 20px auto;
  display: block;
}

.option {
  margin: 0 auto 0;
  max-width: 900px;
  position: relative;
  transition: all 0.5s;
  padding: 0 23px;
}
.option_link {
  text-decoration: underline;
}
.toggle {
  display: none;
}
.title,
.content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  text-align: left;
}
.title {
  margin: 0 auto;
  padding: 10px 0;
  display: block;
  font-weight: 700;
  text-align: center;
  background: #F0642D;
  color: var(--white);
  font-size: 11px;
}
.title::after,
.title::before {
  content: "";
  position: absolute;
  right: 1.25em;
  top: 32%;
  width: 5px;
  transition: all 0.3s;
  background: var(--white);
  height: 17px;
}
.title::after {
  transform: rotate(90deg);
}
@media screen and (max-width: 1180px) {
  .title::after,
  .title::before {
    top:38%;
  }
  .first .title::after,
  .first .title::before {
    top:28%;
  }
}
@media screen and (min-width: 450px) and (max-width: 1180px) {
  .title::after,
  .title::before {
    top: 40%;
  }
}

.content {
  max-height: 0;
  overflow: hidden;
  text-align: left;
  background-color: #fff;
}
.content p {  max-width: 960px;
  line-height: 1.5;
  text-align: left;
}
.content p span {
  font-size: 12px;
}
.toggle:checked + .title + .content {
  max-height: 100%;
  transition: all 1.5s;
}
.toggle:checked + .title::before {
  transform: rotate(90deg) !important;
}
.summary {
  padding: 20px 20px 30px;
  text-align: center;
  font-size: 16px;
  background: #FAF8F3;
}
.summary > p{
  font-weight: 500;
  margin-bottom: 2em;
  font-size: 11px;
}
.summary_text{
  font-weight: bold;
  font-size: 11px;
}
.summary_text + .summary_text{
  margin-top: 25px;
}
.summary_lists {
  text-align: left;
  line-height: 1.7;
}
.summary_lists ol li{
  list-style: decimal;
  margin-left: 1.5em;
}
.summary_lists ul li{
  list-style: disc;
  margin-left: 1.5em;
}
.summary_lists dt {
  font-weight: bold;
  font-size: 14px;
}
.summary_lists dt::before {
  content: "";
  margin-right: .6em;
  width: .7em;
  height: .7em;
  display: inline-block;
  border-radius: 100px;
  background: var(--color-orange);
}
.summary_lists dd {
  margin-top: 5px;
  font-weight: 500;
  font-size: 11px;
}
.summary_lists a {
  text-decoration: underline;
}
.summary_lists dt:nth-of-type(n + 2) {
  padding-top: 20px;
}
.summary_lists .annotation{
  text-indent: -1em;
  padding-left: 1em;
}
@media screen and (max-width: 1180px) {
  .summary{
    padding: 15px 20px 30px;
  }
}

.campaign_terms{
  margin-top: 50px;
}


.merit_wrap::before,
.merit_wrap::after{
  margin-top: 25px;
  content: "";
  display: block;
  width: 100%;
  height: 30px;
  background: var(--color-beige);
}
.merit {
  width: 75%;
  margin: 0 auto;
  padding: 45px 0 0;
}
.merit_logo {
  width: min(100%, 280px);
  margin: 0 auto;
}
.merit_txt {
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  margin: 20px auto;
  width: 100%;
}
.merit h2 {
  font-size: 14px;
}
.angel h2{
  margin: 0 auto;
  max-width: 400px;
}
.merit_link{
  margin: 0 auto;
  display: block;
}

.merit_btn{
  background: #ffb432;
}
.merit_btn img {
  width: auto;
  height: 35px;
  padding-right: 3%;
}

.first{
  margin: 50px 0;
}
.first_btn{
  margin-top: 40px;
  background: #F0642D;
  color: var(--white);
}
.first_btn::after{
  background-image: url(../public/btn_arrow_or.svg);
}
@media screen and (min-width: 391px) {
  .first_br{
    display: none;
  }
}


.small {
  display: block;
  font-size: 12px;
}
.medium {
  display: block;
  font-size: 16px;
}
.ttl {
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}

.toggle {
  display: none;
}

@media screen and (min-width: 1181px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  .fv{
    padding-top: 2rem;
  }
  #main_fv {
    max-width: 980px;
  }
  .parent .round_btn{
    margin-top: 5px;
  }
  .entry-chkboxWrap{
    font-size: 16px;
  }
  .btn{
    width: 296px;
  }
  .round_btn{
    width: min(100%, 664px);
  }
  .round_btn .small {
    font-size: 12px;
  }
  .round_btn_btm {
    font-size: 16px;
  } 
  .round_btn_btm span {
    font-size: 16px;
  }
  .round_btn_btm span::after {
    width: 1.5em;
    height: 1.5em;
  }



  .step{
    padding-bottom:  57px;
  }
  .overview{
    padding-top: 20px;
  }
  .overview_ttl{
    font-size: 32px;
  }
  .overview_content{
    margin-top: 15px;
    padding: 0;
    width: fit-content;
  }
  .overview_content > p{
    font-size: 20px;
    line-height: 1.2;
    max-width: 1000px;
  }
  .overview_content > p + p{
    margin-top: 30px;
  }
  .overview_content .overview_text{
    font-size: 41.54px;
    line-height: 1.1;
    background: url(../public/bg_coin_pc.webp) center 58%/ 95% auto  no-repeat;
  }
  .overview .dl_toggle dt{
    background: #F5F5F5;
  }

  .step_head{
    font-size: 32px;
  }
  .step{
    margin-top: 40px;
    padding-top: 25px;
  }
  .step_lists{
    margin-top: 80px;
    max-width: 1008px;
    flex-direction: row;
    justify-content: center;
    gap: 112px;
  }
  .step_list{
    margin: 0;
    padding-right: 0;
    padding-left: 0;
    width: 359px;
    border-radius: 24px;
  }
  .step_list + .step_list::after{
    top: 50%;
    left: -80px;
    transform: translateY(-50%);
    height: 53px;
    background-image: url(../public/arrow_orange_right.svg);
  }
  .step_txt{
    font-size: 16px;
    line-height: 1.1;
    padding-right: 10px;
    padding-left: 10px;
  }
  .step_note{
    margin-top: 20px;
    text-align: center;
    font-size: 12px;
  }
  .step_lists .round_btn{
    margin-top: 5px;
  }
  .step_list02{
    padding-top: 100px;
  }
  .step_list02 ul{
    margin: 24px auto 0;
    width: 312px;
  }

  .download {
    max-width: 930px;
    margin: 90px auto 0;
  }
  .download_ttl{
    width: 289px;
  }
  .download_txt{
    font-size: 16px;
  }

  .entry_step .dl_accordion {
    margin: 80px auto 0;
    width: 881px;
  }
  .entry_step .dl_accordion-btn {
    font-size: 16px;
    padding: 9px 0;
    width: 100%;
  }
  .entry_step .dl_toggle {
    width: 99%;
  }
  .entry_step .txt {
    display: flex;
    gap: 150px;
    justify-content: center;
  }
  .entry_step .txt__item {
    width: 300px;
    position: relative;
  }
  .entry_step .txt__item:nth-of-type(1) img{
    width: 100%;
  }
  .entry_step .txt__item:first-child::before {
    content: "";
    display: block;
    height: 154px;
    width: 470px;
    position: absolute;
    top: 226px;
    left: -10px;
    background: url(../public/square_arrow.svg) center / contain no-repeat;
  }
  .entry_step .txt__item + .txt__item {
    margin: 0;
  }
  .entry_step .txt__item + .txt__item::before {
    display: none;
  }

  .campaign_terms{
    margin-top: 72px;
  }
  .campaign_terms .option{
    max-width: 960px;
  }
  .title{
    font-size: 16px;
  }
  .summary > p{
    font-size: 15px;
  }
  .summary_text{
    font-size: 15px;
  }
  .summary_lists dt,
  .summary_lists dd{
    font-size: 16px;
  }

  .merit{
    display: flex;
    justify-content: space-between;
    flex-direction: column;
  }
  .merit_wrap::before, .merit_wrap::after{
    height: 44px;
  }
  .merit_wrap::after{
    margin-top: 40px;
  }
  .merit_box{
    display: flex;
    justify-content: center;
    gap: 130px;
  }
  .merit{
    margin: 0;
    width: 442px;
  }
  .merit h2{
    font-size: 18px;
    letter-spacing: 0;
  }
  .angel h2{
    text-align: left;
  }

  .first .option{
    max-width: 881px;
  }
  .first .summary{
    padding: 40px;
  }

}