@charset "UTF-8";
/* reset
----------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

html {
  height: 100%;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* clearfix */
.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clearfix {
  display: inline-block;
}

/* Hides from IE-Mac \*/
* html .clearfix {
  height: 1%;
}

.clearfix {
  display: block;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

:root {
  --lp-base-color: #fff;
  --lp-font-color: #000000;
  --primary-color:#FF7800;
  --secondary-color:#DF6A70;
  --font-langJa:"Noto Sans JP",sans-serif;
  --font-maru:"Zen Maru Gothic", sans-serif;
  --font-weight-regular:400;
  --font-weight-bold:700;
  --font-weight-black:900;
  --dot-size:200px;
}

html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

html,
body {
  width: 100%;
  min-height: 100%;
  height: auto;
}

body {
  font-family: var(--font-langJa);
  line-height: 1.5;
  color: var(--lp-font-color);
  font-size: 16px;
  font-weight: 700;
  min-height: 0vw;
  text-rendering: optimizeLegibility;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
body::before {
  position: fixed;
  content: "";
  z-index: 0;
  width: 100%;
  height: 100%;
  background: url(../img/pc/bg_pc.png);
  background-size: cover;
}

a {
  color: inherit;
  text-decoration: none;
}

@media (min-width: 960) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
:where(:focus-visible) {
  outline: 3px solid Highlight;
  outline-offset: 2px;
}

main {
  position: relative;
  display: block;
  padding-top: 40px;
}
@media screen and (min-width: 1024px) {
  main {
    padding-top: 0px;
  }
}

.l-inner {
  margin: 0 auto;
  width: 89.8666666667%;
  max-width: 375px;
}
.l-inner.--small {
  width: 80%;
}

.pc-only {
  display: none;
}

.sp-only {
  display: block;
}

@media screen and (min-width: 1024px) {
  .pc-only {
    display: block;
  }
  .sp-only {
    display: none;
  }
}
html:has(.is-drawerActive) {
  overflow: hidden;
}

/******************************
* layout
*******************************/
.l-container {
  margin: 0 auto;
  width: 100%;
  max-width: 100%;
  background-color: #fff;
}
@media screen and (min-width: 1024px) {
  .l-container {
    width: 100%;
    max-width: 375px;
  }
}

/***********************
* pc用レイアウト
************************/
.lp-wrapper {
  display: block;
}
.lp-wrapper > .g02 {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 961px) {
  .lp-wrapper {
    display: grid;
    grid-auto-columns: 1fr;
    grid-auto-rows: 1fr;
    grid-template-columns: 1fr 375px 1fr;
    grid-template-rows: auto;
    gap: 0px 0px;
    grid-template-areas: "g01 g02 g03";
  }
  .lp-wrapper > .g01 {
    grid-area: g01;
  }
  .lp-wrapper > .g02 {
    box-shadow: 0px 0px 10px rgba(250, 100, 0, 0.5);
  }
  .lp-wrapper > .g03 {
    grid-area: g03;
  }
}

.lp-fixnav {
  display: none;
  position: fixed;
  z-index: 100;
  left: 0;
  top: 60px;
  padding: 0 4%;
  width: 100%;
  height: calc(100vh - 60px);
  background-color: #fff;
}

.lp-fixnav-scroll {
  height: 100%;
  overflow: auto;
}

.lp-fixnav-inner {
  padding-bottom: 100px;
}
.lp-fixnav-inner .period {
  margin-top: 28px;
}
.lp-fixnav-inner .period dd {
  padding-bottom: 1.25em;
}
.lp-fixnav-inner .period-date {
  color: #FF7800;
  font-size: 30px;
  font-weight: 900;
  font-feature-settings: "palt";
  text-align: center;
}
.lp-fixnav-inner .period-date .unit {
  font-size: 17px;
}
.lp-fixnav-inner .period-date .week {
  font-size: 21px;
}
.lp-fixnav-inner .period-arrow {
  margin: 4px auto 0;
  width: 70px;
  aspect-ratio: 2/1;
}
.lp-fixnav-inner .menu-toc-link {
  font-size: 21px;
}

.sp-menu-toc {
  margin: 4% auto 0;
  max-width: 315px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sp-menu-toc li {
  position: relative;
}
.sp-menu-toc li a {
  display: block;
}

.is-drawerActive .lp-fixnav {
  display: block;
}

/******************************
* PCメニュー 右エリア
*******************************/
.pc-menu {
  display: none;
}
@media screen and (min-width: 961px) {
  .pc-menu {
    display: block;
  }
}

.pc-menu-inner {
  display: none;
}
@media screen and (min-width: 1024px) {
  .pc-menu-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 4% 4%;
    position: -webkit-sticky;
    position: sticky;
    right: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    z-index: 1;
  }
}

.pc-menu-subtitle01 {
  margin: 0 auto 0;
  max-width: 294px;
  width: 38%;
}

.pc-menu-toc {
  margin: 4% auto 0;
  max-width: 315px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pc-menu-toc li {
  position: relative;
}
.pc-menu-toc li a {
  display: block;
}

.menu-toc-link {
  position: relative;
  z-index: 0;
  padding: 0.65em 1em;
  display: block;
  color: #000;
  background: url(../img/sp/btn_menu.png) no-repeat center/contain;
  width: 100%;
  text-align: center;
  font-size: 25px;
  font-weight: 700;
  line-height: 1.4;
  font-size: min(6.66vw,25px);
  font-family: var(--font-maru);
  letter-spacing: -0.09em;
}
.menu-toc-link.large {
  color: #fff;
  background: url(../img/sp/btn_form_1.png) no-repeat center/contain;
}
.menu-toc-link:hover {
  opacity: 0.6;
}

.pc-menu-toc .menu-toc-link {
  font-size: min(1.3vw,25px);
}

/******************************
* PCメニュー 左エリア
*******************************/
.pc-mv {
  display: none;
}
@media screen and (min-width: 961px) {
  .pc-mv {
    display: block;
  }
}

.pc-mv-inner {
  display: none;
}
@media screen and (min-width: 1024px) {
  .pc-mv-inner {
    padding: 7% 7%;
    display: block;
    position: -webkit-sticky;
    position: sticky;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 1;
  }
}

@media screen and (min-width: 1024px) {
  .pc-menu-logo {
    max-width: 197px;
    width: 28.9705882353%;
  }
}
.pc-menu-logo img {
  width: 100%;
}

.pc-contents {
  margin: 5% auto 0;
}

.pc-mv-title {
  margin: 4% auto 0;
  width: 62%;
}
.pc-mv-title img {
  width: 100%;
}

.pc-mv-img {
  margin: 2% auto 0;
  width: 62%;
}
.pc-mv-img img {
  width: 100%;
}

.pc-mv-period {
  margin-top: 4%;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  font-size: 16px;
  font-size: min(0.83vw,16px);
  gap: 8px 0.5em;
}
.pc-mv-period dt {
  width: 8em;
}
.pc-mv-period dt span {
  font-weight: 700;
  font-family: var(--font-maru);
  position: relative;
  padding: 0.5em 0.25em;
  display: block;
  color: #000;
  background: url(../img/sp/btn_menu.png) no-repeat center/contain;
  text-align: center;
}
.pc-mv-period .period-date {
  width: calc(100% - 8em);
  color: #FF7800;
  font-size: 23px;
  font-size: min(1.25vw,24px);
  font-weight: 900;
  font-feature-settings: "palt";
  text-align: left;
}
.pc-mv-period .period-date .unit {
  font-size: 13px;
  font-size: min(0.67vw,13px);
}
.pc-mv-period .period-date .week {
  font-size: 16px;
  font-size: min(0.83vw,16px);
}

/******************************
* ハンバーガーメニュー
*******************************/
.hamburger {
  width: 80px;
  background: url(../img/sp/bg_dw_menu.png) no-repeat center/contain;
  border: none;
  font-family: var(--font-maru);
  font-weight: 700;
}
.hamburger span {
  padding: 1em 0;
  display: inline-block;
  color: #000;
}

/******************************
* header
*******************************/
.l-header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 60px;
  z-index: 101;
  background-color: white;
}
@media screen and (min-width: 1024px) {
  .l-header {
    display: none;
  }
}
.l-header .l-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  width: 97%;
  max-width: 375px;
  height: 100%;
}

.c-logo {
  width: 120px;
  flex-shrink: 0;
}
.c-logo img {
  vertical-align: middle;
}
.c-logo a {
  display: block;
}

/***********************
* footer
***********************/
.l-footer {
  position: relative;
  padding: 17px 4% 50px;
  color: #000;
  text-align: center;
}

.footer-text01 {
  font-size: 16px;
  font-weight: 700;
}

.footer-text02 {
  font-feature-settings: "palt";
  font-size: 20px;
  font-weight: 700;
}

.footer-text03 {
  margin-top: 20px;
  text-align: left;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  flex-wrap: wrap;
}
.footer-text03 dt {
  padding-bottom: 0.5em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.footer-text03 dd {
  padding-bottom: 0.5em;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

.footer-logo {
  margin: 40px auto 0;
  width: 230px;
}
.footer-logo > img {
  width: 100%;
}

.footer-copy {
  margin-top: 15px;
  font-size: 10px;
  text-align: center;
}

/***********************
* utility
************************/
.u-en {
  font-family: var(--font-langEn);
}

.u-num {
  font-family: var(--font-langNum);
}

.u-tal {
  text-align: left;
}

.u-tac {
  text-align: center;
}

.u-tar {
  text-align: right;
}

.u-fwr {
  font-weight: 400;
}

.u-fwm {
  font-weight: 500;
}

.u-fwb {
  font-weight: 700;
}

.u-red {
  color: #FF0000;
}

.u-primary {
  color: var(--key-color);
}

.u-secondary {
  color: var(--lp-secondary-color);
}

.bg-primary {
  background-color: var(--lp-key-color);
}

.bg-secondary {
  background-color: var(--lp-secondary-color);
}

.u-mt10 {
  margin-top: 10px;
}

.u-mt20 {
  margin-top: 20px;
}

.u-mt30 {
  margin-top: 30px;
}

.u-link {
  text-decoration: underline;
}

.u-maru {
  font-family: var(--font-maru);
}

.c-btn01 {
  position: relative;
  padding: 0.5em 0.25em;
  display: block;
  color: #fff;
  background: url(../img/sp/btn_form_1.png) no-repeat center/contain;
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.09em;
  font-family: var(--font-maru);
}
.c-btn01:hover, .c-btn01:focus {
  opacity: 0.6;
}

.c-list01 li {
  position: relative;
  padding-left: 1em;
}
.c-list01 li::before {
  content: "・";
  position: absolute;
  left: 0;
  display: block;
}
.c-list01[data-type=asterisk] li::before {
  content: "※";
  position: absolute;
  left: 0;
  display: block;
}

.c-list02 {
  counter-reset: number 0;
}
.c-list02 li {
  position: relative;
  padding-left: 1.5em;
}
.c-list02 li::before {
  content: counter(number);
  counter-increment: number 1;
  position: absolute;
  left: 0;
  top: 0.25em;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.5em;
  height: 1.5em;
  text-align: center;
  color: #000;
  background-color: #fff;
  border: 2px solid #000;
  border-radius: 100%;
  z-index: 2;
  font-size: 0.75em;
}

.c-title01 {
  margin: 0 auto;
  font-size: 21px;
  font-weight: 700;
  position: relative;
  z-index: 0;
  padding: 0.5em 0.25em;
  display: block;
  color: #000;
  background: url(../img/sp/btn_menu.png) no-repeat center/contain;
  width: 160px;
  text-align: center;
  font-family: var(--font-maru);
}

.c-title02 {
  position: relative;
  margin: 0 auto;
  font-size: 31px;
  font-weight: 900;
  text-align: center;
  display: inline-block;
  width: 2em;
}
.c-title02 img {
  width: 100%;
}

.c-text01 {
  font-size: 15px;
  line-height: 1.6666666667;
}

.c-text02 {
  font-size: 14px;
  line-height: 1.6666666667;
}

.wave-top {
  position: relative;
}
.wave-top::after {
  position: absolute;
  left: 0;
  top: -1px;
  content: "";
  display: block;
  aspect-ratio: 750/68;
  width: 100%;
  background-size: var(--dot-size);
  -webkit-mask-image: url(../img/sp/top_wave.png);
  -webkit-mask-size: contain;
  mask-image: url(../img/sp/top_wave.png);
  mask-size: contain;
}

.wave-bottom {
  position: relative;
}
.wave-bottom::before {
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: 1;
  content: "";
  display: block;
  aspect-ratio: 750/68;
  width: 100%;
  background-size: var(--dot-size);
  -webkit-mask-image: url(../img/sp/bottom_wave.png);
  -webkit-mask-size: contain;
  mask-image: url(../img/sp/bottom_wave.png);
  mask-size: contain;
}

/* mv*/
.sec-main {
  padding-top: 48px;
  padding-bottom: 20%;
  position: relative;
  background-color: #FFFFB4;
}
.sec-main::before {
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: 1;
  content: "";
  display: block;
  aspect-ratio: 750/68;
  width: 100%;
  background: url(../img/sp/bg_dot02_a20.png) #FF7800;
  background-position: bottom left;
  background-size: var(--dot-size);
  -webkit-mask-image: url(../img/sp/bottom_wave.png);
  -webkit-mask-size: contain;
  mask-image: url(../img/sp/bottom_wave.png);
  mask-size: contain;
}
.sec-main .mv {
  margin: 0 auto;
  max-width: 375px;
}
.sec-main .caution {
  margin: 0 auto;
  max-width: 299px;
}
.sec-main .period {
  margin-top: 28px;
}
.sec-main .period dd {
  padding-bottom: 1.25em;
}
.sec-main .period-date {
  color: #FF7800;
  font-size: 36px;
  font-weight: 900;
  font-feature-settings: "palt";
  text-align: center;
}
.sec-main .period-date .unit {
  font-size: 21px;
}
.sec-main .period-date .week {
  font-size: 25px;
}
.sec-main .period-arrow {
  margin: 4px auto 0;
  width: 70px;
  aspect-ratio: 2/1;
}

/* present */
.sec-present {
  position: relative;
  padding: 40px 0 16%;
  background: url(../img/sp/bg_dot02_a20.png) #FF7800;
  background-size: var(--dot-size);
}
.sec-present::before {
  background-image: url(../img/sp/bg_dot01_a20.png);
  background-color: #64B400;
  background-position: bottom left;
}

.present-img > img {
  width: 100%;
}

.present-img01 {
  margin: 30px auto 0;
}

.present-img02 {
  margin: 12px auto 0;
}

.ninzu {
  margin: 30px auto 0;
}

.text-ninzu {
  margin: 16px auto 0;
  width: 78.0415430267%;
}
.text-ninzu img {
  width: 100%;
}

.text-present {
  margin: 40px auto 0;
  width: 97%;
}
.text-present img {
  width: 100%;
}

/* item */
.sec-item {
  position: relative;
  padding-top: 35px;
  padding-bottom: 15%;
  background-image: url(../img/sp/bg_dot01_a20.png);
  background-color: #64B400;
  background-size: var(--dot-size);
}
.sec-item::before {
  background-image: url(../img/sp/bg_dot02_a50.png);
  background-color: #FFE600;
  background-position: bottom left;
}

.item-subtitle {
  margin-top: 14px;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  font-feature-settings: "palt";
}

.item-img {
  margin: 30px auto 0;
  width: 94%;
}
.item-img > img {
  width: 100%;
}

.item-dl {
  margin-top: 24px;
}
.item-dl dt {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
.item-dl dd + dt {
  margin-top: 24px;
}
.item-dl dd {
  text-align: left;
}

.item-list {
  margin: 0 auto;
  font-size: 18px;
  font-weight: 700;
  width: 91%;
}
.item-list span {
  font-size: 12px;
}

/* howto */
.sec-howto {
  position: relative;
  padding-top: 35px;
  padding-bottom: 16%;
  background-image: url(../img/sp/bg_dot02_a50.png);
  background-color: #FFE600;
  background-size: var(--dot-size);
}
.sec-howto::before {
  background-image: url(../img/sp/bg_dot01_a20.png);
  background-color: #50C8FF;
  background-position: bottom left;
}

.step dt span {
  display: block;
  margin: 0 auto;
  width: 106px;
}
.step dt span img {
  width: 100%;
}
.step dd {
  margin-top: 15px;
}
.step dd:not(.last) {
  position: relative;
}
.step dd:not(.last)::after {
  margin: 12px auto 0;
  content: "";
  display: block;
  width: 70px;
  aspect-ratio: 2/1;
  background: url(../img/sp/arrow.svg);
}

.step-img + * {
  margin-top: 1.25em;
}

.howto-lead01 dd {
  padding-top: 1.5em;
  padding-bottom: 1.25em;
}

.howto-lead02 dt {
  line-height: 1;
  background: url(../img/sp/title_line.png) no-repeat center/100%;
  text-align: center;
}
.howto-lead02 dd {
  padding-top: 1.5em;
  padding-bottom: 1.25em;
}

.howto-list01 {
  font-size: 15px;
  counter-reset: number 0;
}
.howto-list01 li {
  position: relative;
  padding-left: 2em;
  font-size: 15px;
}
.howto-list01 li::before {
  content: counter(number);
  counter-increment: number 1;
  position: absolute;
  left: 0;
  top: 0em;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  text-align: center;
  color: #000;
  background-color: #fff;
  border: 2px solid #000;
  border-radius: 100%;
  z-index: 2;
  font-size: 0.75em;
}
.howto-list01 li + li {
  margin-top: 0.5em;
}

.receipt-box {
  margin-top: 30px;
  border: 3px solid #000;
  background-color: #fff;
}

.receipt-box-title {
  padding: 0.5em 1em;
  font-size: 20px;
  line-height: 1.5;
  font-weight: 900;
  text-align: center;
  color: #fff;
  background-color: #000;
}

.receipt-box-detail {
  padding: 20px 4%;
}

.receipt-img img {
  width: 100%;
}

.receipt-img01 {
  margin: 30px auto 0;
  width: 92%;
}

.receipt-img02 {
  margin: 30px auto 0;
  width: 96%;
}

.receipt-list {
  margin-top: 16px;
  font-size: 20px;
  font-weight: 900;
}
.receipt-list li::before {
  top: 0.25em;
  color: #fff;
  background-color: #FF0000;
  border-color: #FF0000;
}

.receipt-caution {
  margin: 10px auto 0;
  width: 92%;
}
.receipt-caution dt {
  padding: 0.5em 0;
  font-size: 20px;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: -0.09em;
  text-align: center;
  border-bottom: 3px solid #000;
}
.receipt-caution dd {
  padding-top: 16px;
  padding-bottom: 20px;
  font-size: 12px;
  font-weight: 700;
}

.ng-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 10%;
}

/* terms */
.sec-terms {
  position: relative;
  padding-top: 30px;
  padding-bottom: 16%;
  background-image: url(../img/sp/bg_dot01_a20.png);
  background-color: #50C8FF;
  background-size: var(--dot-size);
}
.sec-terms::before {
  background-position: left top;
  background-color: #fff;
}

.terms-box {
  margin-top: 24px;
  background-color: #fff;
  border: 3px solid #000;
  padding: 20px 4%;
  height: 300px;
  overflow: auto;
}
.terms-box::-webkit-scrollbar {
  width: 15px; /* 横幅設定 */
}
.terms-box::-webkit-scrollbar-thumb {
  background: #aaa; /* ハンドルの色 */
  border-radius: 20px;
}
.terms-box::-webkit-scrollbar-track {
  background-color: #eee;
}

.terms-dl {
  margin-top: 30px;
  font-size: 14px;
  font-weight: 500;
}
.terms-dl dt {
  padding-bottom: 0.5em;
  color: var(--primary-color);
  font-family: var(--font-maru);
  font-size: 15px;
  font-weight: 700;
  border-bottom: 2px solid #000;
}
.terms-dl dd {
  padding: 1em 0;
  font-size: 14px;
}

.form-agree {
  margin-top: 16px;
  font-weight: 700;
}

.form-agree__check {
  margin: 12px auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.form-agree__check label {
  font-size: 15px;
  display: flex;
  align-items: flex-start;
}
.form-agree__check label input {
  margin-right: 1em;
  transform: scale(1.5);
}

.form-agree__button {
  margin-top: 20px;
  position: relative;
  left: -2%;
  width: 102%;
}

.form-agree__button .c-btn01 {
  pointer-events: none;
  opacity: 0.5;
  cursor: not-allowed;
}

/* チェックされたら有効化 */
.form-agree__check:has(input:checked) + .form-agree__button .c-btn01 {
  pointer-events: auto;
  opacity: 1;
  cursor: pointer;
}