/* RESET */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, div {
  display: block;
  box-sizing: border-box;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  background: transparent;
  transition: all 0.6s ease-out;
  text-decoration: none;
}

a:hover img {
  opacity: 0.6;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

ul {
  list-style-type: none;
}

ol {
  list-style-type: decimal;
}

figure img, h2 img, h3 img, h4 img {
  width: 100%;
  height: auto;
}

.forPC {
  display: block;
}

.forSP {
  display: none;
}

img {
  image-rendering: -webkit-optimize-contrast;
  width: 100%;
}

html {
  font-size: 0.6666666667vw;
  overflow-x: hidden;
  overflow-y: auto;
  scroll-behavior: smooth;
}

@media screen and (max-width: 750px) {
  .forPC {
    display: none;
  }

  .forSP {
    display: block;
  }

  html {
    font-size: 1.3333333333vw;
    overflow-x: hidden;
  }
}
@media screen and (min-width: 1400px) {
  html {
    font-size: 10px;
  }
}
@media screen and (min-width: 751px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
body {
  font-family: 'Noto Sans JP', sans-serif;
  color: #221714;
  overflow-x: hidden;
}

.mv {
  width: 100%;
  height: 80rem;
  background: url("../images/bg_mv.webp") no-repeat center top;
  background-size: 2600px;
}
@media screen and (max-width: 768px) {
  .mv {
    height: 198vw;
    background: url("../images/bg_mv_sp.png") repeat-X center top;
    background-size: 100%;
    position: relative;
    z-index: 1;
  }
}
.mv .mvBody {
  width: 132rem;
  margin: auto;
  position: relative;
  padding-top: 43.6rem;
}
@media screen and (max-width: 768px) {
  .mv .mvBody {
    width: 100%;
    padding-top: 95.4vw;
  }
}
.mv .mvBody figure.products {
  width: 81.9rem;
  position: absolute;
  top: 25.5rem;
  left: 21rem;
}
@media screen and (max-width: 768px) {
  .mv .mvBody figure.products {
    width: 101.3vw;
    top: 72vw;
    left: -0.6vw;
  }
}
.mv .mvBody h1 {
  position: absolute;
  top: 3.3rem;
  left: 14.6rem;
  width: 97rem;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .mv .mvBody h1 {
    width: 86vw;
    top: 18.5vw;
    left: 10vw;
    transform: translateX(0);
  }
}
.mv .mvBody h1 img {
  width: 100%;
  height: auto;
}
.mv .mvBody .logo {
  position: absolute;
  top: 1.8rem;
  left: 0;
  width: 11.4rem;
}
@media screen and (max-width: 768px) {
  .mv .mvBody .logo {
    top: 2.7rem;
    left: 2.7em;
    width: 11.4vw;
  }
}
.mv .mvBody .logo img {
  width: 100%;
  height: auto;
}
.mv .mvBody .logo_event {
  position: absolute;
  top: 1.8rem;
  right: 0;
  width: 14.9rem;
}
@media screen and (max-width: 768px) {
  .mv .mvBody .logo_event {
    width: 17.9vw;
    top: 3.8vw;
    right: 13.8vw;
  }
}
.mv .mvBody .logo_event img {
  width: 100%;
  height: auto;
}
.mv .mvBody .logo_sub {
  position: absolute;
  top: 15rem;
  left: 0;
  width: 17.5rem;
}
@media screen and (max-width: 768px) {
  .mv .mvBody .logo_sub {
    width: 23.3vw;
    top: 2.7rem;
    left: 17.3vw;
  }
}
.mv .mvBody .logo_sub img {
  width: 100%;
  height: auto;
}
.mv .prizeBox {
  width: 110rem;
  margin: auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .mv .prizeBox {
    width: 90vw;
    flex-wrap: wrap;
    gap: 2vw;
  }
}
.mv .prizeBox figure {
  width: 69rem;
}
@media screen and (max-width: 768px) {
  .mv .prizeBox figure {
    width: 100%;
  }
}
.mv .prizeBox figure:nth-of-type(2) {
  width: 38rem;
}
@media screen and (max-width: 768px) {
  .mv .prizeBox figure:nth-of-type(2) {
    width: 100%;
  }
}

/*
nav {
		width:100%;
		height:13rem;
		box-sizing: border-box;
		background:url("../images/bg_menu01.webp") repeat-x top center;
		background-size:4rem;
		padding-top:2.2rem;
	 	position:relative;
		z-index:3;
		transition:all 0.4s ease;
		box-shadow:0 0.5rem 1.5rem rgba(0,0,0,0.4);


		
		&.fixed {
			position:fixed;
			top:-2.3rem;
			animation: fadeIn 2s ease 0s 1 normal;


			@keyframes fadeIn {
				0% {
				  transform: translateY(-100%);
				}
				100% {
					transform: translateY(0);
				}
			  }
		}

		
	}
*/
.navPC {
  width: 100%;
  height: 13rem;
  box-sizing: border-box;
  background: url(../images/bg_menu01.webp) repeat-x top center;
  background-size: 4rem;
  padding-top: 2.2rem;
  position: relative;
  z-index: 3;
  transition: all 0.4s ease;
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.3);
}

ul.menuPC {
  width: 100rem;
  height: 8.1rem;
  margin: auto;
  position: relative;
  padding-left: 5.5rem;
  padding-right: 8rem;
  display: flex;
  justify-content: space-between;
  box-sizing: border-box;
}
ul.menuPC li img {
  width: 100%;
  height: auto;
}
ul.menuPC li:nth-of-type(1) {
  width: 24.9rem;
}
ul.menuPC li:nth-of-type(2) {
  width: 12.27rem;
  margin-top: 1.6rem;
}
@media screen and (max-width: 768px) {
  ul.menuPC li:nth-of-type(2) {
    margin-top: 6.2vw;
  }
}
ul.menuPC li:nth-of-type(3) {
  width: 22.6rem;
}

.sec01 {
  width: 100%;
  height: auto;
  background: linear-gradient(to top, #F59428 0%, #fff8ab 70%, #FFFACF 100%);
  padding-top: 2rem;
  padding-bottom: 14rem;
}
@media screen and (max-width: 768px) {
  .sec01 {
    height: auto;
    padding-top: 9.6vw;
    padding-bottom: 21vw;
  }
}
.sec01 .inner {
  width: 128.4rem;
  margin: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .sec01 .inner {
    width: 100%;
  }
}
.sec01 .inner::after {
  content: '';
  width: 165.3rem;
  height: 572.691rem;
  background: url("../images/bg_sec01_shin_after.webp") no-repeat top center;
  background-size: 100%;
  position: absolute;
  top: 8.7rem;
  left: -20.4rem;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .sec01 .inner::after {
    background-image: url("../images/bg_sec01_shin_after_sp01.png"), url("../images/bg_sec01_shin_after_sp02.png");
    background-position: top center, bottom -25vw center;
    background-repeat: no-repeat, no-repeat;
    background-size: 100%, 100%;
    width: 100%;
    height: 100%;
    top: -15vw;
    left: 0;
  }
}
.sec01 .inner h2 {
  width: 104rem;
  margin-left: 11rem;
}
@media screen and (max-width: 768px) {
  .sec01 .inner h2 {
    width: 94.8vw;
    margin-left: 0;
  }
}
.sec01 .inner h3 {
  width: 95.8rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .sec01 .inner h3 {
    width: 72.9vw;
  }
}
.sec01 .inner ul.presents {
  width: 100%;
  box-sizing: border-box;
  padding-right: 2rem;
  display: flex;
  justify-content: space-between;
  margin: 2.6rem auto 5.6rem;
}
@media screen and (max-width: 768px) {
  .sec01 .inner ul.presents {
    flex-direction: column;
    margin: 2.6rem auto 8.2rem;
  }
}
.sec01 .inner ul.presents li {
  width: 65.2rem;
}
@media screen and (max-width: 768px) {
  .sec01 .inner ul.presents li {
    width: 98.5vw;
    margin-left: 0.5vw;
  }
}
.sec01 .inner ul.presents li img {
  width: 100%;
}
.sec01 .inner ul.presents li:nth-child(2) {
  width: 60rem;
}
@media screen and (max-width: 768px) {
  .sec01 .inner ul.presents li:nth-child(2) {
    width: 90vw;
    margin-top: 4.8vw;
    margin-left: 5vw;
  }
}

.sec02 {
  width: 100%;
  height: auto;
  background: url("../images/bg_shin_sec02.webp") no-repeat center top #f5e828;
  background-size: 2600px;
  padding-top: 9rem;
  padding-bottom: 9.8rem;
  overflow-x: hidden;
}
@media screen and (max-width: 768px) {
  .sec02 {
    height: auto;
    background: url(../images/bg_shin_sec02_sp.webp) no-repeat center top -0.2vw #f5e828;
    background-size: 101%;
    padding-top: 21vw;
    padding-bottom: 19vw;
  }
}
.sec02 .inner {
  width: 100rem;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .sec02 .inner {
    width: 100%;
  }
}
.sec02 .inner::after {
  content: '';
  width: 162.8rem;
  height: 230.2rem;
  background: url("../images/bg_shin_sec02_after00.webp") no-repeat top center;
  background-size: 100%;
  position: absolute;
  top: -6rem;
  left: -34rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner::after {
    display: none;
  }
}
.sec02 .inner h2 {
  width: 83.5rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .sec02 .inner h2 {
    width: 93vw;
  }
}
.sec02 .inner h3.kikan {
  width: 88.6rem;
  margin: auto auto 2rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner h3.kikan {
    width: 64.4vw;
    margin: auto auto 0;
  }
}
.sec02 .inner h3.detail {
  width: 95.8rem;
  margin: auto auto 2rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner h3.detail {
    width: 72.9vw;
    margin: auto auto 0;
  }
}
.sec02 .inner p.lead {
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 3rem;
  margin: 2.4rem auto 3rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .sec02 .inner p.lead {
    font-size: 4.5vw;
    line-height: 6.2vw;
    margin: 5vw auto 3rem;
  }
}
.sec02 .inner figure.takatoshi {
  width: 114.4rem;
  margin: auto 0 2rem -6.5rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner figure.takatoshi {
    width: 100.267vw;
    margin: -3.2vw 0 6.9vw 1vw;
  }
}
.sec02 .inner figure.other {
  width: 87rem;
  margin: 4.5rem auto 2rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner figure.other {
    width: 84vw;
  }
}
.sec02 .inner .takatoshihohou {
  width: 80rem;
  margin: auto auto 8rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .sec02 .inner .takatoshihohou {
    width: 74vw;
    margin: auto;
  }
}
.sec02 .inner .takatoshihohou h3 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 1.2rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner .takatoshihohou h3 {
    font-size: 5vw;
  }
}
.sec02 .inner .takatoshihohou h3:nth-of-type(2) {
  margin-top: 3rem;
}
.sec02 .inner .takatoshihohou p.lead {
  font-size: 1.9rem;
  font-weight: 400;
  line-height: 3rem;
  margin: 0;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .sec02 .inner .takatoshihohou p.lead {
    font-size: 3.42vw;
    line-height: 5.4vw;
    text-align: justify;
  }
}
.sec02 .inner .takatoshihohou p.attention {
  font-size: 1.6rem;
  line-height: 2.6rem;
}
@media screen and (max-width: 768px) {
  .sec02 .inner .takatoshihohou p.attention {
    font-size: 2.88vw;
    line-height: 4.68vw;
    text-align: justify;
    font-feature-settings: "palt";
  }
}
.sec02 .inner .takatoshihohou p.attention a {
  text-decoration: underline;
  color: inherit;
}
.sec02 .inner p.btnOubo {
  width: 45rem;
  margin: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .sec02 .inner p.btnOubo {
    width: 68vw;
    margin: 14vw auto auto;
  }
}

.sec03 {
  width: 100%;
  background: #f01e00;
  padding-top: 11rem;
  padding-bottom: 23rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .sec03 {
    padding-top: 9.8vw;
    padding-bottom: 18.4vw;
  }
}
.sec03::before {
  content: '';
  width: 100%;
  height: 40rem;
  background: #fbf6a9;
  position: absolute;
  top: 6.9rem;
  left: 0;
}
@media screen and (max-width: 768px) {
  .sec03::before {
    top: 7.5vw;
    height: 72.2vw;
  }
}
.sec03 h2.yakisobanohi {
  width: 91.4rem;
  margin: auto auto 4rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .sec03 h2.yakisobanohi {
    width: 97vw;
    margin: auto auto 5.6vw;
  }
}
.sec03 h3 {
  font-size: 2.9rem;
  color: #fff;
  margin: auto auto 1.2rem;
  text-align: center;
}
.sec03 p.basho {
  font-size: 3.8rem;
  color: #fff;
  margin: auto auto 12rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .sec03 p.basho {
    font-size: 3.8vw;
    margin: auto auto 11vw;
  }
}
.sec03 figure.oshirase {
  width: 64.7rem;
  margin: 2.3rem auto;
}
@media screen and (max-width: 768px) {
  .sec03 figure.oshirase {
    width: 84vw;
  }
}
.sec03 p.detail {
  font-size: 3.6rem;
  font-weight: 700;
  color: #fff67f;
  margin: auto;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .sec03 p.detail {
    font-size: 5vw;
  }
}

table.event {
  margin: 6.4rem auto 7.2rem;
  background: #fff;
  font-size: 2rem;
  line-height: 3rem;
  width: 70rem;
}
@media screen and (max-width: 768px) {
  table.event {
    width: 90vw;
    font-size: 3vw;
  }
}
table.event th {
  font-weight: 700;
  border-bottom: 1px solid #f01e00;
  border-right: 1px solid #f01e00;
  text-align: center;
  vertical-align: middle;
  padding: 0 4.6rem;
}
@media screen and (max-width: 768px) {
  table.event th {
    padding: 0 3vw;
  }
}
table.event td {
  border-bottom: 1px solid #f01e00;
  padding: 3rem 4.6rem;
}
@media screen and (max-width: 768px) {
  table.event td {
    padding: 3.2vw 3.8vw;
  }
}

figure.lastyer {
  width: 84rem;
  margin: auto auto 7.4rem;
}
@media screen and (max-width: 768px) {
  figure.lastyer {
    width: 58vw;
  }
}

figure.goods01, figure.goods02 {
  width: 90rem;
  margin: auto auto 5rem;
}
@media screen and (max-width: 768px) {
  figure.goods01, figure.goods02 {
    width: 90vw;
    margin: auto auto 7.2vw;
  }
}

figure.tosns {
  width: 81.2rem;
  margin: 12.6rem auto 11rem;
}
@media screen and (max-width: 768px) {
  figure.tosns {
    width: 60.4vw;
    margin: 14vw auto 16vw;
  }
}

ul.snsIcons {
  width: auto;
  margin: auto auto 11rem;
  display: flex;
  justify-content: center;
  gap: 5.4rem;
}
@media screen and (max-width: 768px) {
  ul.snsIcons {
    width: auto;
    margin: auto auto 13.6vw;
    gap: 10.9vw;
  }
}
ul.snsIcons li {
  width: 10rem;
}
@media screen and (max-width: 768px) {
  ul.snsIcons li {
    width: 18.6vw;
  }
}

.attentionBox {
  width: 70.5rem;
  margin: auto;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .attentionBox {
    width: 84.6vw;
  }
}
.attentionBox h3 {
  font-size: 1.9rem;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .attentionBox h3 {
    font-size: 3.3vw;
  }
}
.attentionBox ul {
  list-style-type: disc;
  list-style-position: outside;
  margin-left: 2.5rem;
}
@media screen and (max-width: 768px) {
  .attentionBox ul {
    margin-left: 4vw;
  }
}
.attentionBox ul li {
  font-size: 1.6rem;
  line-height: 2.6rem;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .attentionBox ul li {
    font-size: 2.88vw;
    line-height: 4.6rem;
  }
}

.sec04 {
  width: 100%;
  background: #fff;
  padding-top: 11rem;
  padding-bottom: 11.8rem;
  border-bottom: 1px solid #707070;
}
@media screen and (max-width: 768px) {
  .sec04 {
    padding-bottom: 12vw;
  }
}
.sec04 h2 {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  .sec04 h2 {
    font-size: 3.83vw;
  }
}
.sec04 h3 {
  font-size: 3.2rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  .sec04 h3 {
    font-size: 5.1vw;
    line-heght: 6.1vw;
  }
}
.sec04 .viaTel {
  margin: auto auto 2.8rem;
  display: flex;
  justify-content: center;
  gap: 4.8rem;
}
@media screen and (max-width: 768px) {
  .sec04 .viaTel {
    width: 79.5vw;
    flex-direction: column;
    gap: 3vw;
    margin: auto auto 6.4vw;
  }
}
.sec04 .viaTel span {
  font-size: 1.8rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .sec04 .viaTel span {
    font-size: 3vw;
    text-align: center;
  }
}
.sec04 .viaTel p {
  width: 50rem;
}
@media screen and (max-width: 768px) {
  .sec04 .viaTel p {
    width: 79.5vw;
    text-align: center;
  }
}
.sec04 .viaTel p img {
  width: 100%;
  height: auto;
}
.sec04 figure.uketsuke {
  width: 85.7rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .sec04 figure.uketsuke {
    width: 68vw;
  }
}
.sec04 ul {
  margin: auto;
  display: flex;
  justify-content: center;
  gap: 3.4rem;
}
.sec04 ul li {
  font-size: 2rem;
}
.sec04 ul li span {
  font-size: 1.9rem;
  border: 0.082rem solid #221714;
  padding: 0 0.3rem;
  margin-right: 1.2rem;
}

.howto25 {
  width: 100rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .howto25 {
    width: 84vw;
  }
}
.howto25 h3.h3_howto {
  width: 100%;
  height: 6.8rem;
}
@media screen and (max-width: 768px) {
  .howto25 h3.h3_howto {
    height: 13vw;
  }
}
.howto25 .howtoInner {
  padding: 4.5rem 12rem;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner {
    padding: 5vw;
    padding-bottom: 13vw;
  }
}
.howto25 .howtoInner p.lead {
  font-size: 1.9rem;
  line-height: 3rem;
  margin-bottom: 1.4rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner p.lead {
    font-size: 3.4vw;
    line-height: 5.4vw;
  }
}
.howto25 .howtoInner p.attention {
  font-size: 1.6rem;
  line-height: 2.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner p.attention {
    font-size: 2.88vw;
    line-height: 4.68vw;
  }
}
.howto25 .howtoInner .oubosaki {
  margin: 2.4rem auto 6.4rem;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
  padding: 2.8rem 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .oubosaki {
    margin: 5.6vw auto 13vw;
  }
}
.howto25 .howtoInner .oubosaki p {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 3.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .oubosaki p {
    font-size: 3.8vw;
    line-height: 5.8vw;
  }
}
.howto25 .howtoInner .oubosaki p:nth-of-type(2) {
  margin-top: 1.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .oubosaki p:nth-of-type(2) {
    margin-top: 0;
  }
}
.howto25 .howtoInner .case {
  padding-bottom: 7.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .case {
    padding-bottom: 13vw;
  }
}
.howto25 .howtoInner .case h4 {
  margin-bottom: 3.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .case h4 {
    margin-bottom: 5.8vw;
  }
}
.howto25 .howtoInner .case p.btn_dl {
  width: 42rem;
  margin: 1.2rem auto auto;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .case p.btn_dl {
    width: 68vw;
  }
}
.howto25 .howtoInner .steps {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.howto25 .howtoInner .steps dl {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  padding-bottom: 5.4rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl {
    padding-bottom: 11vw;
  }
}
.howto25 .howtoInner .steps dl.step_01 {
  width: 100%;
}
.howto25 .howtoInner .steps dl.step_01 figure {
  width: 66.7rem;
  margin: 4.6rem auto auto;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_01 figure {
    width: 74vw;
  }
}
.howto25 .howtoInner .steps dl.step_02 {
  width: 35rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_02 {
    width: 100%;
  }
}
.howto25 .howtoInner .steps dl.step_02 figure {
  width: 19.2rem;
  margin: 4.6rem auto auto;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_02 figure {
    width: 42.5vw;
  }
}
.howto25 .howtoInner .steps dl.step_03 {
  width: 35rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_03 {
    width: 100%;
  }
}
.howto25 .howtoInner .steps dl.step_03 figure {
  width: 25.8rem;
  margin: 4.6rem 0 auto 8rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_03 figure {
    width: 45vw;
    margin: 4.6rem 0 auto 20vw;
  }
}
.howto25 .howtoInner .steps dl.step_04 {
  width: 21.9rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_04 {
    width: 100%;
  }
}
.howto25 .howtoInner .steps dl.step_04 figure {
  width: 15.3rem;
  margin: 3rem auto auto;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_04 figure {
    width: 40vw;
    margin: 6vw auto auto;
  }
}
.howto25 .howtoInner .steps dl.step_05 {
  width: 21.9rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_05 {
    width: 100%;
  }
}
.howto25 .howtoInner .steps dl.step_05 figure {
  width: 19.8rem;
  margin: 3rem auto auto 3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_05 figure {
    width: 51.9vw;
    margin: 6vw auto auto 17vw;
  }
}
.howto25 .howtoInner .steps dl.step_06 {
  width: 21.9rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_06 {
    width: 100%;
  }
}
.howto25 .howtoInner .steps dl.step_06 figure {
  width: 19.4rem;
  margin: -0.5rem auto 0 4rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl.step_06 figure {
    width: 45vw;
    margin: 6vw auto auto 22vw;
  }
}
.howto25 .howtoInner .steps dl dd p {
  font-size: 1.8rem;
  line-height: 2.7rem;
  text-align: center;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl dd p {
    font-size: 3.8vw;
    line-height: 6vw;
  }
}
.howto25 .howtoInner .steps dl dd p.alignL {
  text-align: left;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .steps dl dd p.alignL {
    text-align: center;
  }
}
.howto25 .howtoInner .tableBox {
  margin-bottom: 5.7rem;
}
.howto25 .howtoInner .tableBox h3 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .tableBox h3 {
    font-size: 5vw;
  }
}
.howto25 .howtoInner .tableBox table {
  border-right: 1px solid #707070;
  border-bottom: 1px solid #707070;
}
.howto25 .howtoInner .tableBox table th {
  border-left: 1px solid #707070;
  border-top: 1px solid #707070;
  width: 13.8rem;
  text-align: center;
  vertical-align: middle;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .tableBox table th {
    width: 14vw;
    font-size: 3.24vw;
    line-height: 4.08vw;
  }
}
.howto25 .howtoInner .tableBox table td {
  border-left: 1px solid #707070;
  border-top: 1px solid #707070;
  width: 37.6rem;
  vertical-align: top;
  padding: 2rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .tableBox table td {
    width: calc(100% - 14vw);
    padding: 2vw;
  }
}
.howto25 .howtoInner .tableBox table td.figs {
  width: calc(100% - 51.4rem);
  padding: 1rem 0;
  border-left: none;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .tableBox table td.figs {
    display: none;
  }
}
.howto25 .howtoInner .tableBox table td.figs img.fig01 {
  width: 20.9rem;
}
.howto25 .howtoInner .tableBox table td.figs img.fig02 {
  width: 24.6rem;
}
.howto25 .howtoInner .tableBox table td.figs img.fig03 {
  width: 21.4rem;
}
.howto25 .howtoInner .tableBox table td.figs img.fig04 {
  width: 16.7rem;
}
.howto25 .howtoInner .tableBox table td img.fig_sp01 {
  width: 47.2vw;
  margin: 0 0 1vw 5vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp02 {
  width: 35.8vw;
  margin: 0.5vw 0 1vw 16vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp03 {
  width: 27.2vw;
  margin: -7.5vw 0 1vw 31vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp04 {
  width: 42.4vw;
  margin: 1vw 0 1vw 8vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp05 {
  width: 43.3vw;
  margin: 1vw 0 1vw 8vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp06 {
  width: 53.3vw;
  margin: 1vw 0 1.5vw 0;
}
.howto25 .howtoInner .tableBox table td img.fig_sp07 {
  width: 44.8vw;
  margin: 1vw 0 1.5vw 5vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp08 {
  width: 44.5vw;
  margin: 1vw 0 1.5vw 5vw;
}
.howto25 .howtoInner .tableBox table td img.fig_sp09 {
  width: 51.2vw;
  margin: 1vw 0 1.5vw 5vw;
}
.howto25 .howtoInner .tableBox table td p {
  font-size: 1.6rem;
  line-height: 2.6rem;
  background: url("../images/bg_circle.webp") no-repeat top 0.6rem left;
  background-size: 1.4rem;
  padding-left: 1.4rem;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .tableBox table td p {
    font-size: 2.88vw;
    line-height: 4.68vw;
    background: url("../images/bg_circle.webp") no-repeat top 0.6rem left;
    background-size: 2.59vw;
    padding-left: 2.7vw;
  }
}
.howto25 .howtoInner .about {
  margin-bottom: 5.4rem;
}
.howto25 .howtoInner .about h3 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about h3 {
    font-size: 5vw;
  }
}
.howto25 .howtoInner .about dl {
  margin-bottom: 3.5rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl {
    flex-direction: column;
  }
}
.howto25 .howtoInner .about dl dt.about01 {
  width: 44rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dt.about01 {
    width: 100%;
  }
}
.howto25 .howtoInner .about dl dt.about02 {
  width: 64rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dt.about02 {
    width: 100%;
  }
}
.howto25 .howtoInner .about dl dt.about03 {
  width: 64rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dt.about03 {
    width: 100%;
  }
}
.howto25 .howtoInner .about dl dt h4 {
  font-size: 1.9rem;
  font-weight: 700;
  margin-bottom: 0;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dt h4 {
    font-size: 3.42vw;
  }
}
.howto25 .howtoInner .about dl dt p {
  font-size: 1.9rem;
  line-height: 3rem;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dt p {
    font-size: 3.42vw;
    line-height: 5.4vw;
  }
}
.howto25 .howtoInner .about dl dd img.about01 {
  width: 33.5rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dd img.about01 {
    width: 80.2vw;
    margin: 2vw 0 auto -1.5vw;
  }
}
.howto25 .howtoInner .about dl dd img.about02 {
  width: 9.7rem;
  margin: 1rem 2rem 0 0;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dd img.about02 {
    width: 42.9vw;
    margin: -4vw auto auto 15vw;
  }
}
.howto25 .howtoInner .about dl dd img.about03 {
  width: 13.4rem;
  margin: 2rem -2rem 0 0;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .about dl dd img.about03 {
    width: 53.6vw;
    margin: -2vw auto auto 12vw;
  }
}
.howto25 .howtoInner .announce {
  margin-bottom: 5.4rem;
}
.howto25 .howtoInner .announce h3 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .announce h3 {
    font-size: 5vw;
  }
}
.howto25 .howtoInner .announce p.lead {
  font-size: 1.9rem;
  line-height: 3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .announce p.lead {
    font-size: 3.42vw;
    line-height: 5.4vw;
  }
}
.howto25 .howtoInner .announce p.lead strong {
  font-weight: 700;
  font-feature-settings: "palt";
}
.howto25 .howtoInner .announce p.attention {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .announce p.attention {
    font-size: 2.88vw;
    line-height: 4.68vw;
  }
}
.howto25 .howtoInner .kiyaku h3 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .kiyaku h3 {
    font-size: 5vw;
  }
}
.howto25 .howtoInner .kiyaku p.lead {
  font-size: 1.6rem;
  line-height: 2.6rem;
}
@media screen and (max-width: 768px) {
  .howto25 .howtoInner .kiyaku p.lead {
    font-size: 2.88vw;
    line-height: 4.68vw;
  }
}

.camp01 {
  width: 100%;
  padding-bottom: 0;
  position: relative;
}
.camp01::before {
  display: none;
  content: '';
  width: 100rem;
  height: calc(100% - 9rem);
  display: block;
  position: absolute;
  top: 9.5rem;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-size: 2.8rem, 2.8rem;
}
@media screen and (max-width: 768px) {
  .camp01::before {
    width: 100%;
    height: calc(100% + 10vw);
    margin-left: 0;
    top: -10vw;
    left: 0;
    transform: translateX(0);
    background-size: 2.8vw, 2.8vw;
  }
}
.camp01 h2 {
  width: 90.83rem;
  margin: auto;
  scroll-margin-top: 10rem;
}
.camp01 h2.fixed {
  scroll-margin-top: 0;
}
@media screen and (max-width: 768px) {
  .camp01 h2 {
    width: 98.4vw;
    margin-left: 0.6vw;
    position: relative;
    z-index: 2;
  }
}
.camp01 .detail {
  width: 116rem;
  margin: 4.8rem auto 8rem;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .camp01 .detail {
    width: 85vw;
    flex-wrap: wrap;
    gap: 1.9vw;
  }
}
.camp01 .detail li {
  width: 55.57rem;
}
@media screen and (max-width: 768px) {
  .camp01 .detail li {
    width: 100%;
  }
}
.camp01 .detail li img {
  width: 100%;
  height: auto;
}
.camp01 .howto {
  width: 88rem;
  margin: auto;
  background: #fff;
  box-sizing: border-box;
  padding-bottom: 12rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp01 .howto {
    width: 84vw;
  }
}
.camp01 .howto .l001 {
  width: 14.7rem;
  position: absolute;
  top: -5rem;
  left: -25rem;
}
.camp01 .howto .l002 {
  width: 12.4rem;
  position: absolute;
  top: 36rem;
  left: -20rem;
}
.camp01 .howto .l003 {
  width: 13.6rem;
  position: absolute;
  top: 68rem;
  left: -29rem;
}
.camp01 .howto .l004 {
  width: 14.7rem;
  position: absolute;
  top: 99rem;
  left: -27.5rem;
}
.camp01 .howto .l005 {
  width: 12.36rem;
  position: absolute;
  top: 147rem;
  left: -25rem;
}
.camp01 .howto .l006 {
  width: 13.1rem;
  position: absolute;
  top: 172rem;
  left: -20.4rem;
}
.camp01 .howto .l007 {
  width: 12.2rem;
  position: absolute;
  top: 207rem;
  left: -20rem;
}
.camp01 .howto .l008 {
  width: 15.5rem;
  position: absolute;
  top: 234rem;
  left: -30rem;
}
.camp01 .howto .l009 {
  width: 12.2rem;
  position: absolute;
  top: 259rem;
  left: -20rem;
}
.camp01 .howto .l010 {
  width: 18.8rem;
  position: absolute;
  top: 294rem;
  left: -27rem;
}
.camp01 .howto .l011 {
  width: 15.5rem;
  position: absolute;
  top: 321rem;
  left: -22rem;
}
.camp01 .howto .l012 {
  width: 11.1rem;
  position: absolute;
  top: 357rem;
  left: -25.2rem;
}
.camp01 .howto .l013 {
  width: 12.4rem;
  position: absolute;
  top: 398rem;
  left: -20rem;
}
.camp01 .howto .l014 {
  width: 13.6rem;
  position: absolute;
  bottom: 0;
  left: -25rem;
}
.camp01 .howto .l015 {
  display: none;
  width: 10.3rem;
  position: absolute;
  bottom: 8rem;
  left: -22.2rem;
}
.camp01 .howto .r001 {
  width: 17.6rem;
  position: absolute;
  top: 3rem;
  right: -25rem;
}
.camp01 .howto .r002 {
  width: 11.3rem;
  position: absolute;
  top: 44rem;
  right: -24rem;
}
.camp01 .howto .r003 {
  width: 15.9rem;
  position: absolute;
  top: 66.8rem;
  right: -28.3rem;
}
.camp01 .howto .r004 {
  width: 19.6rem;
  position: absolute;
  top: 105rem;
  right: -27.5rem;
}
.camp01 .howto .r005 {
  width: 15.3rem;
  position: absolute;
  top: 128rem;
  right: -28rem;
}
.camp01 .howto .r006 {
  width: 11rem;
  position: absolute;
  top: 171rem;
  right: -19rem;
}
.camp01 .howto .r007 {
  width: 12.8rem;
  position: absolute;
  top: 195rem;
  right: -24rem;
}
.camp01 .howto .r008 {
  width: 14.6rem;
  position: absolute;
  top: 230rem;
  right: -21rem;
}
.camp01 .howto .r009 {
  width: 12.4rem;
  position: absolute;
  top: 260rem;
  right: -25rem;
}
.camp01 .howto .r010 {
  width: 13.5rem;
  position: absolute;
  top: 292rem;
  right: -20rem;
}
.camp01 .howto .r011 {
  width: 12rem;
  position: absolute;
  top: 323rem;
  right: -24rem;
}
.camp01 .howto .r012 {
  display: none;
  width: 14.6rem;
  position: absolute;
  top: 340rem;
  right: -28.3rem;
}
.camp01 .howto .r013 {
  width: 13.3rem;
  position: absolute;
  top: 370rem;
  right: -20rem;
}
.camp01 .howto .r014 {
  width: 19.8rem;
  position: absolute;
  top: 409rem;
  right: -26rem;
}
.camp01 .howto .r015 {
  width: 13rem;
  position: absolute;
  bottom: 15rem;
  right: -25rem;
}
.camp01 .howto h3 {
  width: 100%;
}
.camp01 .howto .howtoBody {
  padding: 4.5rem 5.8rem 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody {
    padding: 4.5rem 4.7vw 0;
  }
}
.camp01 .howto .howtoBody p {
  text-align: justify;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.6rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p {
    font-size: 2.88vw;
    line-height: 4.68vw;
  }
}
.camp01 .howto .howtoBody p.lead {
  font-size: 1.9rem;
  line-height: 3rem;
  margin-bottom: 1.5rem;
}
.camp01 .howto .howtoBody p.lead span {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.lead span {
    font-size: 3.42vw;
    line-height: 5.4vw;
  }
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.lead {
    font-size: 3.42vw;
    line-height: 5.4vw;
  }
}
.camp01 .howto .howtoBody p.semiLead {
  font-size: 1.7rem;
  line-height: 2.7rem;
  text-align: center;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.semiLead {
    font-size: 3.7vw;
    line-height: 6vw;
  }
}
.camp01 .howto .howtoBody p.transfer {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 3.6rem;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
  padding: 2.8rem 0 2.4rem;
  margin: 2.8rem auto 6.5rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.transfer {
    font-size: 3.4vw;
    line-height: 5.8vw;
    font-feature-settings: "palt";
  }
}
.camp01 .howto .howtoBody .btn_dl {
  width: 42rem;
  margin: auto auto 11.7rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .btn_dl {
    width: 68vw;
  }
}
.camp01 .howto .howtoBody .btn_dl.btn_dl2 {
  margin: 8.8rem auto 18rem;
}
.camp01 .howto .howtoBody h4 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-top: 5.4rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody h4 {
    font-size: 5vw;
  }
}
.camp01 .howto .howtoBody h4.h4Step {
  width: 100%;
}
.camp01 .howto .howtoBody table {
  border-right: 1px solid #707070;
  border-bottom: 1px solid #707070;
  margin-bottom: 6rem;
}
.camp01 .howto .howtoBody table tr {
  border-top: 1px solid #707070;
}
.camp01 .howto .howtoBody table th {
  border-left: 1px solid #707070;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 3rem;
  vertical-align: middle;
  text-align: center;
  width: 17.8%;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody table th {
    font-size: 3.24vw;
    font-weight: 700;
    line-height: 4.08vw;
    width: 19%;
  }
}
.camp01 .howto .howtoBody table td {
  border-left: 1px solid #707070;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.6rem;
  padding: 2rem 2.1rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody table td {
    font-size: 2.88vw;
    line-height: 4.68vw;
  }
}
.camp01 .howto .howtoBody table td ul {
  list-style-type: none;
}
.camp01 .howto .howtoBody table td ul li {
  position: relative;
  padding-left: 1.5rem;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody table td ul li {
    padding-left: 2.8vw;
  }
}
.camp01 .howto .howtoBody table td ul li::before {
  content: '';
  width: 1.44rem;
  height: 1.44rem;
  background: #cbcbcb;
  border-radius: 50%;
  position: absolute;
  top: 0.6rem;
  left: 0;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody table td ul li::before {
    width: 2.59vw;
    height: 2.59vw;
    top: 0.7rem;
  }
}
.camp01 .howto .howtoBody .cases {
  width: 76rem;
  margin: 12rem auto auto;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .cases {
    width: 100%;
  }
}
.camp01 .howto .howtoBody .step01.hagaki {
  display: flex;
  justify-content: space-between;
  width: 64.5rem;
  margin: auto auto 7.9rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step01.hagaki {
    width: 100%;
    display: block;
  }
}
.camp01 .howto .howtoBody .step01.hagaki figure:nth-of-type(1) {
  width: 26.3rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step01.hagaki figure:nth-of-type(1) {
    width: 100%;
  }
}
.camp01 .howto .howtoBody .step01.hagaki figure:nth-of-type(2) {
  padding-top: 1.4rem;
  width: 33.2rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step01.hagaki figure:nth-of-type(2) {
    width: 100%;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki {
  display: flex;
  justify-content: space-between;
  width: 76rem;
  font-feature-settings: "palt";
  margin-bottom: 9rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki {
    width: 100%;
    display: block;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step02 {
  width: 35rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step02 {
    width: 100%;
    display: block;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step02 h4 {
  width: 100%;
  margin-top: 0;
}
.camp01 .howto .howtoBody .step0203.hagaki .step02 h4 img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step02 h4 img {
    margin-bottom: 0;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step02 img {
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step02 img {
    width: 42.4vw;
    margin-bottom: 11.7vw;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step03 {
  width: 35rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step03 {
    width: 100%;
    display: block;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step03 h4 {
  width: 100%;
  margin-top: 0;
}
.camp01 .howto .howtoBody .step0203.hagaki .step03 h4 img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step03 h4 img {
    margin-left: 0;
  }
}
.camp01 .howto .howtoBody .step0203.hagaki .step03 img {
  width: 100%;
  margin: auto;
}
.camp01 .howto .howtoBody .step0203.hagaki .step03 img.step04 {
  margin-top: 3rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .step0203.hagaki .step03 img {
    width: 45vw;
    margin-left: 12vw;
  }
  .camp01 .howto .howtoBody .step0203.hagaki .step03 img.step04 {
    margin-top: auto;
  }
}
.camp01 .howto .howtoBody .stepTriple {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-top: 6rem;
  margin-bottom: 15rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple {
    display: block;
  }
}
.camp01 .howto .howtoBody .stepTriple li {
  width: 22rem;
  height: 42.34rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li {
    width: 100%;
    height: auto;
    display: block;
    text-align: center;
    padding-bottom: 12vw;
  }
}
.camp01 .howto .howtoBody .stepTriple li h4 {
  width: 100%;
  height: 3.716rem;
  margin-top: 0;
  margin-bottom: 1.95rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li h4 {
    height: auto;
  }
}
.camp01 .howto .howtoBody .stepTriple li span {
  font-size: 1.7rem;
  line-height: 2.7rem;
  text-align: left;
  margin-bottom: 4rem;
  letter-spacing: -0.1rem;
  display: block;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li span {
    font-size: 3.8vw;
    line-height: 6vw;
    margin-top: 3.2vw;
    text-align: center;
    letter-spacing: -0.2vw;
  }
}
.camp01 .howto .howtoBody .stepTriple li img {
  height: auto;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li img {
    position: static;
  }
}
.camp01 .howto .howtoBody .stepTriple li img.s1 {
  width: 15.3rem;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li img.s1 {
    width: 40vw;
    transform: translateX(0);
  }
}
.camp01 .howto .howtoBody .stepTriple li img.s2 {
  width: 19.87rem;
  bottom: 0;
  right: -1rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li img.s2 {
    width: 51.9vw;
    transform: translateX(4vw);
  }
}
.camp01 .howto .howtoBody .stepTriple li img.s3 {
  width: 19.4rem;
  bottom: 0;
  right: -2.8rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .stepTriple li img.s3 {
    width: 45vw;
    transform: translateX(4.5vw);
  }
}

.camp02 {
  width: 100%;
  margin-top: 10rem;
  padding-top: 6rem;
  padding-bottom: 0;
  background: #b4e1f5;
  background: linear-gradient(180deg, #b4e1f5 0%, #0a82b4 100%);
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp02 {
    padding-bottom: 0;
    overflow-x: hidden;
  }
}
.camp02 .sectionBody {
  width: 124.4rem;
  margin: auto;
  padding-bottom: 70rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody {
    width: 100%;
  }
}
.camp02 .sectionBody .l016 {
  display: none;
  width: 6.76rem;
  position: absolute;
  top: 80rem;
  left: -9.4rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .l016 {
    display: block;
    width: 10.8vw;
    top: 209vw;
    left: 7vw;
  }
}
.camp02 .sectionBody .l017 {
  display: none;
  width: 5.36rem;
  position: absolute;
  top: 200rem;
  left: -4.8rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .l017 {
    display: block;
    width: 10.8vw;
    top: 245vw;
    left: 9vw;
  }
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .l018 {
    position: absolute;
    width: 7.8vw;
    top: 445vw;
    left: 1vw;
  }
}
.camp02 .sectionBody .r017 {
  display: none;
  width: 17.2rem;
  position: absolute;
  top: 140rem;
  right: -6.9rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .r017 {
    width: 29.2vw;
    top: 304vw;
    right: -4.8vw;
  }
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .r018 {
    position: absolute;
    width: 14.1vw;
    top: 386vw;
    right: 3.5vw;
  }
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .r019 {
    display: none;
    position: absolute;
    width: 8.1vw;
    top: 698vw;
    right: 0;
  }
}
.camp02 .sectionBody .r020 {
  display: none;
  width: 13.3rem;
  position: absolute;
  top: 125rem;
  right: -12rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .r020 {
    width: 29.2vw;
    top: 304vw;
    right: -4.8vw;
  }
}
.camp02 .sectionBody .r021 {
  display: none;
  width: 4.1rem;
  position: absolute;
  top: 182rem;
  right: -1rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .r021 {
    width: 29.2vw;
    top: 304vw;
    right: -4.8vw;
  }
}
.camp02 .sectionBody .croud01 {
  display: none;
  width: 6.44rem;
  position: absolute;
  top: -2rem;
  left: 26rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .croud01 {
    width: 10.9vw;
    top: 32vw;
    left: -1.5vw;
  }
}
.camp02 .sectionBody .croud02 {
  display: none;
  width: 10.9rem;
  position: absolute;
  top: 2rem;
  left: -6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .croud02 {
    width: 6.4vw;
    top: 41vw;
    left: 7vw;
  }
}
.camp02 .sectionBody .croud03 {
  display: none;
  width: 18.5rem;
  position: absolute;
  top: 8rem;
  right: -12rem;
}
@media screen and (max-width: 768px) {
  .camp02 .sectionBody .croud03 {
    width: 18.4vw;
    top: 36.5vw;
    right: -2vw;
  }
}
.camp02::after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  /*
  background:url("../images/bg_wave_l.webp") no-repeat bottom -45rem left,
  	url("../images/bg_wave_r.webp") no-repeat bottom -30rem right;
  background-size:50%;
  */
  background: url("../images/bg_wave02.webp") no-repeat bottom center;
  background-size: 2000px;
}
@media screen and (max-width: 768px) {
  .camp02::after {
    background: url("../images/bg_wave02_sp.webp") no-repeat bottom left -0.4vw;
    background-size: 100.3vw;
    height: 100%;
  }
}
.camp02 h2 {
  width: 124.4rem;
  margin: auto;
  scroll-margin-top: 31.5rem;
}
.camp02 h2.fixed {
  scroll-margin-top: 14.5rem;
}
@media screen and (max-width: 768px) {
  .camp02 h2 {
    width: 108vw;
    margin-left: -2.2vw;
    scroll-margin-top: 6rem;
  }
}
.camp02 .detail {
  width: 104rem;
  margin: 6.3rem auto 14rem;
  display: flex;
  gap: 3.3rem;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .camp02 .detail {
    width: 94vw;
    margin: 14vw auto 23vw;
    gap: 12rem;
    position: relative;
    z-index: 2;
  }
}
.camp02 .detail li {
  width: 100%;
  display: flex;
}
.camp02 .detail li.prize03 {
  justify-content: flex-start;
}
.camp02 .detail li.prize04 {
  justify-content: flex-end;
}
.camp02 .detail li img {
  width: 102rem;
}
@media screen and (max-width: 768px) {
  .camp02 .detail li img {
    width: 100%;
  }
}
.camp02 .information {
  width: 65.7rem;
  margin: auto;
  position: relative;
  z-index: 2;
  padding-bottom: 98.5rem;
}
@media screen and (max-width: 768px) {
  .camp02 .information {
    width: 100%;
    padding-bottom: 82rem;
  }
}
.camp02 .information figure {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .camp02 .information figure {
    width: 77.6vw;
    margin: auto;
  }
}
.camp02 .howto {
  width: 88rem;
  margin: auto;
  background: #fff;
  box-sizing: border-box;
  padding-bottom: 12rem;
  position: relative;
  z-index: 2;
}
.camp02 .howto.finished::after {
  content: '';
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  position: absolute;
  top: 0;
  left: 0;
}
.camp02 .howto.finished::before {
  content: '';
  width: 54.6rem;
  height: 100%;
  background: url(../images/finish.webp) no-repeat;
  background-size: 100%;
  position: absolute;
  top: 11.6rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .camp02 .howto {
    width: 84vw;
    padding-bottom: 8vw;
  }
}
.camp02 .howto .howtoBody {
  padding: 0 6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody {
    padding: 0 5vw;
  }
}
.camp02 .howto .howtoBody h4.howmany {
  width: 69.84rem;
  margin: 6rem auto 3.6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody h4.howmany {
    width: 69vw;
  }
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody h4.howmany img {
    width: 89.4vw;
    margin-left: -10vw;
  }
}
.camp02 .howto .howtoBody figure.text_repost {
  width: 40.68rem;
  margin: 3.4rem auto 5.6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody figure.text_repost {
    width: 66.8vw;
  }
}
.camp02 .howto .howtoBody figure.text_hint {
  width: 100%;
  margin: auto auto 2rem;
  padding: 2.8rem 0;
  /*
  border-top:1px solid #000;
  border-bottom:1px solid #000;
  */
  text-align: center;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody figure.text_hint {
    padding: 4.8vw 0;
    margin-bottom: 5vw;
  }
}
.camp02 .howto .howtoBody figure.text_hint img {
  width: 62.4rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody figure.text_hint img {
    width: 63.7vw;
  }
}
.camp02 .howto .howtoBody p.lead {
  font-size: 1.9rem;
  line-height: 3rem;
  margin-bottom: 1.5rem;
  border: 0.5rem solid #0a5ab4;
  padding: 1.8rem 2rem;
  font-feature-settings: "palt";
  letter-spacing: 0.1rem;
  text-align: justify;
}
.camp02 .howto .howtoBody p.lead.noLine {
  border: none;
  padding: 0 0;
}
.camp02 .howto .howtoBody p.lead span.red {
  color: #e60000;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody p.lead {
    font-size: 3.42vw;
    line-height: 5.4vw;
    text-align: justify;
    font-feature-settings: "palt";
    padding: 1.8rem 2.7rem;
  }
}
.camp02 .howto .howtoBody .stepSingle {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepSingle {
    margin-top: 12vw;
  }
}
.camp02 .howto .howtoBody .stepSingle li span {
  font-size: 1.8rem;
  line-height: 2.8rem;
  text-align: center;
  margin-bottom: 2.4rem;
  display: block;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepSingle li span {
    font-size: 3.8vw;
    line-height: 6vw;
  }
}
.camp02 .howto .howtoBody .stepSingle p.tofollow {
  width: 30rem;
  height: 8rem;
  margin: 3rem auto 9rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepSingle p.tofollow {
    width: 56.8vw;
    height: 15.1vw;
  }
}
.camp02 .howto .howtoBody .stepSingle p.tofollow img {
  width: 100%;
  height: auto;
}
.camp02 .howto .howtoBody .stepDouble {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin: 6rem auto 6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble {
    display: block;
  }
}
.camp02 .howto .howtoBody .stepDouble li {
  width: 35rem;
  height: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li {
    width: 100%;
    height: auto;
    text-align: center;
  }
}
.camp02 .howto .howtoBody .stepDouble li h4 {
  width: 100%;
  margin: 0 auto 1.2rem;
}
.camp02 .howto .howtoBody .stepDouble li span {
  font-size: 1.8rem;
  line-height: 2.8rem;
  text-align: center;
  margin-bottom: 2.4rem;
  display: block;
  font-feature-settings: "palt";
}
.camp02 .howto .howtoBody .stepDouble li span span.red {
  color: #e60000;
  font-size: 2rem;
  font-weight: 900;
  display: inline;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li span span.red {
    font-size: 4.2vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li span img {
  display: inline-block;
  width: 3rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li span img {
    width: 5.9vw;
    height: auto;
  }
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li span {
    font-size: 3.8vw;
    line-height: 6vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li figure {
  width: 100%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li figure img.tw_step03 {
    width: 66vw;
    margin-top: 3vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li figure.ico_or {
  width: 4.9rem;
  height: auto;
  margin: auto auto 1.7rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li figure.ico_or {
    width: 8.76vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li img.tw_step02 {
  width: 26.9rem;
  height: auto;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li img.tw_step02 {
    width: 45.5vw;
    height: auto;
    margin-bottom: 12vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li img.step01many {
  width: 27rem;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li img.step01many {
    position: static;
    width: 42.57vw;
    transform: translateX(0);
    margin-bottom: 9.8vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li img.step02many {
  width: 30.7rem;
  position: absolute;
  bottom: 2.4rem;
  right: 0;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li img.step02many {
    position: static;
    width: 61vw;
    transform: translateX(0);
    margin-bottom: -8vw;
  }
}
.camp02 .howto .howtoBody .stepDouble li p.attention {
  font-size: 1.6rem;
  margin-top: 1.5rem;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .stepDouble li p.attention {
    font-size: 2.8vw;
    line-height: 4.6vw;
  }
}
.camp02 .howto .howtoBody .btn_post {
  width: 42rem;
  margin: auto auto 11.7rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody .btn_post {
    width: 68vw;
    margin: auto auto 8vw;
  }
}
.camp02 .howto .howtoBody h4 {
  font-size: 2.6rem;
  font-weight: 700;
  margin-top: 5.4rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody h4 {
    font-size: 5vw;
  }
}
.camp02 .howto .howtoBody p.attention {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .camp02 .howto .howtoBody p.attention {
    font-size: 2.8vw;
    line-height: 4.6vw;
  }
}

.camp03 {
  width: 100%;
  background: #f01e00;
  padding: 12.6rem 0 20rem;
  position: relative;
}
.camp03::after {
  content: '';
  width: 100%;
  height: 49.5rem;
  background: #fffbbf;
  position: absolute;
  top: 3.5rem;
  left: 0;
}
@media screen and (max-width: 768px) {
  .camp03 {
    overflow-x: hidden;
    padding-top: 8rem;
    padding-bottom: 17vw;
  }
}
.camp03 ul.eventPic {
  width: 88rem;
  margin: 7.8rem auto 9.4rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .camp03 ul.eventPic {
    width: 94vw;
    flex-wrap: wrap;
    gap: 4.5vw;
  }
}
.camp03 ul.eventPic li {
  width: 43rem;
}
@media screen and (max-width: 768px) {
  .camp03 ul.eventPic li {
    width: 100%;
  }
}
.camp03 ul.eventPic li img {
  width: 100%;
  height: auto;
}
.camp03 .howMany {
  width: 88rem;
  margin: auto;
  background: #fff;
  border-radius: 4rem;
  padding-bottom: 4.5rem;
}
@media screen and (max-width: 768px) {
  .camp03 .howMany {
    width: 84.4vw;
    padding-bottom: 10vw;
    border-radius: 6vw;
  }
}
.camp03 .howMany h3 {
  width: 100%;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  .camp03 .howMany h3 {
    width: 96.18vw;
    margin-left: -5.89vw;
  }
}
.camp03 .howMany h3 img {
  width: 100%;
  height: auto;
}
.camp03 .howMany h4 {
  width: 84.2rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .camp03 .howMany h4 {
    width: 79.8vw;
  }
}
.camp03 .howMany h4 img {
  width: 100%;
  height: auto;
}
.camp03 .howMany ul {
  width: 79.8rem;
  margin: 4rem auto auto;
  display: flex;
  flex-direction: column;
  gap: 6.6rem;
}
@media screen and (max-width: 768px) {
  .camp03 .howMany ul {
    width: 73vw;
    margin: 10vw auto 11vw;
    gap: 9.5vw;
  }
}
.camp03 .howMany ul li {
  width: 100%;
}
.camp03 .howMany ul li img {
  width: 100%;
  height: auto;
}
.camp03 .howMany figure.numero {
  width: 35.7rem;
  margin: 5.5rem auto auto;
}
.camp03 .howMany figure.numero img {
  width: 100%;
  height: auto;
}
.camp03 h2 {
  width: 100rem;
  margin: auto;
  scroll-margin-top: 36rem;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 768px) {
  .camp03 h2 {
    width: 96.1vw;
    margin: auto;
    scroll-margin-top: 11vw;
  }
}
.camp03 h2.fixed {
  scroll-margin-top: 19rem;
}
.camp03 .eventScene {
  display: none;
  width: 88rem;
  margin: 5.7rem auto 6rem;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .camp03 .eventScene {
    width: 84vw;
    flex-wrap: wrap;
    gap: 2vw;
    margin-bottom: 11vw;
  }
}
.camp03 .eventScene figure {
  width: 43rem;
}
@media screen and (max-width: 768px) {
  .camp03 .eventScene figure {
    width: 100%;
  }
}
.camp03 .howto {
  display: none;
  width: 88rem;
  margin: auto;
  background: #fff;
  box-sizing: border-box;
  padding-bottom: 10rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .camp03 .howto {
    width: 84vw;
  }
}
.camp03 .howto .howtoBody {
  padding: 4.5rem 6rem 0;
}
.camp03 .howto .howtoBody p.lead {
  font-size: 1.9rem;
  line-height: 3rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 768px) {
  .camp03 .howto .howtoBody p.lead {
    font-size: 3.4vw;
    line-height: 5.2vw;
  }
}
.camp03 .howto .howtoBody p.transfer {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 3.6rem;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
  padding: 2.8rem 0 2.4rem;
  margin: 2.8rem auto 3rem;
}
@media screen and (max-width: 768px) {
  .camp03 .howto .howtoBody p.transfer {
    font-size: 3.8vw;
    line-height: 5.2vw;
  }
}
@media screen and (max-width: 768px) {
  .camp03 .howto .howtoBody p.transfer span {
    display: block;
    margin-bottom: 2vw;
  }
}
.camp03 table {
  width: 85rem;
  margin: 12rem auto 4rem;
  font-size: 2rem;
  background: #fffbbf;
}
@media screen and (max-width: 768px) {
  .camp03 table {
    width: 70.5rem;
    font-size: 2.2rem;
    margin-top: 10rem;
  }
}
.camp03 table th {
  font-weight: 700;
  border-top: 1px solid #000;
  padding: 2.8rem 0 2.8rem 2.2rem;
  vertical-align: middle;
  text-align: left;
  width: 16.6rem;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .camp03 table th {
    width: 18.7rem;
  }
}
.camp03 table th.firstDeg {
  border-top: none;
}
.camp03 table td {
  font-weight: 400;
  border-top: 1px solid #000;
  border-left: 1px solid #000;
  padding: 2.8rem 3.1rem;
  font-feature-settings: "palt";
  letter-spacing: 0.25rem;
}
@media screen and (max-width: 768px) {
  .camp03 table td {
    padding: 3.2rem 3.1rem;
  }
}
.camp03 table td.firstDeg {
  border-top: none;
}
.camp03 figure.moriage {
  width: 113.6rem;
  margin: auto auto 5.8rem;
  transform: translateX(-3rem);
}
@media screen and (max-width: 768px) {
  .camp03 figure.moriage {
    width: 73.5rem;
    transform: translateX(0);
  }
}
.camp03 figure.tweet {
  width: 81.2rem;
  margin: 12.5rem auto 12rem;
}
@media screen and (max-width: 768px) {
  .camp03 figure.tweet {
    width: 45.3rem;
  }
}
.camp03 ul.detail {
  width: 120rem;
  margin: auto;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .camp03 ul.detail {
    width: 70.5rem;
  }
}
.camp03 ul.detail li {
  width: 88rem;
  float: left;
}
@media screen and (max-width: 768px) {
  .camp03 ul.detail li {
    width: 100%;
    float: none;
  }
}
.camp03 ul.detail li img {
  width: 100%;
  height: auto;
}
.camp03 ul.detail li:nth-of-type(2) {
  float: right;
  margin-top: -2.4rem;
}
@media screen and (max-width: 768px) {
  .camp03 ul.detail li:nth-of-type(2) {
    float: none;
    margin-top: -1.3rem;
  }
}
.camp03 ul.detail li:nth-of-type(3) {
  margin-top: -2.4rem;
}
@media screen and (max-width: 768px) {
  .camp03 ul.detail li:nth-of-type(3) {
    float: none;
    margin-top: -1.3rem;
  }
}
.camp03 ul.tweetSNS {
  width: 25.9rem;
  margin: auto auto 11.6rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .camp03 ul.tweetSNS {
    width: 36.3rem;
  }
}
.camp03 ul.tweetSNS li {
  width: 10rem;
}
@media screen and (max-width: 768px) {
  .camp03 ul.tweetSNS li {
    width: 14rem;
  }
}
.camp03 ul.tweetSNS li img {
  width: 100%;
  height: auto;
}
.camp03 .attentionBox {
  width: 77.8rem;
  margin: auto;
  font-feature-settings: "palt";
  color: #fff;
}
@media screen and (max-width: 768px) {
  .camp03 .attentionBox {
    width: 62.4rem;
  }
}
.camp03 .attentionBox h3 {
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 3rem;
  letter-spacing: 0.2rem;
}
@media screen and (max-width: 768px) {
  .camp03 .attentionBox h3 {
    font-size: 2.4rem;
  }
}
.camp03 .attentionBox ul {
  list-style-type: none;
  margin-top: 0.8rem;
  margin-left: 0.5rem;
  margin-bottom: 8rem;
}
@media screen and (max-width: 768px) {
  .camp03 .attentionBox ul {
    margin-top: 1.5rem;
    margin-bottom: 1rem;
  }
}
.camp03 .attentionBox ul li {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.7rem;
  position: relative;
  padding-left: 0.6rem;
  letter-spacing: 0.1rem;
}
@media screen and (max-width: 768px) {
  .camp03 .attentionBox ul li {
    font-size: 2.16rem;
    line-height: 3.7rem;
    padding-left: 1rem;
  }
}
.camp03 .attentionBox ul li::before {
  content: '';
  width: 0.3rem;
  height: 0.3rem;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: 1.2rem;
  left: 0;
}
@media screen and (max-width: 768px) {
  .camp03 .attentionBox ul li::before {
    top: 1.5rem;
    width: 0.6vw;
    height: 0.6vw;
  }
}

.inquiry {
  width: 100%;
  border-bottom: 1px solid #000;
  background: #fff;
}
.inquiry figure {
  width: 86.2rem;
  margin: 9.7rem auto 11.8rem;
}
@media screen and (max-width: 768px) {
  .inquiry figure {
    width: 77.4vw;
  }
}

footer {
  width: 92rem;
  margin: auto;
  padding: 3.6rem 0 4rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  footer {
    width: 100%;
    flex-wrap: wrap;
    padding: 3.6rem 5vw 4rem;
  }
}
footer .first {
  width: 43rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
@media screen and (max-width: 768px) {
  footer .first {
    width: 100%;
  }
}
footer .first p {
  font-size: 1.4rem;
  margin-right: 1.5em;
}
@media screen and (max-width: 768px) {
  footer .first p {
    font-size: 2.8vw;
    margin-right: 2em;
  }
}
footer .first p a {
  color: #000;
}
footer .first p a:hover {
  text-decoration: underline;
}
footer .first .copy {
  margin-top: 0.5em;
}
footer .third {
  width: 152px;
}
@media screen and (max-width: 768px) {
  footer .third {
    width: 100%;
    margin-top: -7vw;
    display: flex;
    justify-content: flex-end;
  }
}
@media screen and (max-width: 768px) {
  footer .third img {
    width: 30vw;
  }
}
footer .second {
  width: 156px;
}
@media screen and (max-width: 768px) {
  footer .second {
    width: 26.8vw;
    margin-top: 4.9vw;
  }
}
footer .second ul {
  display: flex;
  justify-content: space-between;
}
footer .second ul li {
  width: 4.5rem;
}
@media screen and (max-width: 768px) {
  footer .second ul li {
    width: 7.95vw;
  }
}
footer .second ul li img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  #menuButton {
    position: fixed;
    top: 4.9vw;
    right: 3.3vw;
    display: block;
    width: 8vw;
    height: 6vw;
    z-index: 5;
  }
  #menuButton span {
    display: block;
    background: #fff;
    width: 8vw;
    height: 0.8vw;
    position: absolute;
    left: 0;
    transition: all 0.3s ease;
  }
  #menuButton span:first-child {
    top: 0;
  }
  #menuButton span:nth-child(2) {
    top: 2.6vw;
  }
  #menuButton span:nth-child(3) {
    top: 5.2vw;
  }
  #menuButton.active span:first-child {
    transform: translateY(2.5vw) rotate(45deg);
    background: #e60000;
  }
  #menuButton.active span:nth-child(2) {
    opacity: 0;
  }
  #menuButton.active span:nth-child(3) {
    transform: translateY(-2.7vw) rotate(-45deg);
    background: #e60000;
  }

  .menu-panel {
    visibility: none;
    position: fixed;
    top: 0;
    right: 0;
    width: 64%;
    height: 0;
    background: rgba(255, 240, 0, 0.95);
    opacity: 0;
    transition: all .8s ease;
    padding: 20vw 10vw 0;
    border-radius: 0 0 0 21vw;
    z-index: -1;
  }
  .menu-panel.active {
    opacity: 1;
    height: auto;
    z-index: 2;
  }
  .menu-panel p.btn_close {
    width: 14.1vw;
    margin: 12vw auto 0;
  }
  .menu-panel p.btn_close img {
    width: 100%;
    height: auto;
  }

  nav ul {
    width: 100%;
    height: 20vw;
    margin: auto;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    gap: 5.4vw;
  }
  nav ul li {
    position: static;
    display: flex;
    justify-content: center;
    margin: auto;
    border-bottom: 0.6vw solid #fff;
    padding-bottom: 5.4vw;
    width: 100%;
  }
  nav ul li img {
    height: auto;
  }
  nav ul li:nth-of-type(1) img {
    width: 47.8vw;
  }
  nav ul li:nth-of-type(2) img {
    width: 23.5vw;
    transform: translateX(0);
  }
  nav ul li:nth-of-type(3) {
    border-bottom: none;
  }
  nav ul li:nth-of-type(3) img {
    width: 42vw;
  }

  nav .menu-panel.active ul {
    display: flex;
    height: auto;
    z-index: 2;
  }
}
.prizeDetail {
  visibility: none;
  padding-bottom: 0;
  opacity: 0;
  transition: all .4s ease;
  height: 0;
}

.prizeDetail.active {
  visibility: visible;
  opacity: 1;
  height: auto;
  padding-bottom: 4rem;
}

.camp01 .howto .howtoBody p.toDetail, .camp01 .howto .howtoBody p.closeDetail {
  font-size: 1.9rem;
  width: 26.7rem;
  height: 4.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #231815;
  border-radius: 0.4rem;
  margin-bottom: 3rem;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.toDetail, .camp01 .howto .howtoBody p.closeDetail {
    width: 100%;
    height: 8.3vw;
    border: 0.1rem solid #231815;
    border-radius: 0.8rem;
    z-index: 2;
    font-size: 3.42vw;
  }
}

.camp01 .howto .howtoBody p.toDetail.active {
  display: none;
}

.camp01 .howto .howtoBody p.closeDetail {
  margin-top: 3rem;
}

.camp01 .howto .howtoBody p.toDetail::before {
  content: '';
  width: 1.3rem;
  height: 1px;
  border-top: 1px solid #231815;
  transform: rotate(45deg);
  position: absolute;
  top: 52%;
  right: 2.5rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.toDetail::before {
    width: 2rem;
    right: 3rem;
  }
}

.camp01 .howto .howtoBody p.toDetail::after {
  content: '';
  width: 1.3rem;
  height: 1px;
  border-top: 1px solid #231815;
  transform: rotate(-45deg);
  position: absolute;
  top: 52%;
  right: 1.4rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.toDetail::after {
    width: 2rem;
  }
}

.camp01 .howto .howtoBody p.closeDetail::before {
  content: '';
  width: 1.3rem;
  height: 1px;
  border-top: 1px solid #231815;
  transform: rotate(-45deg);
  position: absolute;
  top: 52%;
  right: 2.3rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.closeDetail::before {
    width: 2rem;
    right: 2.7rem;
  }
}

.camp01 .howto .howtoBody p.closeDetail::after {
  content: '';
  width: 1.3rem;
  height: 1px;
  border-top: 1px solid #231815;
  transform: rotate(45deg);
  position: absolute;
  top: 52%;
  right: 1.4rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody p.closeDetail::after {
    width: 2rem;
  }
}

.camp01 .howto .howtoBody .prizeDetail p {
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  .camp01 .howto .howtoBody .prizeDetail p {
    font-size: 3.42vw;
    line-height: 1.5;
  }
}

/* sp menu */
#menu-open {
  width: 8vw;
  height: 6vw;
  position: absolute;
  top: 5vw;
  right: 2.5vw;
  z-index: 3;
}

a#menu-open span {
  display: block;
  width: 8vw;
  height: 1.05vw;
  background: #fff;
}

a#menu-open span:first-child {
  position: absolute;
  top: 0;
  right: 0;
  transition: all 0.4s ease;
}

a#menu-open span:nth-child(2) {
  position: absolute;
  top: 2.8vw;
  right: 0;
  transition: all 0.4s ease;
}

a#menu-open span:nth-child(3) {
  position: absolute;
  top: 5.8vw;
  right: 0;
  transition: all 0.4s ease;
}

#menu-open.open {
  position: fixed;
  z-index: -1;
  opacity: 0;
}

#menu-panel {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 20;
  padding: 20vw 10vw 0;
  width: 70vw;
  height: 88vw;
  background: rgba(215, 23, 24, 0.9);
  box-sizing: border-box;
  transition: all 0.5s ease;
  border-radius: 0 0 0 10vw;
}

#menu-panel.open {
  opacity: 1;
  visibility: visible;
  z-index: 20;
}

#menu-panel > ul {
  margin: auto;
}

#menu-panel > ul > li {
  border-bottom: 2rem solid #fff;
  margin-bottom: 0;
}
#menu-panel > ul > li:last-of-type {
  border: none;
}
@media screen and (max-width: 768px) {
  #menu-panel > ul > li:last-of-type {
    border-bottom: 2rem solid #fff;
  }
}

#menu-panel > ul > li > a {
  font-size: 2.56rem;
  padding: 5.4rem 0.9rem;
  display: block;
  color: #fff;
}

#menu-panel > ul li ul.secondDeg {
  margin-top: 0;
  padding-bottom: 1rem;
}

#menu-panel > ul li ul.secondDeg li {
  border-bottom: none;
  margin-bottom: 2.1rem;
}

#menu-panel > ul li ul.secondDeg li a {
  font-size: 2.4rem;
  padding: 1rem 0;
  display: block;
  color: #fff;
}

