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

: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-crimson: #D00E31;
  --color-yellow: #FFB432;
  --color-orange: #FF8400;
  --color-beige: #F9F4F1;
  --color-red: #D62D26;
  --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;

  --bg-main-color: #fff6e5;
  --bg-sub-color: #f9f4f1;
  --bg-yellow-color: #ffb432;
  --bg-orange-color: #f0642d;
  --text-main-color: #3d3937;
  --text-sub-color: #002dc3;
}

button {
  display: block;
  margin: auto;
  width: 100%;
}
img {
  width: 100%;
}
.pc {
  display: none;
}
.sp {
  display: block;
}
p a{
  text-decoration: underline;
}
.asterisk{
  font-size: 0.7em;
  vertical-align: top;
}

footer{
  margin-top: 50px;
}

.inner {
  padding: 0 16px;
  margin: auto;
}
.fv {
  width: 100%;
}
.fv_bg {
  width: 100%;
  height: auto;
  text-align: center;
}
#main_fv {
  max-width: 746px;
  height: 100%;
  width: 100%;
  display: block;
  margin: 0 auto;
}
#main_fv img {
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.btn {
  width: 458.2px;
  height: 70px;
  font-size: 1.125rem;
  margin: 10px auto 0;
  font-weight: 800;
  font-size: 23px;
  text-align: center;
}

.parent {
  margin: 25px auto 0;
  background-color: var(--white);
  font-size: 1rem;
  text-align: center;
}
.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 .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;
}


