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: #fff4be;
  --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;
}
.asterisk{
  font-size: 0.7em;
  vertical-align: top;
}

.inner {
  padding: 0 16px;
  margin: auto;
}
.fv {
  width: 100%;
}
.fv_bg {
  position: relative;
  width: 100%;
  height: auto;
  text-align: center;
}
.fv_title {
  position: static;
  margin: 0 auto 12px;
  width: min(92%, 780px);
  color: var(--txt);
  font-size: 24px;
  font-weight: bold;
  line-height: 1.35;
  text-align: center;
  letter-spacing: 0.03em;
  text-shadow: none;
}
.c-footer.c-footer--border-top {
  padding-top: 0;
}
#main_fv {
  max-width: 780px;
  height: 100%;
  width: 100%;
  display: block;
  margin: 0 auto;
}
#main_fv img {
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.parent {
  margin: 0 auto 0;
  background-color: var(--white);
  font-size: 1rem;
  text-align: center;
  /* height: 0;
  overflow: hidden; */
}
.parent.fixed{
  padding: 15px 0;
  margin: 0 auto;
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
  background-color: rgba(217, 217, 217, 0.5);
  z-index: 999;
  height: auto;
}
.parent .round_btn{
  margin-top: 20px;
}
.entry-chkboxWrap {
  font-weight: 900;
  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 {
  color: var(--color-black);
  text-align: center;
  font-weight: bold;
  background-color: var(--color-lemonchiffon);
  box-shadow: 4px 4px 0#c2c2c2;
  margin: 10px auto 0;
}
#fv_btn.entry-btnStyle_checked {
  background-color: var(--btn-yellow);
  pointer-events: auto;
}
.fv_btn.round_btn {
  background-color: #a7a7a7;
  pointer-events: none;
}

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

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

.overview{
  margin-top: 20px;
  padding: 11px 0 30px;
}
.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);
}
.overview_content .overview_note{
  font-weight: 500;
  font-size: 10px;
}

.entry_lists{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.entry_list_btns{
  margin-top: 15px;
}
.entry_list_btn{
  margin: 10px auto 0;
  width: 83%;
  height: 53px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 4px 4px 0 #c2c2c2;
}
.entry_list_note{
  margin: 15px auto 0;
  width: min(92%, 500px);
  font-size: 9px;
}

.entry_notice {
  padding: 0 13px;
}
.entry_notice__inner {
  margin: 0 auto;
  padding: 20px 18px 24px;
  width: min(100%, 560px);
  border: 2px solid var(--color-blue);
  border-radius: 22px;
  background-color: var(--white);
}
.entry_notice__item {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}
.entry_notice__item:first-child {
  font-size: 24px;
}
.entry_notice__item + .entry_notice__item {
  margin-top: 4px;
}
.entry_notice__btn {
  margin: 16px auto 0;
  color: var(--color-black);
  background-color: var(--btn-yellow);
  box-shadow: 4px 4px 0 #c2c2c2;
  width: min(100%, 320px);
}
.entry_notice__btn::after {
  background-image: url(../public/btn_arrow_ye.svg);
}
.entry_notice__btn-note {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
}
.entry_notice__link {
  margin-top: 12px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
}
.entry_notice__link a {
  color: var(--color-blue);
}
.entry_notice__desc {
  margin: 24px auto 0;
  width: min(100%, 560px);
  padding: 0 13px;
  font-size: 12px;
  line-height: 1.6;
  text-align: left;
}
.entry_notice__desc a {
  color: var(--color-blue);
}
.entry_notice__detail {
  margin: 20px auto 0;
  width: min(100%, 560px);
  padding: 0 13px;
  text-align: left;
}
.entry_notice__detail-ttl {
  margin-top: 16px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
}
.entry_notice__detail-ttl:first-child {
  margin-top: 0;
}
.entry_notice__detail-text,
.entry_notice__detail-note {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.7;
}
.entry_notice__detail a {
  color: var(--color-blue);
}


.entry_step{
  margin-top: 48px;
  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: 15px auto 0;
  padding: 6px 30px 0 10px;
  color: var(--color-blue);
  font-weight: bold;
  text-align: center;
  background: #fff;
  border: 1px solid var(--color-blue);
  border-radius: 25.5px;
  width: 85%;
  min-width: 290px;
  font-size: 16px;
}  
.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-btn_text {
  margin: 0 auto;
  display: block;
  max-width: 263px;
}
.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 .dl_accordion .dl_toggle .dl_toggle-item-img-01 {
  margin: 20px auto;
}
.entry_step .txt__item {
  font-size: 20px;
  font-weight: bold;
  position: relative;
}
.entry_step .txt__annotation {
  font-size: 12px;
  font-weight: 500;
  margin: 10px auto 0;
  width: 250px;
  max-width: 100%;
}
.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;
}