#menu-panel > ul:nth-of-type(3) {
  width: 67rem;
  display: grid;
  /* width: fit-content; */
  column-gap: 2em;
  grid-template-columns: repeat(2, auto);
  margin-top: 3rem;
}

#menu-panel > ul:nth-of-type(3) li {
  border-bottom: none;
}

p.navRights {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
  margin-top: 26.2rem;
}

.btn-menu {
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 0;
  border: none;
  height: 5.4vw;
  width: 5.4vw;
  opacity: 0 !important;
  z-index: 1;
}

.btn-menu.active {
  opacity: 1 !important;
  z-index: 30;
}

#menu-close {
  top: 1.7vw;
  right: 2.1vw;
  cursor: pointer;
}

#menu-close span {
  width: 8vw;
  height: 1.05vw;
  background: #fff;
  transition: 0.4s;
}

#menu-close span:first-child {
  position: absolute;
  top: 4.8rem;
  right: 0;
  transition: all 0.4s ease;
  transform: rotate(45deg);
}

#menu-close span:nth-child(2) {
  display: none;
}

#menu-close span:nth-child(3) {
  position: absolute;
  top: 4.8rem;
  right: 0;
  transition: all 0.4s ease;
  transform: rotate(-45deg);
}

p.closeBtn {
  font-size: 3vw;
  color: #fff;
  position: absolute;
  bottom: 5.5vw;
  left: 50%;
  transform: translateX(-50%);
}