/* ボタン */
.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,.round_btn .icon-r {
  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-r {
  background: url(./public/btn_arrow_r.svg) top right / contain no-repeat;
}
.round_btn .icon-dl {
  background: url(./public/btn_arrow_dl.svg) top right / contain no-repeat;
}

/* アコーディオン */
.dl_accordion {
  clear: both;
  width: 100%;
  padding: 0;
}
/* アコーディオンボタン */
.dl_accordion-btn {
  position: relative;
  outline: initial;
  width: 100%;
  margin: 20px auto 0;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: var(--txt);
  background: var(--white);
  border-radius: 9999px;
  box-shadow: 0px 1px 3px 0px rgba(190, 190, 190, 1);
  padding: 10px;
}  
.dl_accordion-btn.active {
  color: var(--color-navy);
  background: var(--color-skyblue);
}  
.dl_accordion-btn .inn {
  position: absolute;
  width: 20px;
  height: 20px;
  top: 0;
  bottom: 0;
  background-color: var(--color-yellow);
  border-radius: 9999px;
  right: 1em;
  margin: auto;
}
.dl_accordion-btn.active .inn {
  background-color: var(--color-navy);
}
.dl_accordion-btn .inn .line {
  position: absolute;
  display: inline-block;
  background-color: var(--color-navy);
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
  transition: 0.3s;
}
.dl_accordion-btn.active .inn .line {
  background-color: var(--white);
}
.dl_accordion-btn .inn .line:nth-of-type(1) {
  top: 45%;
  left: 22%;
  transform: rotate(90deg);
}
.dl_accordion-btn .inn .line:nth-of-type(1) {
  opacity: 1;
}
.dl_accordion-btn.active .inn .line:nth-of-type(1) {
  opacity: 0;
}

/* アコーディオン内容 */
.dl_accordion .dl_toggle {
  width: 100%;
  margin: 0 auto 0;
  border-radius: 12px;
  font-size: 12px;
  line-height: 1.8;
  font-weight: bold;
}
.dl_toggle dl{
  margin-top: 20px;
}
.dl_toggle dt{
  margin-top: 15px;
  padding: 4px;
  background: var(--white);
}
.dl_toggle dd{
  padding: 7px;
}
.dl_toggle .numbering{
  text-indent: -1em;
  padding-left: 1em;
  display: inline-block;
}


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


.step{
  margin-top: 40px;
  padding: 30px 20px;
  background: var(--color-blue);
}

.overview_ttl{
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  color: var(--white);
}
.overview_content{
  margin: 5px auto 0;
  padding: 5px 10px 15px;
  width: min(100%, 450px);
  border-radius: 10px;
  background: var(--white);
}
.overview_content > p{
  margin-top: 15px;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.8;
}
.overview_content > p span{
  color: var(--color-pink);
}
.overview_content .overview_text{
  padding: 0 30px 20px;
  font-size: 28px;
  color: var(--color-orange);
  line-height: 1.01;
  min-height: 138px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: url(./public/bg_coin_sp.webp) center / contain no-repeat;
}
.overview_content > img{
  margin-top: 15px;
}
.overview_content .dl_accordion-btn{
  margin-top: 0;
}
.overview_content .round_btn{
  margin: 0 auto 20px;
  width: 100%;
}
.overview .dl_toggle dt{
  background: #F5F5F5;
}
.overview .dl_toggle dd a{
  text-decoration: underline;
}

.step_lists{
  margin: 42px auto 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.step_list{
  margin: 0 auto;
  padding: 20px 14px;
  width: min(100%, 450px);
  border-radius: 10px;
  background: var(--white);
  font-weight: bold;
}
.step_ttl{
  margin: 0 auto;
  width: fit-content;
  font-size: 24px;
  color: var(--color-navy);
  line-height: 1.1;
  background-image: linear-gradient(transparent 75%, #FFEA00 50%);
}
.step_txt{
  margin-top: 25px;
  text-align: center;
  font-size: 14px;
  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;
}


.download {
  margin-top: 60px;
}
.download_ttl {
  margin: 0 auto;
  width: min(90%, 400px);
  display: block;
}
.download_txt {
  margin-top: 20px;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  line-height: 2;
  color: var(--color-navy);
}
.download .large_banner{
  margin: 20px auto 0;
  width: min(94%, 500px);
}

.campaign {
  margin-top: 43px;
}
.campaign_ttl {
  margin-top: 20px;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.8;
  color: var(--color-navy);
}
.campaign_txt {
  margin: 10px auto 0;
  padding: 0 30px;
  max-width: 770px;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}
.campaign_link {
  margin: 20px auto 0;
  padding: 0 30px;
  max-width: 770px;
  display: block;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  text-decoration: underline;
}
.campaign .large_banner{
  margin: 15px auto 0;
  width: min(90%, 450px);
}
.campaign .large_banner a{
  display: block;
}

.p-home__mail-magazine{
  margin-top: 43px;
}


.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;
}

/* entry-step */
.entry-step {
  margin: 0 0 3rem 0;
  padding: 2.5rem 6.155%;
  width: 100vw;
  max-width: none;
  border-radius: 0;
  background-color: var(--bg-sub-color);
}
.entry-step .title {
  margin-bottom: 2.5rem;
  margin-top: 0;
  font-size: 1.25rem;
  line-height: 1.8;
  color: var(--text-sub-color);
  text-align: center;
  font-weight: 700;
}
.entry-step .att {
  font-size: 0.75rem;
}
.entry-step .important {
  padding-left: 1.75rem;
  color: var(--bg-orange-color);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.8;
  position: relative;
}
.entry-step .important::before {
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='25' viewBox='0 0 24 25' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 22.5391C17.5228 22.5391 22 18.0619 22 12.5391C22 7.01621 17.5228 2.53906 12 2.53906C6.47715 2.53906 2 7.01621 2 12.5391C2 18.0619 6.47715 22.5391 12 22.5391Z' stroke='%23F0642D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M12 8.53906V12.5391' stroke='%23F0642D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M12 16.5391H12.01' stroke='%23F0642D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
  position: absolute;
  left: 0;
  top: -0.0625rem;
}
.entry-step .step-lists {
  list-style-type: none;
  padding-left: 0;
}
.entry-step .step-lists > li {
  margin-inline: auto;
  margin-bottom: 3.75rem;
  padding: 2rem 1.5rem 1.5rem;
  width: 100%;
  max-width: 21.375rem;
  background-color: #fff;
  border-radius: 1rem;
  position: relative;
}
.entry-step .step-lists > li p:not(.important) {
  margin-bottom: 0.5rem;
  line-height: 1.8;
  font-size: 0.875rem;
}
.entry-step .step-lists .step-precautions {
  margin-bottom: 0;
}
.entry-step .step-lists .step1::before,
.entry-step .step-lists .step2::before,
.entry-step .step-lists .step-precautions::before {
  content: "";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8.75rem;
  height: 2.3125rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 100vmax;
  background-color: var(--text-sub-color);
  position: absolute;
  top: -1.125rem;
  left: calc(50% - 4.375rem);
}
.entry-step .step-lists .step1::before {
  content: "STEP1";
}
.entry-step .step-lists .step1::after {
  content: "";
  display: block;
  width: 1rem;
  height: 0.75rem;
  background: url("data:image/svg+xml,%3Csvg width='12' height='9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.792 7.97a1 1 0 0 1-1.584 0L.31 1.61A1 1 0 0 1 1.104 0h9.792a1 1 0 0 1 .793 1.61L6.792 7.97Z' fill='%23002DC3'/%3E%3C/svg%3E") no-repeat center top/contain;
  position: absolute;
  bottom: -1.75rem;
  left: calc(50% - 0.5rem);
}
.entry-step .step-lists .step2::before {
  content: "STEP2";
}
.entry-step .step-lists .step-precautions::before {
  content: "注意事項";
}
.entry-step .step-image {
  margin-inline: auto;
  margin-bottom: 1.5rem;
  width: 100%;
  max-width: 18.375rem;
}
.entry-step .step-image img {
  width: 100%;
  height: auto;
  border: 1px solid #f6f6f6;
}
.entry-step .step-image:last-of-type {
  margin-bottom: 0;
}

@media screen and (min-width: 1181px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  .fv{
    padding-top: 2rem;
  }
  .parent {
    margin: 25px auto;
  }
  .parent .round_btn{
    margin-top: 5px;
  }
  .entry-chkboxWrap{
    font-size: 16px;
  }

  .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_ttl{
    font-size: 36px;
  }
  .overview_content{
    margin-top: 5px;
    padding: 5px 24px 20px;
    width: 640px;
    border-radius: 24px;
  }
  .overview_content .overview_text{
    padding: 0 82px 20px;
    line-height: 1.1;
    min-height: 100px;
    background: url(./public/bg_coin_pc.webp) center 0/ 95% auto  no-repeat;
  }
  .overview_content .round_btn{
    width: 70%;
  }
  .overview .dl_toggle dt{
    background: #F5F5F5;
  }
  .step_lists{
    margin-top: 80px;
    max-width: 1008px;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
  .step_list{
    margin: 0;
    width: 492px;
    border-radius: 24px;
  }
  .step_txt{
    font-size: 16px;
  }
  .step_note{
    margin-top: 20px;
    text-align: center;
    font-size: 12px;
  }
  .step_lists .round_btn{
    margin-top: 5px;
  }
  .step_list02 ul{
    margin: 24px auto 0;
    width: 312px;
  }
  .step_list03 .step_txt{
    padding: 25px 0 55px;
  }

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

  .campaign_ttl{
    font-size: 36px;
  }
  .campaign_link{
    margin-top: 30px;
  }
  .campaign .large_banner{
    width: 492px;
  }

  .dl_accordion {
    margin-top: 10px;
  }
  .dl_accordion-btn {
    font-size: 16px;
    padding: 9px 0;
    margin-top: 20px;
  }

  .entry-step {
    margin: 0 0 3rem;
    padding: 5rem 15%;
  }
  .entry-step .title {
    font-size: 2rem;
  }
  .entry-step .register,
  .entry-step .register2,
  .entry-step .register3 {
    font-size: 1rem;
    font-weight: 700;
  }
  .entry-step .register3 {
    margin-bottom: 1.5rem;
  }
  .entry-step .att {
    font-size: 0.75rem;
  }
  .entry-step .important {
    display: inline-block;
    padding-left: 1.75rem;
    font-size: 1rem;
  }
  .entry-step .important::before {
    content: "";
    top: 0.1875rem;
    left: -0.1875rem;
  }
  .entry-step .step-lists > li {
    padding: 2rem 1.5rem 1.5rem;
    width: 100%;
    max-width: 63rem;
    border-radius: 1.5rem;
    text-align: center;
  }
  .entry-step .step-lists > li p:not(.important) {
    margin-bottom: 0.5rem;
    line-height: 1.8;
    font-size: 1rem;
  }
  .entry-step .step-lists .step1::after {
    bottom: -1.875rem;
  }
}