@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@400;700&display=swap');

@font-face {
  font-family: icon;
  src: url(../font/icon.eot);
  src: url(../font/icon.eot#iefix) format("embedded-opentype"),
       url(../font/icon.woff) format("woff"),
       url(../font/icon.ttf) format("truetype"),
       url(../font/icon.svg#icon) format("svg");
  font-weight: normal;
  font-style: normal;
}

 [class^="ico-"]:before, [class*=" ico-"]:before { display: inline-block; font-family: "icon"; font-size: 120%; font-style: normal; font-variant: normal; font-weight: normal; line-height: 1em; margin-left: .2em; margin-right: .2em; text-align: center; text-decoration: inherit; text-transform: none; width: 1em; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.ico-ok:before { content: '\e800'; }
.ico-pagetop:before { content: '\e802'; }
.ico-angle-left:before { content: '\f104'; }
.ico-angle-right:before { content: '\f105'; }
.ico-angle-up:before { content: '\f106'; }
.ico-angle-down:before { content: '\f107'; }

@keyframes slide-in {
 0% { opacity: 0; transform: translate3d(20px,0,0); }
 100% { opacity: 1; transform: translate3d(0,0,0); }
}

.jtb-nav-breadcrumb { margin-bottom: 25px; max-width: 1280px; }
.l-page { font-family: "M PLUS 1p", sans-serif; font-size: 16px; line-height: 1.6; text-align: center; width: 100%; }
.l-page * { box-sizing: border-box; margin: 0 auto; }
.l-page h1 { font-size: 18px; font-weight: bold; line-height: 1; margin: 0 auto 25px; max-width: 1280px; text-align: left; }
.l-page a { color: #20a0d9; }
.l-page a, .l-page button { transition: all .4s ease; }
.l-page img { display: block; margin: 0 auto; max-width: 100%; }
.l-page strong { font-weight: 700; }
.l-page .c-btn { border: none; border-radius: .75em; display: grid; max-width: 720px; place-items: center; width: 100%; }
.l-page .c-btn span { color: #000; font-weight: 700; }
.l-page .c-btn__entry { background-color: #ffe400; box-shadow: 0 .375em 0 0 #ddc600; }
.l-page .c-btn__wrap { margin-top: 2em; }
.l-page button { cursor: pointer; font-family: "M PLUS 1p", sans-serif; font-size: 16px; }
.l-page button.c-btn[disabled], .l-page .c-btn__gray { background: #ddd; pointer-events: none; }
.l-page button.c-btn[disabled] { box-shadow: 0 .375em 0 0 #ccc; }
.l-page button.c-btn[disabled] span, .l-page .c-btn__gray span { color: #999 !important; }
.l-page .c-credit { line-height: 1.4; margin: 0; text-align: left; }
.l-page .c-entry__head .c-label { align-items: center; background-color: #000; border-radius: 100vh; display: inline-flex; height: 3em; justify-content: center; padding: 0 2em; }
.l-page .c-entry__head .c-label span { color: #fff; font-size: 1.5em; font-weight: 700; }
.l-page .c-entry__head p { color: #2673df; font-weight: 700; }
.l-page .c-inner { display: flex; flex-direction: column; margin: 0 auto; max-width: 1280px; width: 89%; }
.js-btn-page-top { bottom: 50px; cursor: pointer; display: none; position: fixed; right: 50px; z-index: 100; }
.js-btn-page-top a { display: block; height: 17px; position: relative; width: 35px; }
.js-btn-page-top a::before { color: #000; content: "\e802"; display: inline-block; font-family: "icon"; font-size: 17px; height: 17px; width: 35px; }
.js-btn-page-top a:hover { opacity: .8; }

.l-contents { width: 100%; }
.sec-entry__block { background-color: #fff; width: 100%; }
.sec-entry__block p strong { font-size: 1.125em; font-weight: 700; }
.sec-entry__block p + p { margin-top: 1em; }
.sec-entry__block .c-check__block li { text-align: left; }
.sec-entry__block .c-check__list { margin-top: 2em; }
.sec-entry__block .c-check__item input[type=checkbox] { display: none; }
.sec-entry__block .c-check__box { cursor: pointer; display: inline-block; padding: .3125em 0 .3125em 1.875em; position: relative; width: auto; }
.sec-entry__block .c-check__box::before { background: #fff; border: 1px solid #ccc; border-radius: .1875em; content: ""; display: block; height: 1em; left: .3125em; position: absolute; top: .5em; width: 1em; }
.sec-entry__block .c-check__box::after { border-right: .375em solid #e0455e; border-bottom: .1875em solid #e0455e; content: ""; display: block; height: 1.25em; left: .4375em; margin-top: -.5em; opacity: 0; position: absolute; top: .5em; transform: rotate(45deg) translate3d(0,2px,0) scale3d(.7,.7,1); transition: transform .2s ease-in-out, opacity .2s ease-in-out; width: .5625em; }
.sec-entry__block input[type=checkbox]:checked + .c-check__box::before { border-color: #666; }
.sec-entry__block input[type=checkbox]:checked + .c-check__box::after { opacity: 1; transform: rotate(45deg) scale3d(1,1,1); }
.sec-entry { width: 100%; }
.sec-entry__list { display: flex; flex-direction: column; gap: 3em; width: 100%; }
.sec-entry__item { width: 100%; }
.sec-entry .c-message { background-color: #fff; border: 2px solid #e90004; border-radius: .625em; margin: 0 auto; max-width: 1080px; padding: 2.25em 2em; }
.sec-entry .c-message p { color: #e90004; font-weight: 700; }
.sec-guideline { background-color: #fff; }
.sec-guideline dl { margin-top: 2em; text-align: justify; }
.sec-guideline dl dt { font-weight: 700; }
.sec-guideline dl dd { line-height: 1.5; }
.sec-guideline dl p + ul, .sec-guideline dl p + p { margin-top: 1em; }
.sec-guideline dl ul li { display: list-item; list-style: disc; list-style-position: outside; margin-left: 1em; }
.sec-guideline dl li + li { padding-top: .285714em; }
.sec-guideline dl li ul li { margin-left: 1em; list-style-type: circle; }
.sec-guideline .c-heading { color: #2673df; font-weight: 700;  }
.sec-guideline .c-link__prev { margin-bottom: 2em; text-align: right; }
.sec-guideline .c-flow__item { align-items: center; border: 1px solid #2673df; display: flex; }
.sec-guideline .c-flow__item + .c-flow__item { margin-top: 1em; }
.sec-guideline .c-flow__item * { margin: 0; }
.sec-guideline .c-flow__title { font-weight: 700; }
.sec-guideline .c-flow__title span { display: block; font-size: .875em; font-weight: 400; }
.sec-guideline .c-flow__no { color: #2673df; font-weight: 700; line-height: 1; text-align: center; }
.sec-guideline .c-flow__no em { font-size: 2em; display: block; }
.sec-guideline .c-notice__list li { list-style: none; margin-left: 1.25em; text-indent: -1.25em; }
.sec-guideline .c-notice__list li::before { content: "※"; }

@media screen and (min-width:768px) and ( max-width:1280px) {
  .l-page { font-size: 1.25vw; margin: 0; }
}
@media screen and (min-width:768px){
  .sp-item { display: none; }
  .breadcrumb-upper { margin: 0 auto 25px; max-width: 1230px; padding: 0 .5em; text-align: left; }
  .breadcrumb-upper__fix, .breadcrumb-upper__scroll, .breadcrumb-upper__item { display: inline-block; font-size: 10px; }
  .breadcrumb-upper__item { line-height: 2.1; margin-left: 1.5em; padding-left: .2em; position: relative; }
  .breadcrumb-upper__item::before { color: #999; content: ">"; left: -1.1em; line-height: 2.1; position: absolute; top: 0; }
  .l-page a:hover { color: #4181e1; text-decoration: none; }
  .l-page a:hover img { opacity: .7; }
  .l-page .c-btn { height: 6em; }
  .l-page .c-btn__entry span { font-size: 2em; }
  .l-page .c-btn__gray span { font-size: 1.5em; }
  .l-page .c-btn__entry:hover { box-shadow: 0 0 0 0 #ddc600; translate: 0 .375em; }
  .l-page .c-btn__wrap + .c-check__block { margin-top: 4em; }
  .l-page .c-credit small { font-size: .875em; }
  .l-page .c-entry__title { margin: 1em auto; width: 65%; }
  .l-page .c-entry__head p { font-size: 1.375em; }
  .l-page .c-flex { display: flex; justify-content: space-between; }
  .l-page .c-inner { gap: 3em; }
  .l-contents { padding-top: 2.5em; }
  .sec-entry .c-btn span { font-size: 1.5em; }
  .sec-entry .c-message p { font-size: 2em; }
  .sec-entry__block { padding: 4em 6.25em; }
  .sec-entry__block .c-check__list { display: inline-block; }
  .sec-guideline { padding: 3em 6.25em 5em; }
  .sec-guideline .c-heading { font-size: 2em; }
  .sec-guideline .c-flow__item { padding: 0 2em; }
  .sec-guideline .c-flow__item img { width: 7.5em; }
  .sec-guideline dl { border-top: 1px solid #dedede; font-size: .9375em; }
  .sec-guideline dl dt { clear: left; float: left; padding-left: 1em; padding-top: 2em; width: 20%; }
  .sec-guideline dl dd { border-bottom: 1px solid #dedede; padding: 2em 1em 2em 23%; }
  .sec-guideline a:hover { text-decoration: underline; }
}

@media screen and (max-width:767px){
  #JTBGF-ly_footer.JTBGF-ly_footer { margin-top: 0 !important; }
  .breadcrumb-upper { background-color: #fff; border-top: 1px solid #d7d7d7; display: flex; flex-wrap: nowrap; font-size: 10px; line-height: 3rem; margin-top: 5em; overflow: hidden; position: relative; }
  .breadcrumb-upper__fix { box-shadow: 6px 0 10px 0 rgba(0, 0, 0, .3); position: relative; transition: box-shadow .3s; width: 7em; z-index: 3; }
  .breadcrumb-upper__fix a { padding-left: .5rem; }
  .breadcrumb-upper__scroll { flex: 1; overflow: hidden; }
  .breadcrumb-upper__list { display: flex; flex-wrap: nowrap; height: 3rem; overflow-x: scroll; overflow-y: hidden; white-space: nowrap; }
  .breadcrumb-upper__item a { padding: 0 .5rem 0 1.8rem; }
  .breadcrumb-upper__item:last-child { padding: 0 1.2rem 0 1.8rem; }
  .breadcrumb-upper__fix a, .breadcrumb-upper__item a { display: block; background-color: #fff; text-align: center; position: relative; }
  .breadcrumb-upper__fix a::before, .breadcrumb-upper__item a::before, .breadcrumb-upper__fix a:after, .breadcrumb-upper__item a:after { content: ""; border-style: solid; border-width: 2rem 0 2rem 1rem; position: absolute; top: -.5rem; }
  .breadcrumb-upper__fix a::before, .breadcrumb-upper__item a::before { border-color: transparent transparent transparent #fff; right: -.9rem; z-index: 2; }
  .breadcrumb-upper__fix a::after, .breadcrumb-upper__item a::after { border-color: transparent transparent transparent #d7d7d7; right: -1rem; z-index: 1; }
  .js-btn-page-top { bottom: 20px; right: 20px; }
  .js-btn-page-top a { background-color: #999; border-radius: 6px; display: block; height: 30px; width: 30px; }
  .js-btn-page-top a::before { color: #fff; content: "\f106"; display: inline-block; font-family: "icon"; line-height: 29px; width: auto; }
  .l-page { font-size: 3.2vw; padding: 20px 0 0; }
  .l-page h1 { margin-bottom: 20px; padding: 0 1%; }
  .l-page .c-btn { height: 4em; }
  .l-page .c-btn__entry span { font-size: 1.25em; }
  .l-page .c-btn__gray span { font-size: 1em; }
  .l-page .c-btn__wrap + .c-check__block { margin-top: 3em; }
  .l-page .c-inner { gap: 2em; }
  .l-page .c-sec { margin: 1.5em auto 0; }
  .sec-entry .c-message p { font-size: 1.75em; }
  .sec-entry__block { padding: 3em 1.825em; }
  .sec-guideline { padding: 2em 7%; }
  .sec-guideline .c-heading { font-size: 1.625em; }
  .sec-guideline .c-flow__item { padding: 0 1em; }
  .sec-guideline .c-flow__item img { width: 5.5em; }
  .sec-guideline .c-flow__title { font-size: .875em; }
  .sec-guideline dt { border-bottom: 1px solid #dedede; width: 100%; }
  .sec-guideline dd + dt { padding-top: 1em; }
  .sec-guideline dd { padding: 1em 0; }
}
