/* ==========================================================================
	Common
	========================================================================== */
/*==================================================================
// Keyframe
//================================================================*/
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;800&display=swap");
@-webkit-keyframes purupuru {
  0%, 40% {
    -webkit-transform: skew(0deg, 0deg);
            transform: skew(0deg, 0deg);
  }
  5% {
    -webkit-transform: skew(5deg, 5deg);
            transform: skew(5deg, 5deg);
  }
  10% {
    -webkit-transform: skew(-4deg, -4deg);
            transform: skew(-4deg, -4deg);
  }
  15% {
    -webkit-transform: skew(3deg, 3deg);
            transform: skew(3deg, 3deg);
  }
  20% {
    -webkit-transform: skew(-2deg, -2deg);
            transform: skew(-2deg, -2deg);
  }
  25% {
    -webkit-transform: skew(1deg, 1deg);
            transform: skew(1deg, 1deg);
  }
  30% {
    -webkit-transform: skew(-0.6deg, -0.6deg);
            transform: skew(-0.6deg, -0.6deg);
  }
  35% {
    -webkit-transform: skew(0.3deg, 0.3deg);
            transform: skew(0.3deg, 0.3deg);
  }
}
@keyframes purupuru {
  0%, 40% {
    -webkit-transform: skew(0deg, 0deg);
            transform: skew(0deg, 0deg);
  }
  5% {
    -webkit-transform: skew(5deg, 5deg);
            transform: skew(5deg, 5deg);
  }
  10% {
    -webkit-transform: skew(-4deg, -4deg);
            transform: skew(-4deg, -4deg);
  }
  15% {
    -webkit-transform: skew(3deg, 3deg);
            transform: skew(3deg, 3deg);
  }
  20% {
    -webkit-transform: skew(-2deg, -2deg);
            transform: skew(-2deg, -2deg);
  }
  25% {
    -webkit-transform: skew(1deg, 1deg);
            transform: skew(1deg, 1deg);
  }
  30% {
    -webkit-transform: skew(-0.6deg, -0.6deg);
            transform: skew(-0.6deg, -0.6deg);
  }
  35% {
    -webkit-transform: skew(0.3deg, 0.3deg);
            transform: skew(0.3deg, 0.3deg);
  }
}
@-webkit-keyframes elasticus {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}
@keyframes elasticus {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}
@-webkit-keyframes scribble {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  2% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  4% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  6% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  8% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  10% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
@keyframes scribble {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  2% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  4% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  6% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  8% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  10% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
@-webkit-keyframes scribble-inv {
  0% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
  2% {
    -webkit-transform: rotate(10deg) scale(-1, 1);
            transform: rotate(10deg) scale(-1, 1);
  }
  4% {
    -webkit-transform: rotate(-10deg) scale(-1, 1);
            transform: rotate(-10deg) scale(-1, 1);
  }
  6% {
    -webkit-transform: rotate(10deg) scale(-1, 1);
            transform: rotate(10deg) scale(-1, 1);
  }
  8% {
    -webkit-transform: rotate(-10deg) scale(-1, 1);
            transform: rotate(-10deg) scale(-1, 1);
  }
  10% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
  100% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
}
@keyframes scribble-inv {
  0% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
  2% {
    -webkit-transform: rotate(10deg) scale(-1, 1);
            transform: rotate(10deg) scale(-1, 1);
  }
  4% {
    -webkit-transform: rotate(-10deg) scale(-1, 1);
            transform: rotate(-10deg) scale(-1, 1);
  }
  6% {
    -webkit-transform: rotate(10deg) scale(-1, 1);
            transform: rotate(10deg) scale(-1, 1);
  }
  8% {
    -webkit-transform: rotate(-10deg) scale(-1, 1);
            transform: rotate(-10deg) scale(-1, 1);
  }
  10% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
  100% {
    -webkit-transform: rotate(0deg) scale(-1, 1);
            transform: rotate(0deg) scale(-1, 1);
  }
}
/* Wobble Horizontal */
@-webkit-keyframes wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(8px);
            transform: translateX(8px);
  }
  33.3% {
    -webkit-transform: translateX(-6px);
            transform: translateX(-6px);
  }
  49.95% {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
  }
  66.6% {
    -webkit-transform: translateX(-2px);
            transform: translateX(-2px);
  }
  83.25% {
    -webkit-transform: translateX(1px);
            transform: translateX(1px);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(8px);
            transform: translateX(8px);
  }
  33.3% {
    -webkit-transform: translateX(-6px);
            transform: translateX(-6px);
  }
  49.95% {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
  }
  66.6% {
    -webkit-transform: translateX(-2px);
            transform: translateX(-2px);
  }
  83.25% {
    -webkit-transform: translateX(1px);
            transform: translateX(1px);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes yurayura {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  50% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
@keyframes yurayura {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  50% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
/* ==========================================================================
	00_Base
	========================================================================== */
/*==================================================================
// reset
//================================================================*/
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

ul[role=list],
ol[role=list] {
	list-style: none;
}

html:focus-within {
	scroll-behavior: smooth;
}

body {
	text-rendering: optimizeSpeed;
	line-height: 1.5;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

img,
picture {
	max-width: 100%;
	display: block;
}

input,
button,
textarea,
select {
	font: inherit;
}

@media (prefers-reduced-motion: reduce) {
	html:focus-within {
		scroll-behavior: auto;
	}

	*,
*::before,
*::after {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
ul,
li {
	list-style: none;
}

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

/*==================================================================
// Fonts
//================================================================*/
.title_font {
	font-weight: 700;
}

/*==================================================================
// root
//================================================================*/
:root {
  --color-White: #ffffff;
  --color-BaseWhite: #f5f5f5;
  --color-LightGray: #e0e0e0;
  --color-LightGrayB3: #b3b3b3;
  --color-Gray: #969696;
  --color-Dark: #232323;
  --color-Black: #070002;
  --color-RichBlack: #000000;
  --color-Orange: #ef5324;
  --color-Primary: #ef5324;
  --color-PrimaryDark: #a04696;
  --color-PrimaryGrad1: linear-gradient(90deg, #c8328c, #be3291);
  --color-PrimaryGrad2: linear-gradient(90deg, #d2268f, #bf3392);
  --color-Secondary: #ffb955;
  --color-SecondaryLight: #fff582;
  --color-SecondaryGrad: linear-gradient(90deg, #ffb955, #fff582);
  --color-SectionA_Border: #e4ca59;
  --color-SectionB_Border: #2aa6a8;
  --color-TextDefault: #232323;
  --color-TextTitle: #393939;
  --color-Link: #006699;
  --color-LinkVisited: #006699;
  --color-LinkHover: #993300;
  --color-LinkActive: #993300;
  --color-Bg: #f5f5f5;
  --color-ScrollBg: #1f54a8;
  --color-ScrollColor: #fff;
  --color-btnPraGrad: linear-gradient(44deg, #d2268f, #b722a4);
  --color-btnOcherBg: #e4ca59;
  --color-btnOcherBorder: #c1a221;
  --color-btnOcherText: #8d4411;
  --color-btnTwitterBg: #2b93b5;
  --color-btnTwitterBorder: #1e86aa;
  --color-btnTwitterText: #ffffff;
  --color-btnTurquoiseBg: #2aa6a8;
  --color-btnTurquoiseBorder: #147d7f;
  --color-btnTurquoiseText: #ffffff;
  --color-btnOrangeBg: #ef5324;
  --color-btnOrangeBorder: #db481c;
  --color-btnOrangeText: #ffffff;
  --color-SidebarText: #ffffff;
  --color-SidebarHr: #9e0f70;
  --color-Facebook: #3b5998;
  --color-Twitter: #55acee;
  --color-Line: #00b900;
  --color-LoadingBg: #554848;
}
:root[data-theme=dark] {
  --color-White: #ffffff;
  --color-BaseWhite: #f5f5f5;
  --color-LightGray: #e0e0e0;
  --color-Gray: #969696;
  --color-Dark: #232323;
  --color-Black: #070002;
  --color-RichBlack: #000000;
  --color-Orange: #ef5324;
  --color-Primary: #ef5324;
  --color-PrimaryDark: #a04696;
  --color-PrimaryGrad1: linear-gradient(90deg, #c8328c, #be3291);
  --color-PrimaryGrad2: linear-gradient(90deg, #d2268f, #bf3392);
  --color-Secondary: #ffb955;
  --color-SecondaryLight: #fff582;
  --color-SecondaryGrad: linear-gradient(90deg, #ffb955, #fff582);
  --color-SectionA_Border: #e4ca59;
  --color-SectionB_Border: #2aa6a8;
  --color-TextDefault: #232323;
  --color-TextTitle: #393939;
  --color-Link: #006699;
  --color-LinkVisited: #006699;
  --color-LinkHover: #993300;
  --color-LinkActive: #993300;
  --color-Bg: #f5f5f5;
  --color-ScrollBg: #1f54a8;
  --color-ScrollColor: #fff;
  --color-btnPraGrad: linear-gradient(44deg, #d2268f, #b722a4);
  --color-btnOcherBg: #e4ca59;
  --color-btnOcherBorder: #c1a221;
  --color-btnOcherText: #8d4411;
  --color-btnTwitterBg: #2b93b5;
  --color-btnTwitterBorder: #1e86aa;
  --color-btnTwitterText: #ffffff;
  --color-btnTurquoiseBg: #2aa6a8;
  --color-btnTurquoiseBorder: #147d7f;
  --color-btnTurquoiseText: #ffffff;
  --color-btnOrangeBg: #ef5324;
  --color-btnOrangeBorder: #db481c;
  --color-btnOrangeText: #ffffff;
  --color-SidebarText: #ffffff;
  --color-SidebarHr: #9e0f70;
  --color-Facebook: #3b5998;
  --color-Twitter: #55acee;
  --color-Line: #00b900;
  --color-LoadingBg: #554848;
}

::-moz-selection {
  background: var(--color-ScrollBg);
  color: var(--color-ScrollColor);
}

::selection {
	background: var(--color-ScrollBg);
	color: var(--color-ScrollColor);
}

::-moz-selection {
	background: var(--color-scrollBg);
	color: var(--color-ScrollColor);
}

* {
	-webkit-font-smoothing: antialiased;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/*==================================================================
// base
//================================================================*/
html {
	font-size: 10px;
}
@media (max-width: 1024px) {
	html {
		font-size: 9.5px;
	}
}
@media (max-width: 768px) {
	html {
		font-size: 10px;
	}
}
@media (max-width: 320px) {
	html {
		font-size: 9px;
	}
}

body {
  position: relative;
  font-size: 1.4rem;
  height: auto;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 400;
  line-height: 1.35;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  -webkit-overflow-scrolling: touch;
  letter-spacing: 0.3rem;
  overflow: auto;
}
body.fixed {
	overflow: hidden;
}

p {
	font-size: 1.7rem;
	line-height: 1.2em;
}
p + p {
	margin-top: 1.6rem;
}
@media (max-width: 768px) {
	p {
		font-size: 1.4rem;
		line-height: 1.4em;
	}
}

a {
  text-decoration: none;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
a:hover {
	opacity: 0.7;
}
a[href^="tel:"] {
	pointer-events: none;
}
@media (max-width: 768px) {
	a[href^="tel:"] {
		pointer-events: auto;
	}
}

th,
td {
	vertical-align: top;
	font-weight: normal;
	text-align: left;
	word-break: break-all;
}
@media (max-width: 768px) {
	th,
td {
		display: block;
		width: 100%;
	}
}

/*==================================================================
// icon
//================================================================*/
i.blank {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/external-link.svg?size=24&color=0B3D8C") center center no-repeat;
	background-size: contain;
	margin-left: 3px;
}

i.blank-s {
	display: inline-block;
	width: 0.5em;
	height: 0.5em;
	content: "";
	background: url("https://icongr.am/fontawesome/external-link.svg?size=24&color=0B3D8C") center center no-repeat;
	background-size: contain;
	margin-left: 3px;
	vertical-align: top;
}

i.lock {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/lock.svg?size=24&color=0B3D8C") center center no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(50% - 0.5em);
	left: 1rem;
}

i.lock-wt {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/lock.svg?size=24&color=ffffff") center center no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(50% - 0.5em);
	left: 1rem;
}

i.arrow-blue {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/chevron-right.svg?size=24&color=0B3D8C") center center no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(50% - 0.5em);
	right: 1rem;
}

i.arrow-wt {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/chevron-right.svg?size=24&color=ffffff") center center no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(50% - 0.5em);
	right: 1rem;
}

i.sns-twi {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/twitter.svg?size=24&color=ffffff") center center no-repeat;
	background-size: contain;
}

i.sns-ig {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/instagram.svg?size=24&color=ffffff") center center no-repeat;
	background-size: contain;
}

i.sns-fb {
	display: inline-block;
	width: 1em;
	height: 1em;
	content: "";
	background: url("https://icongr.am/fontawesome/facebook-square.svg?size=24&color=ffffff") center center no-repeat;
	background-size: contain;
}

i.icon {
	width: 1.5em;
	height: 1.5em;
	display: inline-block;
	vertical-align: middle;
}

.icon-mail {
  -webkit-mask: url(../ico/ico-mail.svg) no-repeat center center;
          mask: url(../ico/ico-mail.svg) no-repeat center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}

.icon-file {
  -webkit-mask: url(../ico/ico-file.svg) no-repeat center center;
          mask: url(../ico/ico-file.svg) no-repeat center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}

.icon-arrow {
  -webkit-mask: url(../ico/ico-arrow.svg) no-repeat center center;
          mask: url(../ico/ico-arrow.svg) no-repeat center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}

.icon-download {
  -webkit-mask: url(../ico/ico-download.svg) no-repeat center center;
          mask: url(../ico/ico-download.svg) no-repeat center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}

/*==================================================================
// layout
//================================================================*/
.container {
	position: relative;
	width: 100%;
	display: none;
}

.wrap {
	position: relative;
	width: 100%;
	z-index: 100;
}

.main {
	position: relative;
	overflow: hidden;
}

.bg {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: var(--color-White);
	z-index: -1;
}

/*==================================================================
// Section
//================================================================*/
.sectionInner {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1.6rem;
}
@media (max-width: 1280px) {
	.sectionInner {
		width: 95%;
	}
}
.sectionBg {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 1;
}
@media (max-width: 768px) {
	.sectionBg {
		display: none;
	}
}
.sectionBg__firework {
	width: 100%;
	height: 100%;
	position: relative;
}
.sectionBg__firework .firework-item {
	position: absolute;
	width: 400px;
	height: 400px;
}
.sectionBg__firework .firework-01 {
	background: url(../img/firework_01.png) no-repeat center center;
	background-size: contain;
}
.sectionBg__firework .firework-02 {
	background: url(../img/firework_02.png) no-repeat center center;
	background-size: contain;
}
.sectionBg__firework .firework-03 {
	background: url(../img/firework_03.png) no-repeat center center;
	background-size: contain;
}
.sectionBg__firework .firework-img {
	display: block;
	width: 100%;
	height: 100%;
	visibility: hidden;
}
.sectionBg__firework .firework-img.--anime {
  visibility: initial;
  -webkit-animation: firework-anime 2s 1 both;
          animation: firework-anime 2s 1 both;
}
@-webkit-keyframes firework-anime {
  0% {
    -webkit-clip-path: circle(0%);
            clip-path: circle(0%);
  }
  25% {
    -webkit-clip-path: circle(37%);
            clip-path: circle(37%);
  }
  50% {
    -webkit-clip-path: circle(43.5%);
            clip-path: circle(43.5%);
  }
  75% {
    -webkit-clip-path: circle(100%);
            clip-path: circle(100%);
  }
  100% {
    -webkit-clip-path: circle(100%);
            clip-path: circle(100%);
  }
}
@keyframes firework-anime {
  0% {
    -webkit-clip-path: circle(0%);
            clip-path: circle(0%);
  }
  25% {
    -webkit-clip-path: circle(37%);
            clip-path: circle(37%);
  }
  50% {
    -webkit-clip-path: circle(43.5%);
            clip-path: circle(43.5%);
  }
  75% {
    -webkit-clip-path: circle(100%);
            clip-path: circle(100%);
  }
  100% {
    -webkit-clip-path: circle(100%);
            clip-path: circle(100%);
  }
}
.sectionTitle {
	margin-bottom: 4rem;
	border-left: solid 2rem var(--color-Primary);
	padding: 1rem 2rem;
}
@media (max-width: 768px) {
	.sectionTitle {
		border-width: 1rem;
	}
}
.sectionTitle span {
	display: block;
}
.sectionTitle .ja {
	font-size: 5rem;
	line-height: 1em;
	font-weight: 900;
}
@media (max-width: 768px) {
	.sectionTitle .ja {
		font-size: min(8vw, 5rem);
	}
}
.sectionTitle .en {
	font-size: 2.5rem;
	line-height: 1.5em;
	color: var(--color-Primary);
	padding-top: 1rem;
}
@media (max-width: 768px) {
	.sectionTitle .en {
		font-size: min(4vw, 2.5rem);
	}
}
.sectionOverlay {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 2;
}
@media (max-width: 1280px) {
	.sectionOverlay {
		display: none;
	}
}
.sectionOverlay__goblin {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1.6rem;
	width: 100%;
	height: 100%;
	position: relative;
}
@media (max-width: 1280px) {
	.sectionOverlay__goblin {
		width: 95%;
	}
}
.sectionOverlay__goblin .goblin-item {
  position: absolute;
  width: 210px;
  -webkit-animation: yurayura 2s infinite step-start both;
          animation: yurayura 2s infinite step-start both;
}
.sectionOverlay__goblin .goblin-item:nth-child(odd) {
	left: -210px;
}
.sectionOverlay__goblin .goblin-item:nth-child(even) {
	right: -210px;
}
.sectionOverlay__goblin .goblin-img {
	width: 100%;
	height: auto;
}

/* ==========================================================================
	01_Component
	========================================================================== */
/*==================================================================
// btn
//================================================================*/
.c-btn {
  display: inline-block;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.c-btn > a {
	display: block;
	width: 100%;
	height: 100%;
}
.c-btn__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-btn.--headNav {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.02em;
  border-radius: 999px;
  border: solid 2px;
  width: 200px;
  height: 64px;
}
.c-btn.--headNav::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 0%;
  height: 100%;
  top: 0;
  left: 0;
  border-radius: 999px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.c-btn.--headNav:hover {
  -webkit-transform: scale(1.1) rotate(0.07deg);
          transform: scale(1.1) rotate(0.07deg);
}
.c-btn.--headNav:hover a {
	opacity: 1;
}
.c-btn.--headNav .icon {
	margin-right: 12px;
	width: 35px;
	height: 35px;
}
.c-btn.--rounded {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.02em;
  border-radius: 999px;
  border: solid 2px;
}
.c-btn.--rounded a {
	padding: 1em 1em;
}
.c-btn.--rounded:hover {
  -webkit-transform: scale(1.1) rotate(0.07deg);
          transform: scale(1.1) rotate(0.07deg);
}
.c-btn.--rounded:hover a {
	opacity: 1;
}
.c-btn.--hitodama::before, .c-btn.--hitodama::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 120%;
  aspect-ratio: 80/130;
  background: url(../img/hitodama_01.png) no-repeat center center !important;
  background-size: contain !important;
  will-change: transform, animation;
  -webkit-animation: fuwafuwa 2s infinite ease-in-out both;
          animation: fuwafuwa 2s infinite ease-in-out both;
}
.c-btn.--hitodama::before {
	left: -20px;
}
.c-btn.--hitodama::after {
  right: -20px;
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
.c-btn.--color-ocher {
	background: var(--color-btnOcherBg);
	border-color: var(--color-btnOcherBorder);
}
.c-btn.--color-ocher a {
	color: var(--color-btnOcherText);
}
.c-btn.--color-ocher::after {
	background: var(--color-btnOcherText);
}
.c-btn.--color-ocher::after a {
	color: var(--color-btnOcherBg);
}
.c-btn.--color-twi {
	background: var(--color-btnTwitterBg);
	border-color: var(--color-btnTwitterBorder);
}
.c-btn.--color-twi a {
	color: var(--color-btnTwitterText);
}
.c-btn.--color-twi::after {
	background: var(--color-btnTwitterText);
}
.c-btn.--color-twi::after a {
	color: var(--color-btnTwitterBg);
}
.c-btn.--color-turquoise {
	background: var(--color-btnTurquoiseBg);
	border-color: var(--color-btnTurquoiseBorder);
}
.c-btn.--color-turquoise a {
	color: var(--color-btnTurquoiseText);
}
.c-btn.--color-turquoise::after {
	background: var(--color-btnTurquoiseText);
}
.c-btn.--color-turquoise::after a {
	color: var(--color-btnTurquoiseBg);
}
.c-btn.--color-orange {
	background: var(--color-btnOrangeBg);
	border-color: var(--color-btnOrangeBorder);
}
.c-btn.--color-orange a {
	color: var(--color-btnOrangeText);
}
.c-btn.--color-orange::after {
	background: var(--color-btnOrangeText);
}
.c-btn.--color-orange::after a {
	color: var(--color-btnOrangeBg);
}

.ctaFloat {
	z-index: 200;
	position: fixed;
	bottom: 3%;
	right: 3%;
}
@media (max-width: 768px) {
	.ctaFloat {
		bottom: 1rem;
		right: 1rem;
	}
}
.ctaFloat a picture {
  height: 20vw;
  width: 20vw;
  max-width: 360px;
  max-height: 360px;
  position: relative;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.ctaFloat a picture:hover {
  -webkit-animation-name: wobble-horizontal;
          animation-name: wobble-horizontal;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  opacity: 1;
}
@media (max-width: 768px) {
	.ctaFloat a picture {
		height: 30vw;
		width: 30vw;
	}
}
.ctaFloat a picture:hover {
	opacity: 1;
}
.ctaFloat a picture img,
.ctaFloat a picture source {
	height: 100%;
	width: 100%;
}

/*==================================================================
// platformNav
//================================================================*/
.platformNav {
  position: relative;
  width: 100%;
  max-width: 690px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
@media (max-width: 1280px) {
	.platformNav {
		max-width: none;
	}
}
.platformNav .nav__item {
  position: relative;
  width: 100%;
  border: solid 4px #2aa6a8;
  border-radius: 16px;
  background: var(--color-White);
  padding: 2.5rem 4rem;
  gap: 2.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1024px) {
  .platformNav .nav__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 768px) {
	.platformNav .nav__item {
		padding: 2rem;
	}
}
.platformNav .nav__item .genre {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4375;
  letter-spacing: 0em;
  width: 120px;
  height: 64px;
  border-radius: 10px;
  background-color: #e4ca59;
  color: var(--color-White);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1280px) {
	.platformNav .nav__item .genre {
		width: 100%;
	}
}
@media (max-width: 768px) {
	.platformNav .nav__item .genre {
		font-size: 4vw;
	}
}
.platformNav .nav__item ul {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: center;
	position: relative;
	width: 100%;
}

.platformNav .nav__item ul .nav__btn {
  border: solid 2px #1e85a7;
  border-radius: 999px;
  background-color: #369fc1;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.platformNav .nav__item ul .nav__btn:hover a {
	opacity: 1;
}
.platformNav .nav__item ul .nav__btn a {
  text-align: center;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  color: var(--color-White);
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0em;
  padding: 16px;
}
.platformNav .nav__item.--pc .nav__btn, .platformNav .nav__item.--app .nav__btn {
	width: calc(50% - 8px);
}
@media (max-width: 480px) {
  .platformNav .nav__item.--pc .nav__btn, .platformNav .nav__item.--app .nav__btn {
    width: 100%;
  }
}
@media (max-width: 480px) {
	.platformNav .nav__item.--sp ul {
		width: 100%;
	}
}
.platformNav .nav__item.--sp .nav__btn {
	width: calc(50% - 8px);
}
@media (max-width: 768px) {
	.platformNav .nav__item.--sp .nav__btn {
		width: calc(50% - 8px);
	}
}
@media (max-width: 480px) {
	.platformNav .nav__item.--sp .nav__btn {
		width: 100%;
	}
}

/* ==========================================================================
	02_Global
	========================================================================== */
/*==================================================================
// Header
//================================================================*/
.header {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 200;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
@media (max-width: 768px) {
	.header {
		background-color: transparent;
	}
}

.headNav {
  position: relative;
  width: 100%;
  background: url(../img/texture_03.png) repeat;
  height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.headNav .nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  height: 100%;
  padding-right: 2rem;
  gap: 24px;
}
@media (max-width: 1440px) {
	.headNav .nav__list {
		gap: 12px;
	}
}
@media (max-width: 1280px) {
	.headNav .nav__list {
		display: none;
	}
}
.headNav .nav__item {
	position: relative;
	border: solid 2px var(--color-White);
	border-radius: 999px;
}
.headNav .nav__item a {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.02em;
  color: var(--color-White);
  padding: 10px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1440px) {
	.headNav .nav__item a {
		font-size: 14px;
		font-size: 1.4rem;
		line-height: 1.4285714286;
		letter-spacing: 0.02em;
	}
}
.headNav .nav__item:hover {
	background-color: var(--color-White);
}
.headNav .nav__item:hover a {
	opacity: 1;
	color: var(--color-Orange);
}
.headNav__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  height: 80px;
  gap: 16px;
  position: relative;
}
@media (max-width: 480px) {
	.headNav__btn {
		width: 95%;
	}
}
@media (max-width: 480px) {
	.headNav__btn .c-btn {
		width: 50%;
	}
}
.headNavSp {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	display: none;
	background: url(../img/texture_03.png) repeat;
	z-index: 500;
}
.headNavSp__btn {
	position: fixed;
	width: 8vw;
	height: 8vw;
	top: 2vw;
	right: 2vw;
	background: #ef5324;
	border-radius: 999px;
	border: solid 2px #d83f11;
	z-index: 600;
	display: none;
}
@media (max-width: 1280px) {
	.headNavSp__btn {
		display: block;
	}
}
@media (max-width: 768px) {
	.headNavSp__btn {
		width: 16vw;
		height: 16vw;
	}
}
.headNavSp__btn:hover {
  opacity: 1;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
}
.headNavSp__btn.open {
	background: var(--color-White);
}
.headNavSp__btn span {
  display: block;
  width: calc(8vw - 60%);
  top: 30%;
  left: calc(30% - 2px);
  position: absolute;
  height: 0.64vw;
  background: var(--color-White);
  right: 0;
  border-radius: 999px;
  -webkit-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
}
@media (max-width: 768px) {
	.headNavSp__btn span {
		width: calc(16vw - 60%);
	}
}
.headNavSp__btn span:nth-of-type(2) {
	top: calc(3.68vw - 2px);
}
@media (max-width: 768px) {
	.headNavSp__btn span:nth-of-type(2) {
		top: calc(7.68vw - 2px);
	}
}
.headNavSp__btn span:nth-of-type(3) {
	top: auto;
	bottom: 30%;
}
.headNavSp__btn.open span {
	background: #ef5324;
}
.headNavSp__btn.open span:nth-of-type(1) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.headNavSp__btn.open span:nth-of-type(2) {
	width: 0;
}
.headNavSp__btn.open span:nth-of-type(3) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
.headNavSp__inner {
  width: 70%;
  max-width: 480px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.headNavSp__inner .headNav {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: auto;
  gap: 24px;
}
.headNavSp__inner .headNav .nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: auto;
  padding: 0;
  gap: 16px;
}
.headNavSp__inner .headNav .nav__list li {
	width: 100%;
}
.headNavSp__inner .headNav .nav__list li span {
	font-size: 3vw;
}
@media (max-width: 768px) {
	.headNavSp__inner .headNav .nav__list li span {
		font-size: 4vw;
	}
}
.headNavSp__inner .headNav__btn {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: auto;
}
.headNavSp__inner .headNav__btn .c-btn {
	width: 100%;
	height: 96px;
}
@media (max-width: 768px) {
	.headNavSp__inner .headNav__btn .c-btn {
		height: 64px;
	}
}
.headNavSp__inner .headNav__btn .c-btn span {
	font-size: 2.8vw;
}
@media (max-width: 768px) {
	.headNavSp__inner .headNav__btn .c-btn span {
		font-size: 3.6vw;
	}
}

/*==================================================================
// Footer
//================================================================*/
.footer {
	position: relative;
	z-index: 100;
	background-color: var(--color-Black);
	background: url(../img/footer-bg.jpg) no-repeat center center;
	background-size: cover;
	padding: 9.6rem 0;
	margin: 0;
}
@media (max-width: 768px) {
	.footer {
		background: url(../img/footer-bg-sp.jpg) no-repeat center center;
		background-size: cover;
	}
}
.footer a {
	color: var(--color-White);
}
.footer__wrap {
	display: grid;
	grid-template-areas: "footerInfo footerNav" "footerText footerNav";
	grid-template-columns: 40% 60%;
}
@media (max-width: 1024px) {
	.footer__wrap {
		grid-template-areas: "footerInfo" "footerNav" "footerText";
		grid-template-columns: 100%;
	}
}
.footer .info {
  grid-area: footerInfo;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
}
@media (max-width: 1024px) {
	.footer .info {
		padding-bottom: 7rem;
	}
}
.footer .info > a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.footer .info > a:hover {
  -webkit-animation-name: wobble-horizontal;
          animation-name: wobble-horizontal;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  opacity: 1;
}
.footer .info > a:hover {
	opacity: 1;
}
.footer .info picture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}
@media (max-width: 768px) {
	.footer .info picture {
		padding-bottom: 3rem;
	}
}
@media (max-width: 480px) {
	.footer .info picture {
		padding-bottom: 1rem;
	}
}
.footer .info picture source,
.footer .info picture img {
	width: 100%;
	max-width: 400px;
	height: auto;
}
@media (max-width: 768px) {
	.footer .info picture source,
.footer .info picture img {
		max-width: 420px;
	}
}
.footer .info .c-btn {
	width: 200px;
}
@media (max-width: 768px) {
	.footer .info .c-btn {
		max-width: 90%;
	}
}
.footer .text {
  grid-area: footerText;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 1rem;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1024px) {
	.footer .text {
		padding-top: 7rem;
	}
}
.footer .text .policy a {
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1.5;
	letter-spacing: 0em;
	color: #e4ca59;
	text-decoration: underline;
}
.footer .text .copyright {
	color: var(--color-White);
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1.5;
	letter-spacing: 0em;
	margin: 0;
}
.footer .platformNav {
	grid-area: footerNav;
}
@media (max-width: 1280px) {
	.footer .platformNav .genre {
		width: 120px;
	}
}
@media (max-width: 1024px) {
	.footer .platformNav .genre {
		width: 100%;
	}
}

/*==================================================================
// Loading
//================================================================*/
.loadings {
  width: 100vw;
  height: 100vh;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  background-color: var(--color-LoadingBg);
  -webkit-transition-property: opacity, visibility;
  transition-property: opacity, visibility;
  position: fixed;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 999;
}
.loadings.loaded {
	opacity: 0;
	visibility: hidden;
}

.loading__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 42px;
}
.loading__img {
  width: 160px;
  -webkit-animation: fuwafuwa 2s infinite ease-in-out both;
          animation: fuwafuwa 2s infinite ease-in-out both;
}
.loading__text {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-White);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}
.loading__text span {
  display: block;
  -webkit-transform: translate(0, 105%);
          transform: translate(0, 105%);
  -webkit-transition: -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s, -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}
.loading__text.-visible span {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}
.loading__text span:nth-child(2) {
  -webkit-transition-delay: 0.06s;
          transition-delay: 0.06s;
}
.loading__text span:nth-child(3) {
  -webkit-transition-delay: 0.12s;
          transition-delay: 0.12s;
}
.loading__text span:nth-child(4) {
  -webkit-transition-delay: 0.18s;
          transition-delay: 0.18s;
}
.loading__text span:nth-child(5) {
  -webkit-transition-delay: 0.24s;
          transition-delay: 0.24s;
}
.loading__text span:nth-child(6) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.loading__text span:nth-child(7) {
  -webkit-transition-delay: 0.36s;
          transition-delay: 0.36s;
}
.loading__text span:nth-child(8) {
  -webkit-transition-delay: 0.42s;
          transition-delay: 0.42s;
}
.loading__text span:nth-child(9) {
  -webkit-transition-delay: 0.48s;
          transition-delay: 0.48s;
}
.loading__text span:nth-child(10) {
  -webkit-transition-delay: 0.54s;
          transition-delay: 0.54s;
}
.loading__text span:nth-child(11) {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}

/* ==========================================================================
	03_Pages
	========================================================================== */
/*==================================================================
// mainVisual
//================================================================*/
.mainVisual {
  position: relative;
  width: 100%;
  height: 100vh;
  max-height: 820px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
}
@media (max-width: 1280px) {
	.mainVisual {
		height: 100%;
		max-height: none;
	}
}
@media (max-width: 768px) {
	.mainVisual {
		padding-top: 0;
	}
}
.mainVisual__bg {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: absolute;
	background-color: var(--color-White);
	z-index: -2;
}
.mainVisual__bg source,
.mainVisual__bg img {
  -o-object-fit: cover;
     object-fit: cover;
  pointer-events: none;
}
.mainVisual__inner {
  position: relative;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media (max-width: 768px) {
  .mainVisual__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.mainVisual__content {
  position: relative;
  width: 60%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}


@media (max-width: 1280px) {
	.mainVisual__content {
		width: 50%;
	}
}
@media (max-width: 768px) {
  .mainVisual__content {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    width: 100%;
    max-width: 100%;
    height: auto;
    margin-top: -50vw;
    z-index: 2;
  }
}
.mainVisual__content--img {
	width: 100%;
	max-width: 780px;
}
.mainVisual__kitaro {
  position: relative;
  width: calc(40% + (100vw - 1280px) / 2);
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-animation: mvKitaro 2s infinite ease-in-out both;
          animation: mvKitaro 2s infinite ease-in-out both;
}
@media (max-width: 1280px) {
	.mainVisual__kitaro {
		width: 50%;
	}
}
@media (max-width: 768px) {
  .mainVisual__kitaro {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 100%;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: -30vw;
    height: auto;
    z-index: 1;
  }
}
@-webkit-keyframes mvKitaro {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes mvKitaro {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.mainVisual__scroll {
	position: absolute;
	bottom: 0;
	height: 90px;
}
@media (max-width: 1280px) {
	.mainVisual__scroll {
		height: 60px;
	}
}
@media (max-width: 768px) {
	.mainVisual__scroll {
		height: 30px;
	}
}
.mainVisual__scroll--wrap {
	position: relative;
	height: 100%;
}
.mainVisual__scroll .line {
	position: relative;
	display: block;
	margin: 0 auto;
	width: 10px;
	height: 100%;
}
.mainVisual__scroll .line::after {
  position: absolute;
  bottom: 2px;
  content: "";
  display: block;
  margin: 0;
  padding: 0;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--color-Primary);
  border-right: 2px solid var(--color-Primary);
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
}
.mainVisual__scroll .line::before {
  position: absolute;
  bottom: 0;
  left: calc(50% - 1px);
  margin-left: -1px;
  width: 2px;
  height: 100%;
  background: #b91a2f;
  content: "";
  -webkit-animation: elasticus 3s cubic-bezier(1, 0, 0, 1) infinite;
          animation: elasticus 3s cubic-bezier(1, 0, 0, 1) infinite;
}
.mainVisual__scroll .text {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-weight: 900;
  position: absolute;
  left: 20px;
  top: calc(50% - 0.5em);
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0;
  color: var(--color-Dark);
}
@media (max-width: 1280px) {
	.mainVisual__scroll .text {
		font-size: 1.6rem;
	}
}

/*==================================================================
// present
//================================================================*/
.presentSection {
	background: url(../img/texture_01.jpg) repeat;
	padding: 5rem 0 2rem;
	position: relative;
	width: 100%;
}
.presentSection.thanksErrSection {
	padding-top: 0!important;
}

@media (max-width: 768px) {
	.presentSection {
		padding: 3rem 0 4rem;
	}
}
.presentSection .sectionInner {
	padding-right: 4rem;
	padding-left: 4rem;
}
@media (max-width: 1280px) {
	.presentSection .sectionInner {
		padding-right: 2vw;
		padding-left: 2vw;
	}
}
.presentSection__title {
	position: relative;
	width: 100%;
	background: url(../img/texture_03.png) repeat;
	z-index: 10;
}
@media (max-width: 768px) {
	.presentSection__title .sectionInner {
		width: 100%;
		padding: 0;
	}
}
.presentSection__title picture {
	width: 100%;
	max-width: 1200px;
	position: relative;
	z-index: 1;
}
.presentSection__title picture::after {
	content: "";
	position: absolute;
	right: -100px;
	bottom: 0px;
	height: 120%;
	aspect-ratio: 230/208;
	background: url(../img/balloon_01.png) no-repeat center center;
	background-size: contain;
	z-index: -1;
}
@media (max-width: 1440px) {
	.presentSection__title picture::after {
		height: 100%;
		right: 0;
		bottom: 20px;
	}
}
@media (max-width: 768px) {
	.presentSection__title picture::after {
		top: -10%;
		height: 60%;
	}
}
.presentSection__list {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 6rem 0 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 4rem;
  z-index: 10;
}
@media (max-width: 768px) {
	.presentSection__list {
		padding: 2rem 0 2rem;
		gap: 2rem;
	}
}
.presentSection__list .item {
  background: var(--color-White);
  border: solid 10px var(--color-SectionA_Border);
  border-radius: 40px;
  padding: 3.6rem;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media (max-width: 768px) {
  .presentSection__list .item {
    gap: 2rem;
    padding: 3vw;
  }
}
.presentSection__list .item__title {
	width: 100%;
	background: url(../img/texture_03.png) repeat;
	border-radius: 999px;
	margin-bottom: 36px;
}
@media (max-width: 768px) {
	.presentSection__list .item__title {
		margin-bottom: 0;
	}
}
.presentSection__list .item__img {
	width: calc(50% - 10px);
}
@media (max-width: 768px) {
  .presentSection__list .item__img {
    width: 100%;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
.presentSection__list .item__content {
  background: linear-gradient(-45deg, #e8cf6a 25%, #e5c959 25%, #e5c959 50%, #e8cf6a 50%, #e8cf6a 75%, #e5c959 75%, #e5c959);
  background-size: 20px 20px;
  border-radius: 2rem;
  padding: 46px 40px;
  width: calc(50% - 10px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (max-width: 768px) {
  .presentSection__list .item__content {
    width: 100%;
    padding: 3rem;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
.presentSection__list .item__content .title {
  color: #8d4411;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  margin-bottom: 20px;
}
@media (max-width: 1280px) {
  .presentSection__list .item__content .title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 16px;
  }
}
@media (max-width: 768px) {
  .presentSection__list .item__content .title {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.presentSection__list .item__content .title p {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 28px;
  font-size: 2.8rem;
  line-height: 1.4285714286;
  letter-spacing: 0em;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media (max-width: 768px) {
	.presentSection__list .item__content .title p {
		font-size: 4vw;
	}
}
.presentSection__list .item__content .title img {
	margin-left: 8px;
}
@media (max-width: 768px) {
	.presentSection__list .item__content .title img {
		width: 30%;
		height: auto;
	}
}
.presentSection__list .item__content .detail {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.7142857143;
  letter-spacing: 0.1em;
  color: #554848;
}
@media (max-width: 768px) {
	.presentSection__list .item__content .detail {
		font-size: 3vw;
	}
}
.presentSection__list .item__content .detail .c-btn {
	width: 100%;
	max-width: 320px;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 1;
	letter-spacing: 0.02em;
}
@media (max-width: 768px) {
	.presentSection__list .item__content .detail .c-btn {
		font-size: 4vw;
		max-width: 500px;
	}
}
.presentSection__list .item:not(.thanksErrItem):first-of-type {
	-webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
	padding: 0;
}
@media (max-width: 1280px) {
	.presentSection__list .item:not(.thanksErrItem):first-of-type {
		margin-bottom: calc((1280px - 100vw) * 0.3);
	}
}
@media (max-width: 768px) {
	.presentSection__list .item:not(.thanksErrItem):first-of-type {
		margin-bottom: 0;
		padding: 3vw;
	}
}
.presentSection__list .item:first-of-type .item__content {
	position: absolute;
  bottom: 20px;
  right: -110px;
  width: 950px;
  height: 220px;
  background: url(../img/txt-bg_01.png) no-repeat center center;
  background-size: contain;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: none;
  padding: 36px 20px;
}
@media (max-width: 1280px) {
	.presentSection__list .item:first-of-type .item__content {
		bottom: calc(20px + (1280px - 100vw) * -0.3);
	}
}
@media (max-width: 1024px) {
	.presentSection__list .item:first-of-type .item__content {
		right: auto;
		left: auto;
	}
}
@media (max-width: 768px) {
	.presentSection__list .item:first-of-type .item__content {
		position: relative;
		margin-top: -10vw;
		top: 0;
		left: 0;
		width: 100%;
		height: auto;
		background: linear-gradient(-45deg, #e8cf6a 25%, #e5c959 25%, #e5c959 50%, #e8cf6a 50%, #e8cf6a 75%, #e5c959 75%, #e5c959);
		background-size: 20px 20px;
		padding: 3rem;
	}
}
@media (max-width: 1280px) {
  .presentSection__list .item:first-of-type .title {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0;
  }
}
@media (max-width: 768px) {
  .presentSection__list .item:first-of-type .title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
  }
}
@media (max-width: 768px) {
	.presentSection__list .item:first-of-type .title p {
		font-size: 4.8vw;
	}
}
@media (max-width: 768px) {
	.presentSection__list .item:first-of-type .title img {
		width: 50%;
	}
}
.presentSection__list .item:first-of-type .detail {
	text-align: left;
}
.presentSection__list .item:first-of-type .item__img {
	width: 1240px;
}
@media (max-width: 1280px) {
	.presentSection__list .item:first-of-type .item__img {
		width: 100%;
		max-width: 1240px;
	}
}
.presentSection__list .item:first-of-type .item__img picture {
	width: 100%;
	margin-left: -60px;
	margin-top: -40px;
}
@media (max-width: 1024px) {
	.presentSection__list .item:first-of-type .item__img picture {
		margin-left: 0;
	}
}
.presentSection__list .item:nth-of-type(2), .presentSection__list .item:nth-of-type(3) {
  width: calc(50% - 4rem / 2);
  margin-top: 3rem;
}
@media (max-width: 1024px) {
  .presentSection__list .item:nth-of-type(2), .presentSection__list .item:nth-of-type(3) {
    margin-top: 0;
    width: 100%;
  }
}
.presentSection__list .item:nth-of-type(2) .detail, .presentSection__list .item:nth-of-type(3) .detail {
  text-align: left;
}
@media (max-width: 1024px) {
  .presentSection__list .item:nth-of-type(2) .detail, .presentSection__list .item:nth-of-type(3) .detail {
    text-align: center;
  }
}
.presentSection__list .item:nth-of-type(2) .title p, .presentSection__list .item:nth-of-type(3) .title p {
	font-size: 24px;
	font-size: 2.4rem;
	line-height: 1.5;
	letter-spacing: 0em;
}
@media (max-width: 768px) {
	.presentSection__list .item:nth-of-type(2) .title p, .presentSection__list .item:nth-of-type(3) .title p {
		font-size: 4vw;
	}
}
.presentSection__list .item:nth-of-type(2) .item__img, .presentSection__list .item:nth-of-type(3) .item__img {
  margin-bottom: -1rem;
  margin-top: -8rem;
}
@media (max-width: 1024px) {
  .presentSection__list .item:nth-of-type(2) .item__img, .presentSection__list .item:nth-of-type(3) .item__img {
    margin-bottom: 0;
    margin-top: 0;
  }
}
@media (max-width: 1024px) {
  .presentSection__list .item:nth-of-type(2) .item__img img, .presentSection__list .item:nth-of-type(3) .item__img img {
    margin-right: auto;
    margin-left: auto;
  }
}
.presentSection__list .item:nth-of-type(2) .item__img,
.presentSection__list .item:nth-of-type(2) .item__content, .presentSection__list .item:nth-of-type(3) .item__img,
.presentSection__list .item:nth-of-type(3) .item__content {
	width: 100%;
}
.presentSection__list .item:last-of-type {
  margin-bottom: 3rem;
}
.presentSection .goblin-item:nth-child(1) {
	top: 15%;
}
.presentSection .goblin-item:nth-child(2) {
	top: 32%;
}
.presentSection .goblin-item:nth-child(3) {
	top: 50%;
}
.presentSection .goblin-item:nth-child(4) {
	top: 68%;
}
.presentSection .goblin-item:nth-child(5) {
	bottom: 12%;
}

.ctaSection {
	position: relative;
	width: 100%;
	padding: 10rem 0;
	background: url(../img/cta-bg.png) no-repeat center center;
	background-size: cover;
}
@media (max-width: 768px) {
	.ctaSection {
		padding: 5rem 0;
		background: url(../img/cta-bg-sp.png) no-repeat center center;
	}
}
.ctaSection::before, .ctaSection::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 120%;
  -webkit-animation: yurayura 2s infinite step-start both;
          animation: yurayura 2s infinite step-start both;
  z-index: 2;
}
@media (max-width: 1280px) {
	.ctaSection::before, .ctaSection::after {
		height: 80%;
		top: -5%;
	}
}
@media (max-width: 1024px) {
	.ctaSection::before, .ctaSection::after {
		height: 60%;
	}
}
@media (max-width: 768px) {
	.ctaSection::before, .ctaSection::after {
		top: -5%;
	}
}
@media (max-width: 480px) {
	.ctaSection::before, .ctaSection::after {
		height: 50%;
	}
}
.ctaSection::before {
	left: -20px;
	aspect-ratio: 660/984;
	background: url(../img/img-yokai-kitaro.png) no-repeat center center;
	background-size: contain;
}
@media (max-width: 1650px) {
	.ctaSection::before {
		left: -5%;
	}
}
.ctaSection::after {
	right: -20px;
	aspect-ratio: 774/968;
	background: url(../img/img-yokai-neko.png) no-repeat center center;
	background-size: contain;
}
@media (max-width: 1650px) {
	.ctaSection::after {
		right: -10%;
	}
}
.ctaSection .sectionInner {
	position: relative;
	z-index: 3;
}

.ctaSection__title,.thanksErrH2 {
	position: relative;
	margin-bottom: 56px;
	z-index: 3;
}
.ctaSection__h2 {
	position: relative;
	z-index: 3;
}
@media (max-width: 768px) {
	.ctaSection__title,.thanksErrH2 {
		margin-bottom: 24px;
	}
}
.ctaSection__title h2 {
	width: auto;
}

.thanksErrH2,.ctaSection__h2 {
	width: 100%;
}
.ctaSection__title h2,.thanksErrH2,.ctaSection__h2 {
	position: relative;
	display: inline-block;
	color: #8d4411;
	font-size: 32px;
	font-size: 3.2rem;
	line-height: 1.375;
	letter-spacing: 0em;
	z-index: 2;
}
.ctaSection__title h2 span,.thanksErrH2 span,.ctaSection__h2 span {
	font-size: 36px;
	font-size: 3.6rem;
	line-height: 1.2222222222;
	letter-spacing: 0em;
}
@media (max-width: 768px) {
	.ctaSection__title h2,.thanksErrH2,.ctaSection__h2 {
		font-size: 4vw;
	}
	.ctaSection__title h2 span,.thanksErrH2 span,.ctaSection__h2 span {
		font-size: 4.4vw;
	}
}
.ctaSection__title h2::after {
	content: "";
	position: absolute;
	left: -200px;
	bottom: 20px;
	height: 220%;
	aspect-ratio: 230/205;
	background: url(../img/balloon_02.png) no-repeat center center;
	background-size: contain;
	z-index: -1;
}
@media (max-width: 1440px) {
	.ctaSection__title h2::after {
		height: 150%;
		left: -130px;
	}
}
@media (max-width: 1280px) {
	.ctaSection__title h2::after {
		left: calc(50% - 300px);
		top: -100%;
	}
}
@media (max-width: 1024px) {
	.ctaSection__title h2::after {
		left: calc(50% - 260px);
	}
}
@media (max-width: 768px) {
	.ctaSection__title h2::after {
		height: 100%;
		top: -100%;
		left: calc((100vw - 100%) / 2 * -1 + 100px);
	}
}
.ctaSection__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 120px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 4;
}
@media (max-width: 1280px) {
	.ctaSection__btn {
		gap: 40px;
	}
}
@media (max-width: 768px) {
  .ctaSection__btn {
    gap: 2rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.ctaSection__btn .c-btn {
	width: 400px;
}
@media (max-width: 480px) {
	.ctaSection__btn .c-btn {
		width: 90%;
	}
}
.ctaSection__btn .c-btn a {
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 0.7142857143;
	letter-spacing: 0em;
	padding: 1em;
}
@media (max-width: 480px) {
	.ctaSection__btn .c-btn a {
		font-size: 5vw;
	}
}

/*==================================================================
// howto
//================================================================*/
.howtoSection {
	position: relative;
	width: 100%;
	padding: 5rem 0 2rem;
	background: url(../img/texture_02.jpg) repeat;
}
@media (max-width: 768px) {
	.howtoSection {
		padding: 3rem 0 4rem;
	}
}
.howtoSection .sectionInner {
	padding-right: 4rem;
	padding-left: 4rem;
}
@media (max-width: 1280px) {
	.howtoSection .sectionInner {
		padding-right: 2vw;
		padding-left: 2vw;
	}
}
@media (max-width: 768px) {
	.howtoSection .sectionInner {
		padding-right: 1rem;
		padding-left: 1rem;
	}
}
.howtoSection > .sectionInner {
	z-index: 20;
	position: relative;
}
.howtoSection__title {
	position: relative;
	width: 100%;
	background: url(../img/texture_03.png) repeat;
	z-index: 10;
}
@media (max-width: 768px) {
	.howtoSection__title .sectionInner {
		width: 100%;
		padding: 0;
	}
}
.howtoSection__title picture {
	width: 100%;
	max-width: 1200px;
	position: relative;
}
.howtoSection__desc {
  padding: 8rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  z-index: 10;
}
.howtoSection__desc p {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0em;
  color: #60390e;
  margin-bottom: 46px;
}
.howtoSection__desc picture,.howtoSection__desc .period {
	margin: 0 auto 0;
}
.howtoSection__desc .period dt {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	margin-bottom: 10px;
	text-align: center;
}
.howtoSection__desc .period dd {
	-webkit-transform: rotate(0.07deg);
	transform: rotate(0.07deg);
	font-weight: 700;
	-webkit-font-smoothing: subpixel-antialiased;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
	color: #60390e;
}
.howtoSection__desc .period dd span {
	display: block;
	font-weight: 500;
	width: 100%;
}


.howtoSection__item {
	position: relative;
	width: 100%;
	border: solid 10px #2aa6a8;
	border-radius: 40px;
	background: var(--color-White);
	padding: 4rem 4rem 3rem;
	margin-bottom: 42px;
	z-index: 10;
}
@media (max-width: 768px) {
	.howtoSection__item {
		padding-right: 2rem;
		padding-left: 2rem;
	}
}
.howtoSection__item--head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (max-width: 1280px) {
  .howtoSection__item--head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.howtoSection__item--head .ttl {
	width: 40%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
}
@media (max-width: 1280px) {
	.howtoSection__item--head .ttl {
		width: 100%;
	}
}
.howtoSection__item--head .ttl .num {
  grid-area: howtoItemHeadNum;
  font-size: 28px;
  font-size: 2.8rem;
  line-height: 1.4285714286;
  letter-spacing: 0.1em;
  width: 200px;
  height: 80px;
  background-color: #ef5324;
  color: var(--color-White);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.howtoSection__item--head .ttl h2 {
	grid-area: howtoItemHeadH2;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
	color: #8d4411;
	margin: 42px 0 30px;
}
@media (max-width: 1280px) {
	.howtoSection__item--head .ttl h2 {
		font-size: 3vw;
	}
}
@media (max-width: 768px) {
	.howtoSection__item--head .ttl h2 {
		font-size: 5vw;
		margin: 5vw 0 4vw;
	}
}
.howtoSection__item--head .ttl p {
	grid-area: howtoItemHeadP;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.25;
	letter-spacing: 0em;
	color: #554848;
}
@media (max-width: 1280px) {
	.howtoSection__item--head .ttl p {
		font-size: 2vw;
		margin-bottom: 32px;
	}
}
@media (max-width: 768px) {
  .howtoSection__item--head .ttl p {
    font-size: 4vw;
  }
}
.howtoSection__item--head .ttl p small {
  font-size: 0.7em;
  color: var(--color-Gray);
}
.howtoSection__item--head .ttl.--wide {
	width: 100%;
	display: grid;
	grid-template-areas: "howtoItemHeadNum howtoItemHeadPicture" "howtoItemHeadH2 howtoItemHeadPicture" "howtoItemHeadP howtoItemHeadPicture" "howtoItemHeadBtn howtoItemHeadPicture";
	grid-template-columns: 40% 60%;
}
@media (max-width: 1280px) {
	.howtoSection__item--head .ttl.--wide {
		grid-template-areas: "howtoItemHeadNum" "howtoItemHeadPicture" "howtoItemHeadH2" "howtoItemHeadP" "howtoItemHeadBtn";
		grid-template-columns: 100%;
	}
}
.howtoSection__item--head .ttl.--wide .num,
.howtoSection__item--head .ttl.--wide H2,
.howtoSection__item--head .ttl.--wide p,
.howtoSection__item--head .ttl.--wide .c-btn {
	margin-right: auto;
	margin-left: auto;
}
.howtoSection__item--head .ttl .c-btn {
	grid-area: howtoItemHeadBtn;
	margin-top: 3rem;
	width: 90%;
	max-width: 320px;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 0.7142857143;
	letter-spacing: 0.02em;
}
@media (max-width: 768px) {
	.howtoSection__item--head .ttl .c-btn {
		max-width: none;
		margin-top: 1rem;
		font-size: 6vw;
		width: auto;
	}
	.howtoSection__item--head .ttl .c-btn a {
		padding-right: 2em;
		padding-left: 2em;
	}
}
.howtoSection__item--head .ttl > picture {
	grid-area: howtoItemHeadPicture;
}
@media (max-width: 1280px) {
	.howtoSection__item--head .ttl > picture {
		width: 100%;
		margin-top: 3rem;
	}
}
.howtoSection__item--head .ttl > picture img,
.howtoSection__item--head .ttl > picture source {
	margin-right: auto;
	margin-left: auto;
}
.howtoSection__item .accordion {
  border: solid 4px #1e85a7;
  border-radius: 32px;
  background-color: #f0f0f0;
  width: 100%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  margin-top: 48px;
  margin-bottom: 32px;
}
.howtoSection__item .accordion__header {
  position: relative;
  border: solid 4px #1e85a7;
  border-radius: 32px;
  background-color: #369fc1;
  color: var(--color-White);
  width: calc(100% + 8px);
  height: 64px;
  margin-top: -10px;
  margin-bottom: -14px;
  margin-left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  z-index: 2;
}
.howtoSection__item .accordion__header::after {
  -webkit-mask: url(../ico/ico-arrow-up.svg) no-repeat center center;
          mask: url(../ico/ico-arrow-up.svg) no-repeat center center;
  -webkit-mask-size: contain;
          mask-size: contain;
  right: 3rem;
  content: "";
  width: 5.5rem;
  height: 5.5rem;
  background-color: var(--color-White);
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media (max-width: 768px) {
  .howtoSection__item .accordion__header::after {
    right: 3vw;
    width: 6vw;
    height: 6vw;
  }
}
.howtoSection__item .accordion__header.open::after {
  -webkit-transform: translateY(-50%) rotate(-180deg);
          transform: translateY(-50%) rotate(-180deg);
}
.howtoSection__item .accordion__header p {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__header p {
		font-size: 3.5vw;
		line-height: 1.2em;
	}
}
.howtoSection__item .accordion__inner {
	width: 100%;
	padding: 3rem 4rem 7rem;
	z-index: 1;
	display: none;
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner {
		padding-right: 2rem;
		padding-left: 2rem;
	}
}
.howtoSection__item .accordion__inner > p {
	color: #d54317;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
}
.howtoSection__item .accordion__inner .flowBox {
	position: relative;
	width: 100%;
	color: #554848;
	margin-bottom: 52px;
}
.howtoSection__item .accordion__inner .flow__title {
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
	margin-bottom: 24px;
}
.howtoSection__item .accordion__inner .flow__wrap {
  position: relative;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner .flow__wrap {
		gap: 1rem;
	}
}
.howtoSection__item .accordion__inner .flow__item {
	position: relative;
	width: 33%;
	max-width: 320px;
	background-color: var(--color-White);
	padding: 0;
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner .flow__item {
		width: 100%;
		max-width: none;
	}
}
.howtoSection__item .accordion__inner .flow__item input {
	display: none;
}
.howtoSection__item .accordion__inner .flow__item input:checked + label::before {
  position: absolute;
  content: "";
  top: -5px;
  right: -5px;
  width: 30px;
  height: 15px;
  border-left: 6px solid #ef5324;
  border-bottom: 6px solid #ef5324;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner .flow__item input:checked + label::before {
		top: 5px;
		left: -5px;
	}
}
.howtoSection__item .accordion__inner .flow__item label,
.howtoSection__item .accordion__inner .flow__item a {
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #554848;
}
.howtoSection__item .accordion__inner .flow__item label {
	cursor: pointer;
	position: relative;
}
.howtoSection__item .accordion__inner .flow__name {
  width: 100%;
  height: 64px;
  background-color: #e4ca59;
  border: solid 2px #ccb343;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0em;
  color: var(--color-White);
}
@media (max-width: 768px) {
  .howtoSection__item .accordion__inner .flow__name {
    font-size: 4vw;
    height: auto;
    line-height: 2;
  }
}
.howtoSection__item .accordion__inner .flow__content {
  position: relative;
  width: 100%;
  background-color: var(--color-White);
  border: solid 2px #ccb343;
  border-top: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 30px 20px 35px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  gap: 16px;
}
@media (max-width: 768px) {
  .howtoSection__item .accordion__inner .flow__content {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    padding: 2rem;
  }
}
@media (max-width: 768px) {
  .howtoSection__item .accordion__inner .flow__content > picture {
    width: 50%;
  }
}
.howtoSection__item .accordion__inner .flow__content > p {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.7142857143;
	letter-spacing: 0em;
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner .flow__content > p {
		width: 50%;
		text-align: left;
		font-size: 3vw;
	}
}
.howtoSection__item .accordion__inner .flow-02 .flow__wrap {
	justify-content: center;
	gap: 12px;
}
.howtoSection__item .accordion__inner .flow-02 .flow__item {
	width: 24.5%;
	margin-bottom: 20px;
}
@media (max-width: 1024px) {
	.howtoSection__item .accordion__inner .flow-02 .flow__item {
		width: 49%;
	}
}
@media (max-width: 768px) {
	.howtoSection__item .accordion__inner .flow-02 .flow__item {
		width: 100%;
		max-width: none;
		margin-bottom: 0;
	}
}
.howtoSection__item .accordion__inner .flow-02, .howtoSection__item .accordion__inner .flow-03 {
	display: none;
}
.howtoSection .goblin-item:nth-child(1) {
	top: 15%;
}
.howtoSection .goblin-item:nth-child(2) {
	top: 32%;
}
.howtoSection .goblin-item:nth-child(3) {
	top: 50%;
}
.howtoSection .goblin-item:nth-child(4) {
	top: 68%;
}
.howtoSection .goblin-item:nth-child(5) {
	bottom: 12%;
}

/*==================================================================
// detail
//================================================================*/
.detailSection {
  position: relative;
  width: 100%;
  padding: 0 0 2rem;
  background-color: var(--color-White);
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
}
@media (max-width: 768px) {
	.detailSection {
		padding: 0 0 4rem;
	}
}
.detailSection > .sectionInner {
	z-index: 10;
}
.detailSection__title {
	position: relative;
	width: 100%;
	background: url(../img/texture_03.png) repeat;
	z-index: 10;
}
@media (max-width: 768px) {
	.detailSection__title .sectionInner {
		width: 100%;
		padding: 0;
	}
}
.detailSection__title picture {
	width: 100%;
	max-width: 1200px;
	position: relative;
}
.detailSection__desc {
  position: relative;
  width: 100%;
  padding: 3rem 0 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 768px) {
  .detailSection__desc {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.detailSection__desc picture {
	width: 55%;
}
@media (max-width: 768px) {
	.detailSection__desc picture {
		width: 100%;
	}
}
.detailSection__desc p {
	width: 45%;
	height: 100%;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
	color: #554848;
}
@media (max-width: 1280px) {
	.detailSection__desc p {
		font-size: min(3.4vw, 18px);
	}
}
@media (max-width: 768px) {
	.detailSection__desc p {
		width: 100%;
	}
}
.detailSection__img {
  position: relative;
  width: 100%;
  padding: 3rem 0 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 768px) {
  .detailSection__img {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.detailSection__img picture {
	width: 100%;
}
.detailSection__btn {
  position: relative;
  width: 100%;
  padding: 3rem 0 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 1024px) {
  .detailSection__btn {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 0 4rem;
  }
}
.detailSection__btn p {
	width: 50%;
	font-size: 32px;
	font-size: 3.2rem;
	line-height: 1.5625;
	letter-spacing: 0em;
	color: var(--color-Orange);
}
@media (max-width: 1280px) {
	.detailSection__btn p {
		font-size: min(4vw, 32px);
	}
}
@media (max-width: 1024px) {
	.detailSection__btn p {
		width: 100%;
		margin-bottom: 2rem;
	}
}
.detailSection__btn .c-btn {
	width: 400px;
	margin-right: auto;
	margin-left: auto;
}
@media (max-width: 480px) {
	.detailSection__btn .c-btn {
		width: 90%;
	}
}
.detailSection__btn .c-btn a {
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 0.7142857143;
	letter-spacing: 0em;
	padding: 1em;
}
@media (max-width: 480px) {
	.detailSection__btn .c-btn a {
		font-size: 5vw;
	}
}

/*==================================================================
// form
//================================================================*/
.formSection {
	position: relative;
	width: 100%;
	padding: 8rem 0 8rem;
	background: url(../img/texture_01.jpg) repeat;
}
@media (max-width: 768px) {
	.formSection {
		padding: 3rem 0 4rem;
	}
}

.formSection__wrap {
  background: var(--color-White);
  border: solid 10px var(--color-SectionA_Border);
  border-radius: 40px;
  padding: 3rem 3rem 12rem;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 10;
}
.formSection__wrap.titleOnly {
	padding-bottom: 3rem;
}
@media (max-width: 768px) {
  .formSection__wrap {
    gap: 2rem;
    padding: 3vw;
  }
}
.formSection__title {
	position: relative;
	width: 100%;
	background: url(../img/ttl-bg_01.png) no-repeat center center;
	background-size: contain;
}
@media (max-width: 768px) {
	.formSection__title {
		background: url(../img/ttl-bg-sp_01.png) no-repeat center center;
		background-size: contain;
	}
}
.formSection__title picture {
	width: 100%;
	position: relative;
}
.formSection__title picture img,
.formSection__title picture source {
	margin-right: auto;
	margin-left: auto;
}
.formSection .entryForm {
  width: 100%;
  max-width: 500px;
  margin-right: auto;
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: left;
  padding: 0rem 0 5rem;
}
@media (max-width: 768px) {
	.formSection .entryForm {
		padding: 0 1rem 5rem;
	}
}
.formSection .entryForm .form-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.formSection .entryForm label,
.formSection .entryForm p.label {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0em;
  margin-top: 3.2rem;
  margin-bottom: 0.3em;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  color: #554848;
}
.formSection .entryForm label:not(.comRadioLabel):not(.comCheckLabel) span,
.formSection .entryForm p.label span {
	font-size: 0.8em;
}

.check_box.list label:not(:last-of-type) {
	margin-bottom: 10px;
}

.check_box.list label {
	display: inline-block;
	margin-left: 0.5em;
	margin-top: 0.5em;
	width: 100%;
}

.formSection .entryForm .form-item:first-of-type label {
	margin-top: 0;
}
.formSection .entryForm input[type=text],
.formSection .entryForm input[type=email],
.formSection .entryForm select,
.formSection .entryForm option {
  border: solid 2px #369fc1;
  border-radius: 10px;
  font-size: 1.8rem;
  padding: 0.5em;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  color: var(--color-Dark);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.formSection .entryForm input[type=text]:focus,
.formSection .entryForm input[type=email]:focus,
.formSection .entryForm select:focus,
.formSection .entryForm option:focus {
  border: solid 2px #e07a7a;
  outline: 0;
}
.formSection .entryForm input[type=text]::-webkit-input-placeholder, .formSection .entryForm input[type=email]::-webkit-input-placeholder, .formSection .entryForm select::-webkit-input-placeholder, .formSection .entryForm option::-webkit-input-placeholder {
  opacity: 0.5;
}
.formSection .entryForm input[type=text]::-moz-placeholder, .formSection .entryForm input[type=email]::-moz-placeholder, .formSection .entryForm select::-moz-placeholder, .formSection .entryForm option::-moz-placeholder {
  opacity: 0.5;
}
.formSection .entryForm input[type=text]:-ms-input-placeholder, .formSection .entryForm input[type=email]:-ms-input-placeholder, .formSection .entryForm select:-ms-input-placeholder, .formSection .entryForm option:-ms-input-placeholder {
  opacity: 0.5;
}
.formSection .entryForm input[type=text]::-ms-input-placeholder, .formSection .entryForm input[type=email]::-ms-input-placeholder, .formSection .entryForm select::-ms-input-placeholder, .formSection .entryForm option::-ms-input-placeholder {
  opacity: 0.5;
}
.formSection .entryForm input[type=text]::placeholder,
.formSection .entryForm input[type=email]::placeholder,
.formSection .entryForm select::placeholder,
.formSection .entryForm option::placeholder {
	opacity: 0.5;
}
.formSection .entryForm select,
.formSection .entryForm option {
	color: #554848;
	-webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
}

.submitWrap {
	margin-top: 6rem;
	width: 100%;
}

.formSection .entryForm .comBtn,.backBtn {
	width: 90%;
	max-width: 320px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
		-ms-flex-pack: center;
			justify-content: center;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
	background-color: var(--color-btnOrangeBg);
	border: solid 2px var(--color-btnOrangeBorder);
	border-radius: 999px;
	color: var(--color-btnOrangeText);
	-webkit-transform: rotate(0.07deg);
			transform: rotate(0.07deg);
	font-weight: 700;
	-webkit-font-smoothing: subpixel-antialiased;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 0.7142857143;
	letter-spacing: 0.02em;
	padding: 1em;
	margin-right: auto;
	margin-left: auto;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	-webkit-transform: translateZ(0);
			transform: translateZ(0);
	-webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
			box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	cursor: pointer;
}
.formSection .entryForm .comBtn:hover,.backBtn:hover {
	-webkit-animation-name: wobble-horizontal;
			animation-name: wobble-horizontal;
	-webkit-animation-duration: 0.5s;
			animation-duration: 0.5s;
	-webkit-animation-timing-function: ease-in-out;
			animation-timing-function: ease-in-out;
	-webkit-animation-iteration-count: 1;
			animation-iteration-count: 1;
	opacity: 1;
}
@media (max-width: 480px) {
	.formSection .entryForm .comBtn,.backBtn {
		font-size: 5vw;
	}
}
.formSection .entryForm .comBtn:disabled {
	background-color: var(--color-Gray);
	border: solid 2px var(--color-Gray);
	pointer-events: none;
}
.formSection .entryForm #btn_cancel,.backBtn {
	background-color: var(--color-LightGrayB3);
	border: solid 2px var(--color-LightGrayB3);
}

.formSection .entryForm .form_hint a {
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1.5;
	letter-spacing: 0em;
	color: #e07a7a;
	text-decoration: underline;
}
.formSection .entryForm__sex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 2rem;
     -moz-column-gap: 2rem;
          column-gap: 2rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.formSection .entryForm__sex label {
	margin-top: 0;
	margin-bottom: 0;
	font-size: 1.8rem;
	padding: 0.5em;
	padding-bottom: 0;
}
.formSection .entryForm .comRadio,
.formSection .entryForm .comCheck {
	display: none;
}
.formSection .entryForm label.comCheckLabel,
.formSection .entryForm label.comRadioLabel {
	cursor: pointer;
}
.formSection .entryForm label.comCheckLabel > span,
.formSection .entryForm label.comRadioLabel > span {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
}

.formSection .entryForm .comCheck + .comCheckLabel > span:before,
.formSection .entryForm .comRadio + .comRadioLabel > span:before {
	content: "";
	background: #f4f4f4;
	border: 1px solid #b4b4b4;
	display: inline-block;
	margin-right: 1em;
	position: relative;
	vertical-align: top;
	text-align: center;
	-webkit-transition: all 250ms ease;
	transition: all 250ms ease;
}

.formSection .entryForm .comRadio + .comRadioLabel > span:before {
	border-radius: 100%;
	width: 1.4em;
	height: 1.4em;
}
.formSection .entryForm .comRadio:checked + .comRadioLabel > span:before {
	background-color: #369fc1;
	-webkit-box-shadow: inset 0 0 0 4px #f4f4f4;
          box-shadow: inset 0 0 0 4px #f4f4f4;
}
.formSection .entryForm .comRadio:focus + .comRadioLabel > span:before {
	outline: none;
	border-color: #369fc1;
}
.formSection .entryForm .comRadio:disabled + .comRadioLabel > span:before {
	-webkit-box-shadow: inset 0 0 0 4px #f4f4f4;
	box-shadow: inset 0 0 0 4px #f4f4f4;
	border-color: #b4b4b4;
	background: #b4b4b4;
}
.formSection .entryForm .comRadio + .comRadioLabel > span:empty:before {
	margin-right: 0;
}
.formSection .entryForm__whatslike {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.formSection .entryForm__whatslike input {
	width: 100%;
	margin-bottom: 1rem;
}
.formSection .entryForm .comCheck + .comCheckLabel > span:before {
	width: 1em;
	height: 1em;
}
.formSection .entryForm .comCheck:checked + .comCheckLabel > span:before {
	background-color: var(--color-Orange);
	-webkit-box-shadow: inset 0 0 0 2px #f4f4f4;
	box-shadow: inset 0 0 0 2px #f4f4f4;
}
.formSection .entryForm .comCheck:focus + .comCheckLabel > span:before {
	outline: none;
	border-color: var(--color-Orange);
}
.formSection .entryForm .comCheck:disabled + .comCheckLabel > span:before {
	-webkit-box-shadow: inset 0 0 0 4px #f4f4f4;
	box-shadow: inset 0 0 0 4px #f4f4f4;
	border-color: #b4b4b4;
	background: #b4b4b4;
}
.formSection .entryForm .comCheck + .comCheckLabel .comCheckLabel > span:empty:before {
	margin-right: 0;
}
.formSection .entryForm .terms {
  color: #554848;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: 0em;
  height: 200px;
  overflow-y: scroll;
  margin: 2rem 0 3rem;
  -webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
  background-color: #f5f5f5;
  border-radius: 5px;
  padding: 1rem;
}
.formSection .entryForm .terms h2,
.formSection .entryForm .terms h3 {
  font-size: 14px;
  margin-bottom: 0.5rem;
  color: #554848;
  -webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
}
.formSection .entryForm .agree {
  line-height: 1em;
  -webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
}
.formSection .entryForm .agree label {
	font-size: 1.5rem;
	color: #554848;
}
.formSection .entryForm .agree a {
	color: #554848;
	text-decoration: underline;
}
.formSection .entryForm .agree a:hover {
	opacity: 1;
}
.formSection .entryForm .error-message {
  background-color: #e12350;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: 0em;
  -webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
  padding: 4px;
  display: none;
  width: 100%;
  margin-top: 1rem;
}
.formSection .entryForm .error-message.-show {
	display: block;
}
.formSection__forgetId {
  border: solid 4px var(--color-Orange);
  border-radius: 32px;
  background-color: var(--color-White);
  width: 100%;
  max-width: 840px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  margin-top: 48px;
  padding-bottom: 7.2rem;
}
@media (max-width: 768px) {
  .formSection__forgetId {
    border: none;
    padding-bottom: 4rem;
  }
}
.formSection__forgetId--inner {
	padding: 0 3rem;
}
@media (max-width: 768px) {
	.formSection__forgetId--inner {
		padding: 0 1rem;
	}
}
.formSection__forgetId > h2 {
  position: relative;
  background: url(../img/ttl-bg_01.png) no-repeat center center;
  background-size: contain;
  color: var(--color-White);
  width: calc(100% + 8px);
  height: 64px;
  margin-top: -10px;
  margin-left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (max-width: 768px) {
  .formSection__forgetId > h2 {
    font-size: 4.5vw;
    background: url(../img/ttl-bg-sp_01.png) no-repeat center center;
    background-size: contain;
    width: 100%;
    height: auto;
    padding: 1em 0.5em;
  }
}
.formSection__forgetId .desc {
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0em;
	color: #554848;
	padding: 4rem 1rem;
}
@media (max-width: 768px) {
	.formSection__forgetId .desc {
		font-size: 4vw;
	}
}
.formSection__forgetId .desc small {
  font-size: 0.7em;
}
.formSection__forgetId .desc small a {
  color: #554848;
}
.formSection .goblin-item:nth-child(1) {
	top: 20%;
}
.formSection .goblin-item:nth-child(2) {
	top: 50%;
}
.formSection .goblin-item:nth-child(3) {
	bottom: 20%;
}

.forgetIdModal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  background: rgba(255, 255, 255, 0.8);
  z-index: 700;
  display: none;
}
.forgetIdModal__inner {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.6rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: var(--color-White);
  border: solid 10px var(--color-SectionA_Border);
  border-radius: 40px;
  padding: 3.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
}
@media (max-width: 1280px) {
  .forgetIdModal__inner {
    width: 95%;
  }
}
.forgetIdModal__inner .title {
  color: var(--color-Orange);
  text-align: center;
}
.forgetIdModal__inner .platform {
  display: none;
}
.forgetIdModal__inner .platform p {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  color: #554848;
}
.forgetIdModal__inner .desc {
  display: none;
}
.forgetIdModal__inner .desc p {
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  color: #554848;
}
.forgetIdModal .closeBtn {
  position: absolute;
  width: 4vw;
  height: 4vw;
  top: 1rem;
  right: 1rem;
  background: #ef5324;
  border-radius: 999px;
  border: solid 2px #d83f11;
  z-index: 600;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
@media (max-width: 768px) {
  .forgetIdModal .closeBtn {
    width: 8vw;
    height: 8vw;
  }
}
.forgetIdModal .closeBtn:hover {
  opacity: 1;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
}
.forgetIdModal .closeBtn.open {
  background: var(--color-White);
}
.forgetIdModal .closeBtn span {
  display: block;
  width: calc(4vw - 60%);
  top: 30%;
  left: calc(30% - 2px);
  position: absolute;
  height: 0.32vw;
  background: var(--color-White);
  right: 0;
  border-radius: 999px;
  -webkit-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
}
@media (max-width: 768px) {
  .forgetIdModal .closeBtn span {
    width: calc(8vw - 60%);
  }
}
.forgetIdModal .closeBtn span:nth-of-type(2) {
  top: calc(1.84vw - 2px);
}
@media (max-width: 768px) {
  .forgetIdModal .closeBtn span:nth-of-type(2) {
    top: calc(3.84vw - 2px);
  }
}
.forgetIdModal .closeBtn span:nth-of-type(3) {
  top: auto;
  bottom: 30%;
}
.forgetIdModal .closeBtn.open span {
  background: #ef5324;
}
.forgetIdModal .closeBtn.open span:nth-of-type(1) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.forgetIdModal .closeBtn.open span:nth-of-type(2) {
  width: 0;
}
.forgetIdModal .closeBtn.open span:nth-of-type(3) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}

/*==================================================================
// download
//================================================================*/
.downloadSection {
	position: relative;
	width: 100%;
	padding: 0 0 2rem;
	background-color: var(--color-White);
	z-index: 20;
}
@media (max-width: 768px) {
	.downloadSection {
		padding: 0 0 4rem;
	}
}
.downloadSection__title {
	position: relative;
	width: 100%;
	background: url(../img/texture_03.png) repeat;
	z-index: 10;
}
@media (max-width: 768px) {
	.downloadSection__title .sectionInner {
		width: 100%;
		padding: 0;
	}
}
.downloadSection__title picture {
	width: 100%;
	max-width: 1200px;
	position: relative;
}
.downloadSection__desc {
  position: relative;
  width: 100%;
  padding: 3rem 0 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  z-index: 10;
}
@media (max-width: 768px) {
  .downloadSection__desc {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 5rem 0;
  }
}
.downloadSection__desc p {
  width: 100%;
  height: 100%;
  -webkit-transform: rotate(0.07deg);
          transform: rotate(0.07deg);
  font-weight: 700;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 32px;
  font-size: 3.2rem;
  line-height: 1.5625;
  letter-spacing: 0em;
  color: var(--color-Orange);
}
@media (max-width: 768px) {
  .downloadSection__desc p {
    font-size: 4.5vw;
    width: 100%;
  }
}
.downloadSection__img {
  position: relative;
  width: 100%;
  padding: 3rem 0 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 10;
}
@media (max-width: 768px) {
  .downloadSection__img {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 0 4rem;
  }
}
.downloadSection__img .item {
  width: 30%;
  background: var(--color-SectionA_Border);
  border: solid 10px var(--color-Primary);
  border-radius: 40px;
  padding: 3.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  gap: 24px;
}
@media (max-width: 1024px) {
	.downloadSection__img .item {
		width: 48%;
	}
}
@media (max-width: 768px) {
	.downloadSection__img .item {
		width: 100%;
	}
}
.downloadSection__img .item picture {
	width: 100%;
}
.downloadSection__img .item picture img,
.downloadSection__img .item picture source {
	margin-right: auto;
	margin-left: auto;
}
.downloadSection__img .item .c-btn {
	width: 100%;
}
.downloadSection__img .item .c-btn i {
  background: var(--color-White);
  position: absolute;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 3rem;
}
.downloadSection .goblin-item:nth-child(1) {
	top: 30%;
}
.downloadSection .goblin-item:nth-child(2) {
	bottom: 20%;
}

/*==================================================================
// playGameModal
//================================================================*/
.playGameModal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 1rem;
	margin: 0;
	background: rgba(255, 255, 255, 0.8);
	z-index: 700;
	display: none;
	overflow-y: scroll;
}
.playGameModal__inner {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.6rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: var(--color-White);
  border: solid 10px var(--color-SectionA_Border);
  border-radius: 40px;
  padding: 3.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
}
@media (max-width: 1280px) {
	.playGameModal__inner {
		width: 95%;
	}
}
@media (max-width: 768px) {
  .playGameModal__inner {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 90%;
    top: 0;
  }
}
.playGameModal__inner .title {
	color: var(--color-Orange);
	text-align: center;
}
.playGameModal .closeBtn {
  position: absolute;
  width: 4vw;
  height: 4vw;
  top: 1rem;
  right: 1rem;
  background: #ef5324;
  border-radius: 999px;
  border: solid 2px #d83f11;
  z-index: 600;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
@media (max-width: 768px) {
  .playGameModal .closeBtn {
    width: 8vw;
    height: 8vw;
  }
}
.playGameModal .closeBtn:hover {
  opacity: 1;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
}
.playGameModal .closeBtn.open {
	background: var(--color-White);
}
.playGameModal .closeBtn span {
  display: block;
  width: calc(4vw - 60%);
  top: 30%;
  left: calc(30% - 2px);
  position: absolute;
  height: 0.32vw;
  background: var(--color-White);
  right: 0;
  border-radius: 999px;
  -webkit-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
}
@media (max-width: 768px) {
	.playGameModal .closeBtn span {
		width: calc(8vw - 60%);
	}
}
.playGameModal .closeBtn span:nth-of-type(2) {
	top: calc(1.84vw - 2px);
}
@media (max-width: 768px) {
	.playGameModal .closeBtn span:nth-of-type(2) {
		top: calc(3.84vw - 2px);
	}
}
.playGameModal .closeBtn span:nth-of-type(3) {
	top: auto;
	bottom: 30%;
}
.playGameModal .closeBtn.open span {
	background: #ef5324;
}
.playGameModal .closeBtn.open span:nth-of-type(1) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.playGameModal .closeBtn.open span:nth-of-type(2) {
	width: 0;
}
.playGameModal .closeBtn.open span:nth-of-type(3) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}

/* ==========================================================================
	04_Utility
	========================================================================== */
/*==================================================================
// Utility
//================================================================*/
.pc {
	display: block;
}
@media (max-width: 1280px) {
	.pc {
		display: none;
	}
}

.is-pc {
	display: none;
}
@media (max-width: 1280px) {
	.is-pc {
		display: block;
	}
}

.tab {
	display: block;
}
@media (max-width: 1024px) {
	.tab {
		display: none;
	}
}

.is-tab {
	display: none;
}
@media (max-width: 1024px) {
	.is-tab {
		display: block;
	}
}

.sp {
	display: block;
}
@media (max-width: 768px) {
	.sp {
		display: none;
	}
}

.is-sp {
	display: none;
}
@media (max-width: 768px) {
	.is-sp {
		display: block;
	}
}

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

.block {
	display: block;
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.f--jcc {
	justify-content: center;
}
.f--jic {
	justify-items: center;
}
.f--acc {
	align-content: center;
}
.f--acsa {
	align-content: space-around;
}
.f--acsb {
	align-content: space-between;
}
.f--aic {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.f--wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.f--column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.w--50p {
	width: 50%;
}
.w--100p {
	width: 100%;
}
.w--100v {
	width: 100vw;
}

.h--50p {
	height: 50%;
}
.h--100p {
	height: 100%;
}
.h--100v {
	height: 100vh;
}

.p--1r {
	padding: 1rem;
}
.p--2r {
	padding: 2rem;
}
.p--3r {
	padding: 3rem;
}
.p--t1r {
	padding-top: 1rem;
}
.p--t3r {
	padding-top: 3rem;
}
.p--t5r {
	padding-top: 5rem;
}
.p--b1r {
	padding-bottom: 1rem;
}
.p--b3r {
	padding-bottom: 3rem;
}
.p--b5r {
	padding-bottom: 5rem;
}
.p--lr1r {
	padding-left: 1rem;
	padding-right: 1rem;
}
.p--lr2r {
	padding-left: 2rem;
	padding-right: 2rem;
}
.p--tb5r {
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.m--1r {
	margin: 1rem;
}
.m--2r {
	margin: 2rem;
}
.m--t1r {
	margin-top: 1rem;
}
.m--t3r {
	margin-top: 3rem;
}
.m--t5r {
	margin-top: 5rem;
}
.m--b1r {
	margin-bottom: 1rem;
}
.m--b3r {
	margin-bottom: 3rem;
}
.m--b5r {
	margin-bottom: 5rem;
}
.m--lra {
	margin-left: auto;
	margin-right: auto;
}

.pos--abs {
	position: absolute;
}
.pos--rel {
	position: relative;
}
.pos--fix {
	position: fixed;
}

.auto {
	margin: auto;
}

.tac {
	text-align: center;
}

.tal {
	text-align: left;
}

.tar {
	text-align: right;
}

.bold {
	font-weight: bold;
}

.c-White {
	color: var(--color-White);
}

.c-BaseWhite {
	color: var(--color-BaseWhite);
}

.c-LightGray {
	color: var(--color-LightGray);
}

.c-Gray {
	color: var(--color-Gray);
}

.c-Dark {
	color: var(--color-Dark);
}

.c-Black {
	color: var(--color-Black);
}

.c-RichBlack {
	color: var(--color-RichBlack);
}

.c-Orange {
	color: var(--color-Orange);
}

.c-Primary {
	color: var(--color-Primary);
}

.c-PrimaryDark {
	color: var(--color-PrimaryDark);
}

.c-PrimaryGrad1 {
	color: var(--color-PrimaryGrad1);
}

.c-PrimaryGrad2 {
	color: var(--color-PrimaryGrad2);
}

.c-Secondary {
	color: var(--color-Secondary);
}

.c-SecondaryLight {
	color: var(--color-SecondaryLight);
}

.c-SecondaryGrad {
	color: var(--color-SecondaryGrad);
}

.c-SectionA_Border {
	color: var(--color-SectionA_Border);
}

.c-SectionB_Border {
	color: var(--color-SectionB_Border);
}

.c-TextDefault {
	color: var(--color-TextDefault);
}

.c-TextTitle {
	color: var(--color-TextTitle);
}

.c-Link {
	color: var(--color-Link);
}

.c-LinkVisited {
	color: var(--color-LinkVisited);
}

.c-LinkHover {
	color: var(--color-LinkHover);
}

.c-LinkActive {
	color: var(--color-LinkActive);
}

.c-Bg {
	color: var(--color-Bg);
}

.c-ScrollBg {
	color: var(--color-ScrollBg);
}

.c-ScrollColor {
	color: var(--color-ScrollColor);
}

.c-btnPraGrad {
	color: var(--color-btnPraGrad);
}

.c-btnOcherBg {
	color: var(--color-btnOcherBg);
}

.c-btnOcherBorder {
	color: var(--color-btnOcherBorder);
}

.c-btnOcherText {
	color: var(--color-btnOcherText);
}

.c-btnTwitterBg {
	color: var(--color-btnTwitterBg);
}

.c-btnTwitterBorder {
	color: var(--color-btnTwitterBorder);
}

.c-btnTwitterText {
	color: var(--color-btnTwitterText);
}

.c-btnTurquoiseBg {
	color: var(--color-btnTurquoiseBg);
}

.c-btnTurquoiseBorder {
	color: var(--color-btnTurquoiseBorder);
}

.c-btnTurquoiseText {
	color: var(--color-btnTurquoiseText);
}

.c-btnOrangeBg {
	color: var(--color-btnOrangeBg);
}

.c-btnOrangeBorder {
	color: var(--color-btnOrangeBorder);
}

.c-btnOrangeText {
	color: var(--color-btnOrangeText);
}

.c-SidebarText {
	color: var(--color-SidebarText);
}

.c-SidebarHr {
	color: var(--color-SidebarHr);
}

.c-Facebook {
	color: var(--color-Facebook);
}

.c-Twitter {
	color: var(--color-Twitter);
}

.c-Line {
	color: var(--color-Line);
}

.c-LoadingBg {
	color: var(--color-LoadingBg);
}

.l--1e {
	line-height: 1em;
}
.l--1-5e {
	line-height: 1.5em;
}
.l--2e {
	line-height: 2em;
}
.l--2-5e {
	line-height: 2.5em;
}
.l--3e {
	line-height: 3em;
}

.highlight {
	background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(0%, #ffff66));
  background: linear-gradient(transparent 50%, #ffff66 0%);
  line-height: 1.3em;
}

.confirm_area {
	font-size: 1.8rem;
	font-weight: 700;
	padding: 5px 0 0 20px;
	word-break: break-all;
}
.confirm_area:empty {
	padding: 0;
	margin-top: 0;
}

.confirm_area span {
	display: inline-block;
	width: 100%;
}
.confirm_area span:not(:last-of-type) {
	margin-bottom: 10px;
}

.thanksErrP {
	color: #554848;
	font-size: 20px;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0em;
	width: 100%;
}
.thanksErrP a {
	color: #369fc1;
}

.apology__container {
	margin-bottom: 5rem;
	position: relative;
	text-align: center;
	z-index: 10;
}

.apology__container .ctaSection__h2 {
	margin-bottom: 56px;
}

.apology__container p {
	font-weight: 700;
	-webkit-font-smoothing: subpixel-antialiased;
	font-size: 2px;
	font-size: 2rem;
	line-height: 1.7142857143;
	letter-spacing: 0.1em;
	color: #554848;
}

@media (max-width: 768px) {
	.apology__container {
		margin-bottom: 3rem;
	}
	.apology__container .ctaSection__h2 {
		margin-bottom: 24px;
	}
	.apology__container p {
		font-size: 3vw;
	}
}