.award{
  margin-top: 80px;
  position: relative;
}
.award::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: -80px;
  left: 50%;
  transform: translateX(-50%);
}
.award_ttl{
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
.award_box{
  margin: 100px auto 0;
  width: min(100%, 450px);
  position: relative;
  display: flex;
  flex-direction: column;
}
.award_img01,
.award_img02,
.award_img03,
.award_img04{
  position: absolute;
}
.award_img01{
  top: -50px;
  left: -5px;
  width: 100px;
}
.award_img02{
  top: -65px;
  right: 5px;
  width: 70px;
}
.award_img03{
  bottom: -82px;
  left: 5px;
  width: 84px;
}
.award_img04{
  bottom: -70px;
  right: 5px;
  width: 84px;
}
.award_note{
  margin: 0 auto;
  width: 70%;
  font-size: 9px;
  font-weight: bold;
}

.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: bold;
  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 {
  color: var(--color-blue);
  text-decoration: underline;
}
.summary_lists a:visited {
  color: var(--color-blue);
}
.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: 10px;
}


.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%, 290px);
  margin: 0 auto;
}
.merit_txt {
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  margin: 20px auto;
  width: 100%;
}
.merit h2 {
  font-size: 14px;
}
.gakken 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;
  }
  .fv_title {
    margin-bottom: 18px;
    width: min(88%, 1008px);
    font-size: clamp(32px, 3vw, 44px);
  }
  #main_fv {
    max-width: 1008px;
  }
  .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;
  }
  .entry_step .dl_accordion .dl_toggle .dl_toggle-item-img-01 {
    margin: 50px auto;
  }
  .entry_notice__inner {
    padding: 24px 28px 28px;
    width: min(100%, 760px);
    border-radius: 28px;
  }
  .entry_notice__item {
    font-size: 24px;
    line-height: 1.5;
  }
  .entry_notice__item:first-child {
    font-size: 32px;
  }
  .entry_notice__btn {
    margin-top: 20px;
    width: min(100%, 360px);
  }
  .entry_notice__btn-note {
    margin-top: 10px;
    font-size: 13px;
  }
  .entry_notice__link {
    margin-top: 14px;
    font-size: 18px;
  }
  .entry_notice__desc {
    width: min(100%, 760px);
    font-size: 12px;
  }
  .entry_notice__detail {
    width: min(100%, 760px);
  }
  .entry_notice__detail-ttl {
    font-size: 18px;
  }
  .entry_notice__detail-text,
  .entry_notice__detail-note {
    font-size: 18px;
  }
  .overview{
    padding-top: 20px;
  }
  .overview_ttl{
    font-size: 32px;
  }
  .overview_content{
    margin-top: 15px;
    padding: 5px 24px 20px;
    width: 1000px;
    border-radius: 24px;
  }
  .overview_content > p{
    font-size: 20px;
    line-height: 1.2;
  }
  .overview_content > p + p{
    margin-top: 30px;
  }
  .overview_content .overview_note{
    font-size: 12px;
  }

  .entry_lists{
    flex-direction: row;
    justify-content: center;
    gap: 96px;
  }
  .entry_list{
    width: 470px;
  }
  .entry_list_btn{
    width: 460px;
    height: 80px;
    font-size: 26.7px;
  }
  .entry_list_note{
    width: 100%;
    font-size: 12px;
  }

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

  .campaign_txt{
    font-size: 36px;
  }
  .campaign .large_banner{
    width: 650px;
  }

  .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_accordion-btn_text {
    max-width: none;
  }
  .entry_step .dl_toggle {
    width: 99%;
  }
  .entry_step .txt {
    display: flex;
    gap: 130px;
    justify-content: center;
  }
  .entry_step .txt__item {
    width: 300px;
    position: relative;
  }
  .entry_step .txt__item img{
    width: min(100%, 250px);
  }
  .entry_step .txt__item + .txt__item {
    margin: 0;
  }
  .entry_step .txt__item + .txt__item::before {
    display: none;
  }

  .award{
    width: 990px;
    margin: 80px auto 0;
  }
  .award::before{
    top: -55px;
  }
  .award_ttl{
    font-size: 32px;
  }
  .award_box{
    margin-top: 20px;
    width: 100%;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
  .award_box img{
    width: min(100%, 957px);
  }
  .award_note{
    width: 100%;
    font-size: 12px;
  }
  .award_box .award_img01{
    top: -73px;
    left: 25px;
    width: 140px;
  }
  .award_box .award_img02{
    top: -72px;
    right: 5px;
    width: 110px;
  }
  .award_box .award_img03{
    bottom: -28px;
    left: 5px;
    width: 115px;
  }
  .award_box .award_img04{
    bottom: 5px;
    right: 5px;
    width: 104px;
  }

  .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;
  }
  .gakken h2{
    max-width: none;
  }

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