@charset "utf-8";
body,div,dl,dt,dd,ul,ol,li,p,h1,h2,h3,h4,h5,h6,th,td,pre,code,blockquote,form,fieldset,legend,input,textarea,figcaption,figure{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:normal}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit}input,textarea,select{font-size:100%}legend{color:#FFF}hr{display:none}img{vertical-align:bottom}select,input,button,textarea{font-size:99%}table{font-size:inherit;font:100%;border-collapse:collapse;border-spacing:0}pre,code,kbd,samp,tt{font-family:monospace;font-size:108%;line-height:100%}.hd{display:block;width:0;height:0;overflow:hidden}.cf:before,.cf:after{content:"";display:table}.cf:after{clear:both}.cf{zoom:1}article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section,main{display:block}*{margin:0;padding:0;box-sizing:border-box;max-height:999999px;outline:none;}*:focus{outline: none;}button{background-color:transparent;border:none;cursor:pointer;outline:none;padding:0;}
/*-----------------------------------------------
 * Bace
 * Modal
 * Header
 * Parts
-------------------------------------------------*/
/*-----------------------------------------------
 * Bace
-------------------------------------------------*/
:root{
	/* color */
	--color-black: #222;
	--color-orange: #ff6400;
	--color-blue: #00a0ff;
	--color-yellow: #ffef66;

	/* charaColor */
	--color-chara-satsuki: #fcc802;
	--color-chara-an: #ea464d;
	--color-chara-sakurako: #d9b4d5;
	--color-chara-haruno: #d9e1e4;
	--color-chara-haruno_lightdark: #b0b7ba;
	--color-chara-kako: #268fd0;

	
	/* default */
	--vw-min: 1200;
	--vh-min: 640;
	--max-percent: 1;/* WindowMaxWidth -> 1920 */


	/* font */
	--font-ja: fot-udmarugo-large-pr6n, sans-serif;
	--font-tegaki: ta-oonishi, sans-serif;
	--font-en: mostra-nuova, sans-serif;

	/* sp-size */
	--sp-size-2: clamp(1px, 0.2667vw, 2px);
	--sp-size-4: min(0.5334vw, 4px);
	--sp-size-8: min(1.0667vw, 8px);
	--sp-size-10: min(1.3334vw, 10px);
	--sp-size-12: min(1.6vw, 12px);
	--sp-size-16: min(2.1334vw, 16px);
	--sp-size-20: min(2.6667vw, 20px);
	--sp-size-24: min(3.2vw, 24px);
	--sp-size-26: min(3.4667vw, 26px);
	--sp-size-28: min(3.7334vw, 28px);
	--sp-size-30: min(4vw, 30px);
	--sp-size-32: min(4.2667vw, 32px);
	--sp-size-36: min(4.8vw, 36px);
	--sp-size-40: min(5.3334vw, 40px);
	--sp-size-48: min(6.4vw, 48px);
	--sp-size-56: min(7.4667vw, 56px);
	--sp-size-64: min(8.5334vw, 64px);
	--sp-size-72: min(9.6vw, 72px);
	--sp-size-80: min(10.6667vw, 80px);
	--sp-size-96: min(12.8vw, 96px);
	--sp-size-192: min(25.6vw, 192px);
}
@media screen and (max-width: 768px){
	:root{
		/* default */
		--vw-min: 750;
		--vh-min: 1296;
	}
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 100;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 200;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 300;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 400;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Bold");
	font-weight: bold;
}
body{
	-webkit-text-size-adjust: 100%;
	background-color: #fff;
	color: var(--color-black);
	font-family: fot-udmarugo-large-pr6n, "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
	font-size: 16px;
	font-weight: normal;
	letter-spacing: 0.07em;
	line-height: 1.8;
	word-wrap: break-word;
}
.pc{ display: block; }
.sp{ display: none; }
a{ color: #222; }
a:hover{ text-decoration: none; }
.ah { transition: opacity .3s ease; }
.ah:hover { opacity: .7; }
::selection{
	background: #6ccfee;
	color: #fff;
}
::-moz-selection{
	background: #6ccfee;
	color:#fff;
}
@media screen and (max-width:768px){ 
	html{ 
		font-size: 62.5%;
	}
	body{
		font-size: 10px; 
		font-size: 1rem;
		font-size: var(--sp-size-24);
		min-width: 320px;
	}
	.sp{ display: block; }
	.pc{ display: none; }
	.ah:hover { opacity: 1; }
}

/* ScrollBar Setting */
::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}
::-webkit-scrollbar-track {
  border-radius: 0px;
  background: rgb(250, 255, 255);
}
::-webkit-scrollbar-thumb {
	background: #222;
	border-radius: 4px;
	margin: 2px;
	box-shadow: none;
}
/* firefox Only Scrollbar */
@-moz-document url-prefix() {
	html{
		scrollbar-color: #222 rgb(255, 255, 255);
		scrollbar-width: thin;
	}
}


/*-----------------------------------------------
 * Modal
-------------------------------------------------*/

/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox{
	-webkit-overflow-scrolling: touch;
	background: url(../img/common/visual_bg.jpg) no-repeat center / cover;
	display: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
@supports (background-image: url(../img/common/visual_bg.webp)){
	.modalBox{
		background-image:url(../img/common/visual_bg.webp);
	}
}
.modalBox:before{
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,85%);
	-webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}
.oneModal{
	display: none;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 1;
}

/* oneModalIn */
.oneModalIn{
	display: flex;
	justify-content: center;
	align-items: center;
	height: auto;
	width: 100%;
	min-width: 100%;
	min-height: 100%;
	margin: 0 auto;
	position: relative;
}
.oneModalIn__cont{
	padding: 50px 0;
}
@media screen and (max-width: 768px){
	.modalBox{
		background-image:url(../img/common/visual_bg-s.jpg);
	}
	@supports (background-image: url(../img/common/visual_bg-s.webp)){
		.modalBox{
			background-image:url(../img/common/visual_bg-s.webp);
		}
	}
	.oneModalIn{
		min-width: 100%;
	}
	.oneModalIn__cont{
		width: 100%;
		padding: 30px 0;
	}
}

/**
 * closeBtn
 */
.modalCloseBtn{
	width: min(calc(80 / var(--vw-min) * 100vw), min(calc(80 / var(--vh-min) * 100vh), calc(80px * var(--max-percent))));
	height: min(calc(80 / var(--vw-min) * 100vw), min(calc(80 / var(--vh-min) * 100vh), calc(80px * var(--max-percent))));;
	position: absolute;
	top: 0;
	right: 0;
	margin-top: min(calc(40 / var(--vw-min) * 100vw), min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	margin-right: min(calc(40 / var(--vw-min) * 100vw), min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	z-index: 2;
}
.modalClose{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	background-color: #FFF;
	position: relative;
	border-radius: 50%;
	overflow: hidden;
	pointer-events: auto;
}
.modalClose:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	border: 1px solid rgba(34, 34, 34, 40%);
	width: 90%;
	height: 90%;
	border-radius: 50%;
}
.modalClose__lines{
	width: 40%;/* 32 */
	height: 20%;/* 16 */
	position: relative;
	z-index: 2;
}
.modalClose__lines > span{
	background-color: var(--color-black);
	display: block;
	width: 100%;
	height: 12.5%;
	margin: auto;
	position: absolute;
	top: 43.75%;
	bottom: 43.75%;
	transition: .4s ease, transform .4s ease;
}
.modalClose__lines > span:nth-child(1){
	transform: rotate(45deg);
}
.modalClose__lines > span:nth-child(2){
	transform: rotate(-45deg);
}
@media screen and (hover:hover) and (pointer: fine){
	.modalClose::after{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		transform: scale(50%);
		background-color: var(--color-black);
		opacity: 0%;
		border-radius: 50%;
		transition: .4s ease;
	}
	.modalClose:hover::after{
		transform: scale(100%);
		opacity: 18%;
	}
}

@media screen and (max-width:768px){
	.modalCloseBtn{
		width: calc(96 / var(--vw-min) * 100vw);
		height: calc(96 / var(--vw-min) * 100vw);
		margin-top: calc(24 / var(--vw-min)* 100vw);
		margin-right: calc(24 / var(--vw-min)* 100vw);
	}
	.modalClose:before{
		width: 89.5834%;
		height: 89.5834%;
		border-width: var(--sp-size-2);
	}
	.modalClose__lines{
		width: 41.6667%;/* 40 */
		height: 20.8334%;/* 20 */
	}
	.modalClose__lines > span{
		height: 20%;/* 4 */
		top: 40%;
		bottom: 40%;
	}
}



/**
 * iframe
 */
/* common */
.commonIframe{
	width: 100%;
	height: 100%;
	display: block;
}

/* youtube */
.youtubeIframeWrap {
	width: 70%;
	max-width: 159.993vh;
	position: relative;
}
@media screen and (max-width: 768px){
	.youtubeIframeWrap {
		width: 100%;
		max-width: 100%;
	}
}
.youtubeIframeWrap:before{
	content: "";
	display: block;
	padding-top: 56.25%;
	z-index: 0;
}
.youtubeIframe{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.modalBox[data-option="-ytShort"] .youtubeIframeWrap,
.youtubeIframeWrap[data-type="short"]{
	max-width: calc(56.25vh - 80px);
}
.modalBox[data-option="-ytShort"] .youtubeIframeWrap:before,
.youtubeIframeWrap[data-type="short"]:before{
	padding-top: 177.7778%;
}


/*-----------------------------------------------
 * Header
-------------------------------------------------*/
.header {
	width: 100%;
	position: fixed;
	top: 0;
	bottom: 0;
	z-index: 999;
	pointer-events: none;
}

/* inner */
.header__inner {
	-webkit-overflow-scrolling: touch;
	width: 100%;
	min-height: 100vh;
	/* min-height: 100dvh; */
	overflow: auto;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	opacity: 0;
	pointer-events: none;
	z-index: 1;
	transition: opacity .5s ease-in-out;
	overflow: auto;
	overscroll-behavior: contain;
}
.header.is-active .header__inner {
	opacity: 1;
	pointer-events: auto;
}

.header__inner:before {
	content: "";
	background: rgba(0,0,0,.8);
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 0;
}

.header__innerCont{
	position: relative;
	z-index: 2;
	width: 100%;
	/* height: 100%; */
	min-height: 100vh;
}
.header.is-active .header__innerCont .comLogo{
	z-index: 2;
	opacity: 1;
	transform: scale(100%);
}
.header:not(.is-active) .header__innerCont .comLogo > .comLogo__link{
	pointer-events: none;
}


/**
 * headerNav
 */
.headerNavWrap{
	width: 50%;
	height: 100%;
	position: relative;
	margin-left: auto;
	z-index: 2;
	overflow: hidden;
}
.headerNavInWrap{
	width: 100%;
	min-height: 100vh;
	padding: 10.6667% 6.6667% 6.6667%;/* 64 40 */
	position: relative;
	display: flex;
	flex-direction: column;
	background-color: rgba(255,255,255,24%);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	font-size: min(calc(32 / var(--vw-min) * 100vw), calc(32px * var(--max-percent)));
	transform: translateX(100%);
	transition: transform .3s cubic-bezier(.54,.32,.46,1.03);
}
header.is-active.is-ani .headerNavInWrap{
	transform: translateX(0%);
}
.headerNavInWrap:before{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 1px;
	background-color: #fff;
}
.headerNav {
	position: relative;
	z-index: 1;
	line-height: 0.9;
}
.headerNav .navList:not(:last-child){
	margin-bottom: 0.75em;/* 24 */
}

.headerNav .navList{
	opacity: 0;
	transform: translateY(50%);
	transition: opacity .3s ease, transform .3s ease;
}
header.is-active.is-ani .headerNav .navList{
	opacity: 1;
	transform: translateY(0%);
}
header.is-active.is-ani .headerNav .navList:nth-of-type(1){
	transition-delay: .3s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(2){
	transition-delay: .35s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(3){
	transition-delay: .4s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(4){
	transition-delay: .45s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(5){
	transition-delay: .5s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(6){
	transition-delay: .55s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(7){
	transition-delay: .6s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(8){
	transition-delay: .65s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(9){
	transition-delay: .7s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(10){
	transition-delay: .75s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(11){
	transition-delay: .8s;
}
header.is-active.is-ani .headerNav .navList:nth-of-type(12){
	transition-delay: .85s;
}


.navList__link{
	display: inline-block;
	font-family: var(--font-en);
	font-weight: 700;
	text-decoration: none;
	line-height: 0.8;
	letter-spacing: 0;
	color: #FFF;
	transition: color .3s ease;
}
.navList__link span{
	background: linear-gradient(var(--color-yellow), var(--color-yellow)) right bottom / 0 40% no-repeat;
	transition: background-size 0.4s;
}

@media screen and (hover:hover) and (pointer: fine){
	.navList__link:hover {
		color: var(--color-black);
	}
	.navList__link:hover span{
		background-size: 100% 40%;
		background-position: left bottom;
	}
}

/* navActive */
.navList__link.is-active{
	color: var(--color-black);
}
.navList__link.is-active span{
	background-size: 100% 40%;
	background-position: left bottom;
}


.snsLists{
	margin-top: auto;
	margin-left: auto;
	display: flex;
	align-items: center;
	position: relative;
}
.snsList__dt{
	font-family: var(--font-en);
	font-size: 16px;
	font-size: 0.5em;
	line-height: 0.8;
	color: #FFF;
	padding-right: 12px;
	padding-right: 0.375em;
}
.snsList__dd{
	padding: 0 12px;
	width: 48px;
	height: 24px;
	padding: 0 0.375em;
	width: 1.5em;
	height: 1.3334em;
}
.snsList__link{
	width: 100%;
	height: 100%;
	position: relative;
	display: block;
}
.snsList__link:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	background-color: #fff;
}
.snsList__link.-x:before{
	-webkit-mask-image: url(../img/common/icon_tw.svg);
	mask-image: url(../img/common/icon_tw.svg);
}
.snsList__link.-insta:before{
	-webkit-mask-image: url(../img/common/icon_insta.svg);
	mask-image: url(../img/common/icon_insta.svg);
}

@media screen and (hover:hover) and (pointer: fine){
	.snsList__link:before{
		transition: .3s ease;
	}
	.headerNavInWrap .snsList__link:hover::before{
		background-color: var(--color-black);
	}
	.mainNavWrap .snsList__link:before{
		z-index: 2;
	}
	.mainNavWrap .snsList__link:after{
		content: '';
		position: absolute;
		top: 0;
		left: -12.5%;
		right: -12.5%;
		bottom: -25%;
		background: linear-gradient(var(--color-yellow), var(--color-yellow)) right bottom / 0% 50% no-repeat;
		transition: background-size 0.4s;
	}
	.mainNavWrap .snsList__link:hover::after{
		background-size: 100% 50%;
        background-position: left bottom;
	}
}

@media screen and (max-width:768px){
	.headerNavWrap{
		width: 53.3334%;/* 400 */
	}
	.headerNavInWrap{
		padding-top: calc(168 / var(--vw-min) * 100vw);
		padding-left: calc(48 / var(--vw-min) * 100vw);
		padding-right: calc(48 / var(--vw-min) * 100vw);
		font-size: calc(44 / var(--vw-min) * 100vw);
		min-height: calc(100vh - (118 / var(--vw-min) * 100vw));
		min-height: calc(100dvh - (118 / var(--vw-min) * 100vw));
	}
	.headerNavInWrap:before{
		width: var(--sp-size-2);
	}
	.headerNav .navList:not(:last-child){
		margin-bottom: calc(40 / var(--vw-min) * 100vw);/* 40 */
	}

	.snsLists{
		padding-top: calc(48 / var(--vw-min) * 100vw);
	}

	.snsList__dt{
		font-size: calc(24 / var(--vw-min) * 100vw);
		padding-right: calc(12 / var(--vw-min) * 100vw);
	}
	.snsList__dd{
		width: calc(72 / var(--vw-min) * 100vw);
		height: calc(48 / var(--vw-min) * 100vw);
	}
}



/**
 * headerNews
 */
.headerNewsWrap{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 50%;
}
.headerNewsInWrap{
	position: sticky;
	top: 0;
	width: 100%;
	height: min(100vh, 100%);
	display: flex;
	flex-direction: column;
}
.headerNewsCont{
	margin-top: auto;
	width: 100%;
	display: flex;
	font-size: min(calc(16 / var(--vw-min) * 100vw), calc(16px * var(--max-percent)));
	border-top: 1px solid #FFF;
}
.headerNewsCont__title{
	flex-shrink: 0;
	font-family: var(--font-en);
	font-weight: 700;
	font-size: 1.25em;/* 20 */
	line-height: 0.8;
	padding: 1.5em 1.25em;/* 24 20 */
	background-color: #333;
	color: #FFF;
}
.headerNewsListsSwiper{
	width: 100%;
	background-color: var(--color-black);
}
.headerNewsList{
	width: 100%;
	padding: 1.625em 4em 1.625em 1.25em ;/* 26 64 26 20 */
	display: flex;
	align-items: center;
	position: relative;
}
.headerNewsList:after{
	content: '';
	position: absolute;
	top: 0;
	right: 1.5em;
	bottom: 0;
	width: 1em;
	height: 1em;
	-webkit-mask: url(../img/common/arrow_r.svg) no-repeat center / contain;
	mask: url(../img/common/arrow_r.svg) no-repeat center / contain;
	background-color: #fff;
	margin: auto 0;
}
.headerNews__link{
	display: flex;
	align-items: flex-end;
	text-decoration: none;
	line-height: 1.25;
	color: #FFF;
}
.headerNews__date{
	flex-shrink: 0;
	font-family: var(--font-en);
	font-size: 1em;/* 20 */
	font-weight: 700;
	line-height: 0.8;
	padding-right: 1.25em;/* 20 */
}
.headerNews__title{
	display: -webkit-box;
    -webkit-line-clamp: 1;
	line-clamp: 1;
    -webkit-box-orient: vertical;
	overflow: hidden;
}
@media screen and (hover:hover) and (pointer: fine){
	.headerNewsList{
		pointer-events: none;
	}
	.header.is-active .headerNewsList .headerNews__link{
		pointer-events: auto;
	}
	.headerNewsList:after{
		transition: transform .3s ease;
	}
	.headerNewsList:hover::after{
		transform: translateX(25%);		
	}

	.headerNews__title span{
		background: linear-gradient(rgba(255, 239, 102, 40%), rgba(255, 239, 102, 40%)) right bottom / 0 40% no-repeat;
		transition: background-size .8s;
	}
	.headerNewsList:hover .headerNews__title span{
		background-size: 100% 40%;
		background-position: left bottom;
	}
}

@media screen and (min-width:769px){
	.headerNewsInWrap{
		overflow: hidden;
	}
	.headerNewsCont{
		transform: translateY(100%);
		transition: transform .3s cubic-bezier(.54,.32,.46,1.03);
	}
	header.is-active.is-ani .headerNewsCont{
		transform: translateY(0%);
	}
}

@media screen and (max-width: 767px){
	.headerNewsWrap{
		position: relative;
		top: unset;
		left: unset;
		bottom: unset;
		width: 100%;
	}
	.headerNewsInWrap{
		height: auto;
		position: relative;
		display: block;
	}
	.headerNewsCont{
		border-width: var(--sp-size-2);
		font-size: calc(24 / var(--vw-min) * 100vw);
	}
	.headerNewsCont__title{
		font-size: calc(32 / var(--vw-min) * 100vw);
		line-height: 0.8;
		padding: calc(24 / var(--vw-min) * 100vw);/* 24 */
		display: flex;
		align-items: center;
	}
	.headerNewsList{
		padding: calc(24 / var(--vw-min) * 100vw) calc(72 / var(--vw-min) * 100vw) calc(24 / var(--vw-min) * 100vw) calc(24 / var(--vw-min) * 100vw);
	}
	.headerNewsList:after{
		right: calc(24 / var(--vw-min) * 100vw);
		width: calc(24 / var(--vw-min) * 100vw);
		height: calc(24 / var(--vw-min) * 100vw);
	}
	.headerNews__link{
		display: block;
	}
	.headerNews__date{
		display: block;
		padding-bottom: calc(20 / var(--vw-min) * 100vw);
	}
}



/**
 * headerBg
 */
.headerBg{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.headerBg:before{
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../img/common/visual_bg.jpg) no-repeat center / cover;
}
.headerBg__chara{
	position: absolute;
	opacity: 0;
}
@supports (background-image: url(../img/common/visual_bg.webp)){
	.headerBg:before{
		background-image:url(../img/common/visual_bg.webp);
	}
}
@media screen and (max-width:768px){
	.headerBg{
		position: absolute;
		bottom: calc(120 / var(--vw-min) * 100vw);
		height: auto;
		overflow: hidden;
		background-image: unset;
	}
	.headerBg:before{
		background-image: url(../img/common/visual_bg-s.webp);
	}
	@supports not (background-image: url(../img/common/visual_bg-s.webp)){
		.headerBg:before{
			background-image: url(../img/common/visual_bg-s.jpg);
		}
	}
}

.headerBg:before{
	transform: scale(125%);
	transition: transform .8s ease;
}
.header.is-active .headerBg:before{
	transform: scale(100%);
}


/* chara1 */
.headerBg__chara[data-chara="0"]{
	width: max(calc(676 / var(--vh-min) * 100vh), calc(676 / var(--vw-min) * 100vw));
	height: max(calc(648 / var(--vh-min) * 100vh), calc(648 / var(--vw-min) * 100vw));
	max-width: 100%;
	max-height: 85.2632vh;
	bottom: 0;
	left: 0;
	opacity: 0;
	transform: translateX(-75%);
	transition: transform .5s ease, opacity .5s ease;
}
.header.is-ani .headerBg__chara[data-chara="0"]{
	opacity: 1;
	transform: translateX(0%);
}
.headerBg__chara[data-chara="0"]:before{
	content: '';
	position: absolute;
	bottom: 0;
	left: -15.8285%;
	width: 115.8285%;/* 783 */
	height: 100%;
	background: url(../img/common/deco_chara1.png) no-repeat left bottom / contain;
}
@supports (background-image: url(../img/common/deco_chara1.webp)){
	.headerBg__chara[data-chara="0"]:before{
		background-image:url(../img/common/deco_chara1.webp);
	}
}
@media screen and (max-width:768px){
	.headerBg__chara[data-chara="0"]{
		width: calc(618 / var(--vw-min) * 100vw);
		height: calc(532 / var(--vw-min) * 100vw);
		max-height: unset;
	}
	.headerBg__chara[data-chara="0"]:before{
		width: 126.6991%;/* 783 */
		height: 100%;
		background-image: url(../img/common/deco_chara1-s.png);
		left: -26.9991%;
	}
	@supports (background-image: url(../img/common/deco_chara1-s.webp)){
		.headerBg__chara[data-chara="0"]:before{
			background-image:url(../img/common/deco_chara1-s.webp);
		}
	}
}


/* chara2-3*/
.headerBg__chara[data-chara="1"]{
	width: max(calc(659 / var(--vh-min) * 100vh), calc(659 / var(--vw-min) * 100vw));
	height: max(calc(1012 / var(--vh-min) * 100vh), calc(1012 / var(--vw-min) * 100vw));
	max-width: 100%;
	max-height: 100vh;
	bottom: 0;
	left: 0;
}
.headerBg__chara[data-chara="1"]:before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../img/common/deco_chara2.png) no-repeat left bottom / contain;
	opacity: 0;
	transform: translateY(25%);
	transition: transform .5s ease, opacity .5s ease;
	z-index: 2;
}
@supports (background-image: url(../img/common/deco_chara2.webp)){
	.headerBg__chara[data-chara="1"]:before{
		background-image:url(../img/common/deco_chara2.webp);
	}
}
.headerBg__chara[data-chara="1"]:after{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 134.1427%;/* 884 */
	height: 100%;
	background: url(../img/common/deco_chara3.png) no-repeat left bottom / contain;
	opacity: 0;
	transform: translateX(-75%);
	transition: transform .5s ease, opacity .5s ease;
}
@supports (background-image: url(../img/common/deco_chara3.webp)){
	.headerBg__chara[data-chara="1"]:after{
		background-image:url(../img/common/deco_chara3.webp);
	}
}
.headerBg__chara[data-chara="1"]{
	transition: opacity .3s ease;
}
.header.is-ani .headerBg__chara[data-chara="1"]{
	opacity: 1;
}
.header.is-ani .headerBg__chara[data-chara="1"]:before{
	opacity: 1;
	transform: translateY(0%);
}
.header.is-ani .headerBg__chara[data-chara="1"]:after{
	opacity: 1;
	transform: translateX(0%);
}
@media screen and (max-width:768px){
	.headerBg__chara[data-chara="1"]:before{
		width: calc(683 / var(--vw-min) * 100vw);
		height: calc(930 / var(--vw-min) * 100vw);
	}
	.headerBg__chara[data-chara="1"]:before{
		width: calc(324 / var(--vw-min)* 100vw);
        height: calc(438 / var(--vw-min)* 100vw);
        top: 0;
		left: calc(32 / var(--vw-min) * 100vw);
        margin-top: calc(120 / var(--vw-min)* 100vw);
		background: url(../img/common/deco_chara2-s.png) no-repeat left 40% / contain;
	}
	.headerBg__chara[data-chara="1"]:after{
		width: 129.429%;/* 884 */
		background-image: url(../img/common/deco_chara3-s.png);
	}
	@supports (background-image: url(../img/common/deco_chara3-s.webp)){
		.headerBg__chara[data-chara="1"]:after{
			background-image:url(../img/common/deco_chara3-s.webp);
		}
	}
}



/* chara4 */
.headerBg__chara[data-chara="2"]{
	width: max(calc(475 / var(--vh-min)* 100vh), calc(475 / var(--vw-min)* 100vw));
	height: max(calc(712 / var(--vh-min)* 100vh), calc(712 / var(--vw-min)* 100vw));
	max-width: 100%;
	max-height: 82.4075vh;
	bottom: 0;
	left: 0;
	opacity: 0;
	transform: translateY(25%);
	transition: transform .5s ease, opacity .5s ease;
	z-index: 2;
}
.headerBg__chara[data-chara="2"]:before{
	content: '';
	position: absolute;
	top: 0;
	left: -17.0527%;
	width: 117.0527%;/* 556 */
	height: 100%;
	background: url(../img/common/deco_chara4.png) no-repeat left bottom / contain;
}
@supports (background-image: url(../img/common/deco_chara4.webp)){
	.headerBg__chara[data-chara="2"]:before{
		background-image:url(../img/common/deco_chara4.webp);
	}
}
.header.is-ani .headerBg__chara[data-chara="2"]{
	opacity: 1;
	transform: translateY(0%);
	transition-delay: .2s;
}
@media screen and (max-width:768px){
	.headerBg__chara[data-chara="2"]{
		width: calc(535 / var(--vw-min) * 100vw);
		height: calc(712 / var(--vw-min) * 100vw);
		max-height: 100%;
	}
	.headerBg__chara[data-chara="2"]:before{
		width: 100%;
		height: 127.809%;/* 910 */
		background: url(../img/common/deco_chara4-s.png) no-repeat left top / contain;
		left: calc(-96 / var(--vw-min) * 100vw);
	}
	@supports (background-image: url(../img/common/deco_chara4-s.webp)){
		.headerBg__chara[data-chara="2"]:before{
			background-image:url(../img/common/deco_chara4-s.webp);
		}
	}
}


/* chara5 */
.headerBg__chara[data-chara="3"]{
	width: max(calc(291 / var(--vh-min) * 100vh), calc(291 / var(--vw-min) * 100vw));
	height: max(calc(557 / var(--vh-min) * 100vh), calc(557 / var(--vw-min) * 100vw));
	max-width: 100%;
	max-height: 87.0313vh;
	bottom: 0;
	left: max(calc(48 / var(--vh-min) * 100vh), calc(48 / var(--vw-min) * 100vw));
	opacity: 0;
	transform: translateX(-75%);
	transition: transform .5s ease, opacity .5s ease;
}
.header.is-ani .headerBg__chara[data-chara="3"]{
	opacity: 1;
	transform: translateX(0%);
	transition-delay: .2s;
}
.headerBg__chara[data-chara="3"]:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../img/common/deco_chara5.png) no-repeat left bottom / contain;
}
@supports (background-image: url(../img/common/deco_chara5.webp)){
	.headerBg__chara[data-chara="3"]:before{
		background-image:url(../img/common/deco_chara5.webp);
	}
}
@media screen and (max-width:768px){
	.headerBg__chara[data-chara="3"]{
		width: calc(337 / var(--vw-min) * 100vw);
		height: calc(487 / var(--vw-min) * 100vw);
		max-height: 100%;
		left: calc(-32 / var(--vw-min) * 100vw);
	}
	.headerBg__chara[data-chara="3"]:before{
		background-image: url(../img/common/deco_chara5-s.png);
	}
	@supports (background-image: url(../img/common/deco_chara5-s.webp)){
		.headerBg__chara[data-chara="3"]:before{
			background-image:url(../img/common/deco_chara5-s.webp);
		}
	}
}



/**
 * navBtn
 */
.header__navBtnWrap {
	width: min(calc(80 / var(--vw-min) * 100vw), min(calc(80 / var(--vh-min) * 100vh), calc(80px * var(--max-percent))));
	height: min(calc(80 / var(--vw-min) * 100vw), min(calc(80 / var(--vh-min) * 100vh), calc(80px * var(--max-percent))));;
	position: absolute;
	top: 0;
	right: 0;
	margin-top: min(calc(40 / var(--vw-min) * 100vw), min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	margin-right: min(calc(40 / var(--vw-min) * 100vw), min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	z-index: 2;
}
.header__navBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	background-color: var(--color-black);
	position: relative;
	border-radius: 50%;
	overflow: hidden;
	pointer-events: auto;
}
.header__navBtn:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(#FFF, #FFF) right bottom / 0 100% no-repeat;
	transition: background-size .4s, opacity .4s ease;
}
.header__navBtnLine{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	border: 1px solid rgba(255,255,255,40%);
	width: 90%;
	height: 90%;
	border-radius: 50%;
	transition: .3s ease;
}
.header__navBtn__lineWrap {
	width: 40%;/* 32 */
	height: 20%;/* 16 */
	position: relative;
	z-index: 2;
}
.header__navBtn--line {
	background-color: #fff;
	display: block;
	width: 100%;
	height: 12.5%;
	margin: auto;
	position: absolute;
	transition: .4s ease, transform .4s ease;
}
.header__navBtn--line:nth-child(1) {
	top: 0;
	bottom: 87.5%;
}
.header__navBtn--line:nth-child(2) {
	top: 87.5%;
	bottom: 0;
}

@media screen and (hover:hover) and (pointer: fine){
	.header__navBtn::after{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		transform: scale(50%);
		background-color: #FFF;
		opacity: 0%;
		border-radius: 50%;
		transition: .4s ease;
	}
	.header__navBtn:hover::after{
		transform: scale(100%);
		opacity: 18%;
	}
}

@media screen and (max-width:768px){
	.header__navBtnWrap {
		width: calc(96 / var(--vw-min) * 100vw);
		height: calc(96 / var(--vw-min) * 100vw);
		margin-top: calc(24 / var(--vw-min) * 100vw);
		margin-right: calc(24 / var(--vw-min) * 100vw);
	}
	.header__navBtnLine{
		width: 89.5834%;
		height: 89.5834%;
		border-width: var(--sp-size-2);
	}
	.header__navBtn__lineWrap {
		width: 41.6667%;/* 40 */
		height: 20.8334%;/* 20 */
	}
	.header__navBtn--line {
		height: 20%;/* 4 */
	}
	.header__navBtn--line:nth-child(1) {
		bottom: 80%;
	}
	.header__navBtn--line:nth-child(2) {
		top: 80%;
	}
}

/* navAcrive */
.header__navBtn.is-active:before{
	opacity: 1;
	background-size: 100% 100%;
	background-position: left bottom;
}
.header__navBtn.is-active .header__navBtnLine{
	border-color:rgba(34, 34, 34, 40%);
}
.header__navBtn.is-active .header__navBtn--line {
	background-color: var(--color-black);
	transition-delay: 0s, .2s;
}
.header__navBtn.is-active .header__navBtn--line:nth-child(1),
.header__navBtn.is-active .header__navBtn--line:nth-child(2){
	top: 43.75%;
	bottom: 43.75%;
}
.header__navBtn.is-active .header__navBtn--line:nth-child(1){
	transform: rotate(45deg);
}
.header__navBtn.is-active .header__navBtn--line:nth-child(2){
	transform: rotate(-45deg);
}

@media screen and (hover:hover) and (pointer: fine){
	.header__navBtn.is-active::after{
		background-color: var(--color-black);
	}
}

@media screen and (max-width:768px){
	.header__navBtn.is-active .header__navBtn--line:nth-child(1),
	.header__navBtn.is-active .header__navBtn--line:nth-child(2){
		top: 40%;
		bottom: 40%;
	}
}



.header__logo .comLogo__link{
	display: block;
	pointer-events: auto;
}


/*-----------------------------------------------
 * FOOTER
-------------------------------------------------*/
.footer{
	width: 100%;
	min-height: 100vh;
	position: relative;
	z-index: 2;
	font-size: min(calc(10 / var(--vw-min) * 100vw), min(calc(10 / var(--vh-min) * 100vh), calc(10px * var(--max-percent))));
}
.footerCont{
	width: 100%;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
@media screen and (max-width:768px){
	.footer{
		font-size: calc(20 / var(--vw-min) * 100vw);
		min-height: max(100vh, 100vw);
	}
	.footerCont{
		padding: calc(216 / var(--vw-min) * 100vw) 0 calc(48 / var(--vw-min) * 100vw);
		display: flex;
		flex-direction: column;
	}
}


/**
* footerBanner
**/
.footer_bannerListsWrap{
	position: absolute;
	top: 0;
	bottom: 0;
	right: min(3.3334%, min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));/* 40 */
	width: 240px;
	height: 216px;
	width: 20%;
	height: 18vw;
	max-width: min(37.5vh, calc(240px * var(--max-percent)));
	max-height: min(33.75vh, calc(216px * var(--max-percent)));
	margin: auto 0;
}
.footer_bannerListsInWrap{
	width: 100%;
	height: 100%;
	padding: 8.3334% 0;
	position: relative;
}
.footer_bannerListsSwiper{
	height: 100%;
	-webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,0.1) 0%, #000 8%, #000 92%, rgba(0,0,0,0.1) 100%);
	mask-image: linear-gradient(180deg, rgba(0,0,0,0.1) 0%, #000 8%, #000 92%, rgba(0,0,0,0.1) 100%);
}
.footer_bannerList{
	width: 100%;
	height: 50%;/* 88 */
	padding: 5% 0;
}
.footer_bannerList > a{
	display: block;
}
.footer_bannerList > a > img{
	width: 100%;
}

.footer_bannerLists__paginations{
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
}

.footer_bannerListsWrap.--noSwiper .footer_bannerLists{
	flex-direction: column;
	justify-content: center;
}

@media screen and (hover:hover) and (pointer: fine){
	.footer_bannerList > a{
		background-color: rgba(255,255,255,50%);
	}
	.footer_bannerList > a img{
		transition: .3s ease;
	}
	.footer_bannerList > a:hover img{
		transform: scale(102.5%);
		opacity: 80%;
	}
}

@media screen and (max-width:768px){
	.footer_bannerListsWrap{
		position: relative;
		top: unset;
		bottom: unset;
		right: unset;
		width: 100%;
		height: auto;
		max-width: unset;
		max-height: unset;
		margin: 0 auto;
		padding: 0 calc(36 / var(--vw-min) * 100vw);
	}
	.footer_bannerListsInWrap{
		padding: 0;
	}
	.footer_bannerListsSwiper{
		-webkit-mask: unset;
		mask: unset;
	}
	.footer_bannerList{
		width: 50%;
		padding: 0 calc(12 / var(--vw-min) * 100vw);
	}
	.footer_bannerLists__paginations{
		position: relative;
		width: 100%;
		margin-top: calc(24 / var(--vw-min) * 100vw);
	}
	.footer_bannerListsWrap.--noSwiper .footer_bannerLists{
		flex-direction: unset;
	}
}


/**
* footerSNS
**/
.footer_shareListsWrap{
	position: absolute;
	top: 0;
	bottom: 0;
	left: min(3.3334%, min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));/* 40 */
	display: flex;
	align-items: center;
	width: 4em;/* 40 */
}
.shareLists{
	width: 100%;
}
.shareLists__title{
	width: 100%;
	font-family: var(--font-en);
	font-size: 1.4em;
	letter-spacing: 0;
	color: #FFF;
	text-align: center;
}
.shareLists__item{
	width: 100%;
	height: 4.4em;
	padding: 1.2em 1em;
}
.shareLists__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
}
.shareLists__link:before {
	content: "";
	width: 100%;
	height: 100%;
	background-color: #FFF;
	display: block;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: 100%;
	mask-size: 100%;
	transition: background-color .4s ease;
}

@media screen and (hover:hover) and (pointer: fine){
	.shareLists__link:hover:before {
		background-color: var(--color-black);
	}	
}

.shareLists__item.is-twitter .shareLists__link:before {
	-webkit-mask-image: url(../img/common/icon_tw.svg);
	mask-image: url(../img/common/icon_tw.svg);
}
.shareLists__item.is-facebook .shareLists__link:before {
	-webkit-mask-image: url(../img/common/icon_fb.svg);
	mask-image: url(../img/common/icon_fb.svg);
}
.shareLists__item.is-line .shareLists__link:before {
	-webkit-mask-image: url(../img/common/icon_line.svg);
	mask-image: url(../img/common/icon_line.svg);
}

@media screen and (max-width:768px){
	.footer_shareListsWrap{
		width: calc(96 / var(--vw-min) * 100vw);
		left: calc(24 / var(--vw-min) * 100vw);/* 24 */;
	}
	.shareLists__title{
		font-size: calc(20 / var(--vw-min) * 100vw);
		letter-spacing: 0;
	}
	.shareLists__item{
		height: calc(96 / var(--vw-min) * 100vw);/* 96 */
		padding:  calc(24 / var(--vw-min) * 100vw);/* 24 */
	}
}

/**
* footer_copyWrap
**/
.footer_copyWrap{
	width: 32em;/* 320 */
	height: 32em;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}
.footer_copyInWrap{
	width: 100%;
	height: 100%;
	position: relative;
}
.footer_copyImage{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	animation: 32s ani_rotate linear infinite;
}
.footer_copyImage img{
	width: 100%;
	height: 100%;
	object-fit: contain;
}

body[data-page="top"]:not([data-nowsection="footer"]) .footer_copyImage{
	animation-play-state: paused;
}

@media screen and (max-width:768px){
	.footer_copyWrap{
		width: calc(480 / var(--vw-min) * 100vw);
		height: calc(576 / var(--vw-min) * 100vw);
		padding: calc(48 / var(--vw-min) * 100vw) 0;
		position: relative;
	}
}


/**
* footerContIn
**/
.footerContIn{
	width: 100%;
	padding: 0 min(3.3334%, min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent)))) min(min(40 / var(--vw-min) * 100vw), min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	margin-top: auto;
}
.footer_anxInfo{
	width: 100%;
	position: relative;
}

.footer_sitecaution{
	text-align: center;
	color: #FFF;
	font-size: 1em;
	font-weight: 500;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
}

.footer_anxLists{
	width: 20em;/* 200 */
}
.footer_anxList{
	display: inline-block;
}
.footer_anxList.logo_anx{
	display: block;
	width: 11.2em;/* 112 */
	margin-bottom: 2.4em;/* */
}
.footer_anxList.logo_anx a{
	display: block;
	width: 100%;
	padding-top: 28.5715%;/* 32 */
	position: relative;
	-webkit-mask: url(../img/common/logo_aniplex.svg) no-repeat center / contain;
	mask: url(../img/common/logo_aniplex.svg) no-repeat center / contain;
	background-color: #fff;
}
.footer_anxList.anx_txtlink{
	position: relative;
}
.footer_anxList:nth-child(2){
	padding-right: 1.5em;
}
.footer_anxList:nth-child(3){
	padding-left: 1.25em;
}
.footer_anxList:nth-child(2):after{
	content: '';
	position: absolute;
	top: 5%;
	right: 0;
	bottom: 5%;
	width: 1px;
	background-color: #FFF;
}
.footer_anxList.anx_txtlink a{
	font-family: var(--font-en);
	font-size: 1.2em;
	line-height: 0.8;
	color: #FFF;
	text-decoration: none;
}


@media screen and (hover:hover) and (pointer: fine){
	.footer_anxList.logo_anx a,
	.footer_anxList.anx_txtlink a{
		transition: .3s ease;
	}
	.footer_anxList.logo_anx a:hover{
		opacity: 70%;
		transform: scale(102.5%);
	}
	.footer_anxList.anx_txtlink a:hover{
		opacity: 75%;
	}
}

@media screen and (max-width:768px){
	.footerContIn{
		padding: 0 calc(48 / var(--vw-min) * 100vw);
		margin-top: unset;
	}
	.footer_sitecaution{
		position: relative;
		font-size: calc(20 / var(--vw-min) * 100vw);
		line-height: 2;
	}
	.footer_anxLists{
		width: auto;
		padding-top: calc(40 / var(--vw-min) * 100vw);
	}
	.footer_anxList.logo_anx{
		width: calc(168 / var(--vw-min) * 100vw);
		margin-bottom: calc(48 / var(--vw-min) * 100vw);
	}
	.footer_anxList:nth-child(2){
		padding-right: calc(32 / var(--vw-min) * 100vw);
	}
	.footer_anxList:nth-child(3){
		padding-left: calc(28 / var(--vw-min) * 100vw);
	}
	.footer_anxList:nth-child(2):after{
		width: var(--sp-size-2);
	}
	.footer_anxList.anx_txtlink a{
		font-size: calc(24 / var(--vw-min) * 100vw);
	}
}

/**
* backToTop
**/
.backTotopWrap{
	position: absolute;
	bottom: 0;
	right: 0;
	margin-bottom: min(3.3334%, min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));/* 40 */
	margin-right: clamp(3.3334%, min(calc(40 / var(--vw-min) * 100vw), calc(40px * var(--max-percent))), calc(40 / var(--vh-min) * 100vh));/* 40 */
	width: 10%;
	max-width: min(calc(120 / var(--vh-min) * 100vh), calc(120px * var(--max-percent)));
}
.backTotopInWrap{
	width: 100%;
	padding-top: 100%;
	position: relative;
}
.btn_backTotop{
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	pointer-events: auto;
}
.btn_backTotop.--scrolling{
	pointer-events: none;
}
.btn_backTotop--circle{
	width: 100%;
	height: 100%;
	margin: 0;
	position: absolute;
	top: 0;
	left: 0;
	transform: rotate(-90deg);
}
.btn_backTotop--circle circle{
	cx: min(calc(60 / var(--vw-min) * 100vw), min(calc(60 / var(--vh-min) * 100vh), calc(60px * var(--max-percent))));
	cy: min(calc(60 / var(--vw-min) * 100vw), min(calc(60 / var(--vh-min) * 100vh), calc(60px * var(--max-percent))));
	r:  calc(min(calc(60 / var(--vw-min) * 100vw), min(calc(60 / var(--vh-min) * 100vh), calc(60px * var(--max-percent)))) - 2px);
	fill: transparent;
	stroke-width: 1px;
	/* stroke-dasharray: 310% 310%; */
	position: absolute;
	top: 0;
	left: 0;
}

.btn_backTotop--circle.-bg circle{
	stroke: rgb(120, 120, 120);
	stroke-dasharray: 320% 320%;
}
.btn_backTotop--circle.-in circle{
	stroke: rgb(255,255,255);
	animation: ani_ssCircle_in 4s linear infinite;
}
.btn_backTotop--circle.-out circle{
	stroke: rgb(120, 120, 120);
	/* stroke-dasharray: 260% 310%; */
	animation: ani_ssCircle_out 4s linear infinite;
}

@keyframes ani_ssCircle_in {
	0%{
		opacity: 1;
		stroke-dasharray: 0% 320%;
	}
	48%,50%{
		opacity: 1;
		stroke-dasharray: 320% 320%;
	}
}
@keyframes ani_ssCircle_out {
	0%,50%{
		opacity: 1;
		stroke-dasharray: 0% 320%;
	}
	98%,100%{
		opacity: 1;
		stroke-dasharray: 320% 320%;
	}
}

.btn_backTotop--txt{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-en);
	font-size: min(min(calc(14 / var(--vw-min) * 100vw), min(calc(14 / var(--vh-min) * 100vh)), calc(14px * var(--max-percent))));/* 14 */
	letter-spacing: 0;
	line-height: 1;
	color: #FFF;
}
.btn_backTotop--arrow{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: min(min(calc(16 / var(--vw-min) * 100vw), min(calc(16 / var(--vh-min) * 100vh)), calc(16px * var(--max-percent))));
	height: min(min(calc(16 / var(--vw-min) * 100vw), min(calc(16 / var(--vh-min) * 100vh)), calc(16px * var(--max-percent))));
	margin-left: auto;
	margin-right: auto;
	margin-top: min(min(calc(16 / var(--vw-min) * 100vw), min(calc(16 / var(--vh-min) * 100vh)), calc(16px * var(--max-percent))));
	-webkit-mask: url(../img/common/arrow_t.svg) no-repeat center / contain;
	mask: url(../img/common/arrow_t.svg) no-repeat center / contain;
	background-color: #fff;
}

@media screen and (hover:hover) and (pointer: fine){
	.btn_backTotop--arrow{
		transition: .3s ease;
	}
	.btn_backTotop:hover .btn_backTotop--arrow{
		transform: translateY(-50%);
	}
}

@media screen and (max-width:768px){
	.backTotopWrap{
		margin-bottom: calc(48 / var(--vw-min) * 100vw);
		margin-right: calc(48 / var(--vw-min) * 100vw);
		width: calc(144 / var(--vw-min) * 100vw);
		max-width: unset;
	}
	.btn_backTotop--circle circle{
		cx: calc(72 / var(--vw-min) * 100vw);
		cy: calc(72 / var(--vw-min) * 100vw);
		r:  calc((72 / var(--vw-min) * 100vw) - 2px);
	}
	.btn_backTotop--circle.-bg circle{
		stroke-dasharray: 390% 390%;
	}

	@keyframes ani_ssCircle_in {
		0%{
			opacity: 1;
			stroke-dasharray: 0% 390%;
		}
		48%,50%{
			opacity: 1;
			stroke-dasharray: 390% 390%;
		}
	}
	@keyframes ani_ssCircle_out {
		0%,50%{
			opacity: 1;
			stroke-dasharray: 0% 390%;
		}
		98%,100%{
			opacity: 1;
			stroke-dasharray: 390% 390%;
		}
	}
	.btn_backTotop--txt{
		width: 5em;
		font-size: calc(20 / var(--vw-min) * 100vw);
		margin: 0 auto;
	}
	.bsst.-pc{display: none;}
	.btn_backTotop--txt.-down{
		width: 3.5em;
	}
	.btn_backTotop--txt.-toTop{
		width: 4em;
	}
	.btn_backTotop--arrow{
		width: calc(24 / var(--vw-min) * 100vw);
		height: calc(24 / var(--vw-min) * 100vw);
		margin-bottom: calc(26 / var(--vw-min) * 100vw);
	}
}




/*-----------------------------------------------
 * Parts
-------------------------------------------------*/
/**
* animation
**/
/* rotate */
@keyframes ani_rotate {
	0%{transform: rotate(0);}
	100%{ transform:rotate(360deg);}
}


/**
* comLogo
**/
.comLogo{
	position: absolute;
	top: min(calc(24 / var(--vw-min) * 100vw), min(calc(24 / var(--vh-min) * 100vh), calc(24px * var(--max-percent))));
	left: min(3.3334%, min(calc(40 / var(--vh-min) * 100vh), calc(40px * var(--max-percent))));
	width: min(calc(200 / var(--vw-min) * 100vw), min(calc(200 / var(--vh-min) * 100vh), calc(200px * var(--max-percent))));
	/* height: min(calc(78 / var(--vw-min) * 100vw), min(calc(78 / var(--vh-min) * 100vh), calc(78px * var(--max-percent)))); */
}
.comLogo__link{
	display: block;
	width: 100%;
	pointer-events: auto;
}
.comLogo img{
	width: 100%;
}

@media screen and (hover:hover) and (pointer: fine){
	.comLogo__link img{
		transition: .3s ease;
	}
	.comLogo__link:hover img{
		transform: scale(105%);
	}
}

@media screen and (max-width:768px){
	.comLogo{
		top: calc(24 / var(--vw-min) * 100vw);
		left: calc(24 / var(--vw-min) * 100vw);
		width: calc(240 / var(--vw-min) * 100vw);
	}
}


/**
* comImage
**/
body:not([data-page="top"]) .comBGImage{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
body:not([data-page="top"]) .comBGImage img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}


/**
* COMLINK
**/
.comLink{
	text-align: center;
	margin-top: 2.5em;/* 40 */
	line-height: 1;
}
.comLink.-mt_x2{
	margin-top: 5em;/* 80 */
}
.comLink__link{
	display: inline-block;
	text-decoration: none;
	min-width: min(25em, 400px);
	max-width: 100%;
	border-radius: 96px;
	color: var(--color-black);
	border: 1px solid var(--color-black);
	padding: 0.75em 2em;/* 12 32 */
	position: relative;
	line-height: 1;
	overflow: hidden;
}
.comLink__link:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.comLink__link.-wh{
	background-color: #fff;
}
.comLink__link.-en{
	font-family: var(--font-en);
}
.comLink__link.-arrow_r:after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0.75em;/* 12 */
	margin: auto 0;
	width: 1em;/* 16 */
	height: 1em;
	-webkit-mask: url(../img/common/arrow_r.svg) no-repeat center / contain;
	mask: url(../img/common/arrow_r.svg) no-repeat center / contain;
	background-color: var(--color-black);
}
.comLink__link.-arrow_l:after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0.75em;/* 12 */
	margin: auto 0;
	width: 1em;/* 16 */
	height: 1em;
	-webkit-mask: url(../img/common/arrow_l.svg) no-repeat center / contain;
	mask: url(../img/common/arrow_l.svg) no-repeat center / contain;
	background-color: var(--color-black);
}
.comLink__link.-blank:after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0.75em;/* 12 */
	margin: auto 0;
	width: 1em;/* 16 */
	height: 1em;
	-webkit-mask: url(../img/common/icon_blank.svg) no-repeat center / contain;
	mask: url(../img/common/icon_blank.svg) no-repeat center / contain;
	background-color: var(--color-black);
}
.comLink__link.-bk{
	color: #FFF;
	background-color: var(--color-black);
}
.comLink__link.-bk.-arrow_r:after,
.comLink__link.-bk.-arrow_l:after,
.comLink__link.-bk.-blank:after{
	background-color: #FFF;
}
.comLink__link--txt{
	position: relative;
}

@media screen and (hover:hover) and (pointer: fine){
	.comLink__link{
		transition: .3s ease;
	}
	.comLink__link:before{
		background: linear-gradient(var(--color-black), var(--color-black)) right bottom / 0 100% no-repeat;
        transition: background-size .4s;
	}
	.comLink__link.-bk:before{
		background-image: linear-gradient(#FFF, #FFF);
	}
	.comLink__link:hover{
		color: #fff;
	}
	.comLink__link.-bk:hover{
		color: var(--color-black);
	}
	.comLink__link:hover::before{
		background-size: 100% 100%;
		background-position: left bottom;
	}

	.comLink__link.-arrow_l:before{
		background-position: left bottom;
	}
	.comLink__link.-arrow_l:hover::before{
		background-position: right bottom;
	}

	.comLink__link.-arrow_r:after,
	.comLink__link.-arrow_l:after,
	.comLink__link.-blank:after{
		transition: .3s ease .2s;
	}
	.comLink__link.-arrow_r:hover::after{
		transform: translateX(50%);
		background-color: #fff;
	}
	.comLink__link.-arrow_l:hover::after{
		transform: translateX(-50%);
		background-color: #fff;
	}
	.comLink__link.-blank:hover::after{
		background-color: #fff;
	}
	.comLink__link.-bk.-arrow_r:hover::after,
	.comLink__link.-bk.-arrow_l:hover::after,
	.comLink__link.-bk.-blank:hover::after{
		background-color: var(--color-black);
	}
}

@media screen and (max-width:768px){
	.comLink{
		margin-top: calc(48 / var(--vw-min) * 100vw);
	}
	.comLink.-mt_x2{
		margin-top: calc(96 / var(--vw-min) * 100vw);
	}
	.comLink__link{
		min-width: 23.25em;/* 558 */
		max-width: 100%;
		padding: 1.0834em 3em;/* 26 72 */
	}
	.comLink__link.-arrow_r:after{
		right: 1em;/* 24 */
	}
}




/**
* com_h2
**/
.com_h2{
	display: flex;
	align-items: flex-end;
	padding-bottom: 1em;
	border-bottom: 1px solid var(--color-black);
}
.com_h2-en{
	display: inline-block;
	font-family: var(--font-en);
	font-size: min(calc(44 / var(--vw-min) * 100vw), calc(44px * var(--max-percent)));
	font-weight: 700;
	line-height: 0.8;
}
.com_h2-ja{
	display: inline-block;
	padding-left: min(calc(24 / var(--vw-min) * 100vw), calc(24px * var(--max-percent)));
	font-weight: 700;
	line-height: 1;
	padding-bottom: 0.25em;
}

@media screen and (max-width:768px){
	.com_h2{
		padding-bottom: calc(24 / var(--vw-min) * 100vw);
		border-width: var(--sp-size-2);
	}
	.com_h2-en{
		font-size: calc(44 / var(--vw-min) * 100vw);
	}
	.com_h2-ja{
		padding-left: calc(24 / var(--vw-min) * 100vw);
		padding-bottom: 0.185em;
	}
}


/*-----------------------------------------------
 * MAIN - COMMON
-------------------------------------------------*/
/**
* main
**/
.main{
	width: 100%;
	min-height: 100vh;
	position: relative;
	z-index: 2;
	background-color: #fafaeb;
	font-size: min(calc(16 / var(--vw-min) * 100vw), calc(16px * var(--max-percent)));
	padding-bottom: min(6.6667%, calc(80px * var(--max-percent)));/* 80 */
}
@media screen and (max-width:768px){
	.main{
		font-size: var(--sp-size-24);
		padding-top: calc(168 / var(--vw-min) * 100vw);
		padding-bottom: calc(96 / var(--vw-min) * 100vw);
	}
}

/**
* mainNavWrap
**/
.mainNavWrap{
	width: 100%;
	position: relative;
	display: flex;
	align-items: center;
	padding: 16px;
	font-size: 16px;
	background-color: #FFF;
}
.mainNavWrap:before{
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 1px;
	background-color: var(--color-black);
}
.mainNavWrap .navLists{
	display: flex;
	flex-wrap: wrap;
	position: relative;
}
.mainNavWrap .navList{
	padding: 8px;
}
.mainNavWrap .navList__link{
	color: var(--color-black);
	font-size: 20px;
}

.mainNavWrap .snsLists{
	flex-shrink: 0;
	margin-top: unset;
	padding-left: 16px;
}
.mainNavWrap .snsList__dt{
	font-size: 14px;
	padding-right: 8px;
	color: var(--color-black);
}
.mainNavWrap .snsList__dd{
	padding: 0 8px;
	width: 36px;
	height: 20px;
}
.mainNavWrap .snsList__link:before{
	background-color: var(--color-black);
}

@media screen and (max-width:768px){
	.mainNavWrap{
		display: none;
	}
}

/**
* mainHead
**/
.mainHead{
	width: 100%;
	padding-top: min(6.6667%, calc(80px * var(--max-percent)));/* 80 */
	padding-left: min(3.3334%, calc(40px * var(--max-percent)));/* 40 */
	padding-right: min(3.3334%, calc(40px * var(--max-percent)));/* 40 */
	padding-bottom: min(3.3334%, calc(40px * var(--max-percent)));/* 40 */
	position: relative;
	display: flex;
	align-items: center;
}
.mainHead:after{
	content: '';
	width: min(calc(213 / var(--vw-min) * 100vw), calc(213px * var(--max-percent)));
	height: min(calc(60 / var(--vw-min) * 100vw), calc(60px * var(--max-percent)));
	margin-left: auto;
	background: url(../img/common/mainhead_deco.svg) no-repeat right center / contain;
}
.mainHead__logo{
	width: 17.8572%;/* 200 */
	max-width: calc(200px * var(--max-percent));
}
.mainHead__logo--link{
	display: block;
}
@media screen and (hover:hover) and (pointer: fine){
	.mainHead__logo--link img{
		transition: .3s ease;
	}
	.mainHead__logo--link:hover img{
		transform: scale(105%);
	}
}
.mainHead__logo img{
	width: 100%;
}
.mainHeadIn{
	display: flex;
	flex-direction: column;
	padding-left: 3.5715%;/* 40 */
}
.mainHead__title-en{
	order: 1;
	height: 1em;
	font-family: var(--font-en);
	font-size: min(calc(58 / var(--vw-min) * 100vw), calc(58px * var(--max-percent)));
	font-weight: 700;
	line-height: 1;
	margin-top: min(calc(12 / var(--vw-min) * 100vw), calc(12px * var(--max-percent)));
	overflow: hidden;
}
.mainHead__txt{
	display: flex;
	align-items: flex-end;
	line-height: 1;
}
.mainHead__txt-num{
	font-family: var(--font-en);
	font-weight: 700;
	font-size: min(calc(44 / var(--vw-min) * 100vw), calc(44px * var(--max-percent)));
	overflow: hidden;
}
.mainHead__txtIn{
	padding-left: min(calc(10 / var(--vw-min) * 100vw), calc(10px * var(--max-percent)));
	padding-bottom: min(calc(4 / var(--vw-min) * 100vw), calc(4px * var(--max-percent)));
}
.mainHead__txt-numTitle{
	font-family: var(--font-en);
	font-weight: 700;
	font-size: min(calc(10 / var(--vw-min) * 100vw), calc(10px * var(--max-percent)));
}
.mainHead__txt-numAll{
	font-family: var(--font-en);
	font-weight: 700;
	font-size: min(calc(21 / var(--vw-min) * 100vw), calc(21px * var(--max-percent)));
	margin-top: min(calc(4 / var(--vw-min) * 100vw), calc(4px * var(--max-percent)));
	padding-left: min(calc(12 / var(--vw-min) * 100vw), calc(12px * var(--max-percent)));
	position: relative;
	color: rgba(34, 34, 34, 40%);
}
.mainHead__txt-numAll:before{
	content: '';
	position: absolute;
	left: 0;
	top: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent)));
	bottom: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent)));
	width: 1px;
	background-color: var(--color-black);
}
.mainHead__title-ja{
	padding-left: min(calc(24 / var(--vw-min) * 100vw), calc(24px * var(--max-percent)));
	font-weight: 700;
	margin-bottom: min(calc(8 / var(--vw-min) * 100vw), calc(8px * var(--max-percent)));
	overflow: hidden;
}

@media screen and (max-width:768px){
	.mainHead{
		padding-top: 0;
		padding-left: calc(48 / var(--vw-min) * 100vw);
		padding-right: calc(48 / var(--vw-min) * 100vw);
		padding-bottom: calc(48 / var(--vw-min) * 100vw);
		align-items: flex-start;
	}
	.mainHead:after{
		width: calc(284 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
		position: absolute;
		top: 0;
		right: calc(24 / var(--vw-min) * 100vw);
	}
	.mainHead__logo{
		display: none;
	}
	.mainHeadIn{
		padding-left: 0;
	}
	.mainHead__title-en{
		font-size: calc(70 / var(--vw-min) * 100vw);
		margin-top: calc(12 / var(--vw-min) * 100vw);
	}
	.mainHead__txt-num{
		font-size: calc(60 / var(--vw-min) * 100vw);
	}
	.mainHead__txtIn{
		padding-left: calc(16 / var(--vw-min) * 100vw);
	}
	.mainHead__txt-numTitle{
		font-size: calc(16 / var(--vw-min) * 100vw);
	}
	.mainHead__txt-numAll{
		font-size: calc(26 / var(--vw-min) * 100vw);
		margin-top: calc(8 / var(--vw-min) * 100vw);
		padding-left: calc(20 / var(--vw-min) * 100vw);
	}
	.mainHead__txt-numAll:before{
		top: var(--sp-size-2);
		bottom: var(--sp-size-2);
		width: var(--sp-size-2);
	}
	.mainHead__title-ja{
		padding-left: calc(24 / var(--vw-min) * 100vw);
		margin-bottom: calc(6 / var(--vw-min) * 100vw);
	}
}


/**
* header__logo
**/
@media screen and (min-width:769px){
	body:not([data-page="top"]) .header__logo,
	body:not([data-page="top"]) .header__navBtnWrap{
		opacity: 0;
		transform: translateY(-25%) scale(80%);
		transition: opacity .3s ease, transform .45s ease;
	}

	body:not([data-page="top"]).--contentShow .header__logo,
	body:not([data-page="top"]).--contentShow .header__navBtnWrap{
		opacity: 1;
		transform: translateY(0%) scale(1);
	}
	body:not([data-page="top"]):not(.--contentShow) .header__logo .comLogo__link,
	body:not([data-page="top"]):not(.--contentShow) .header:not(.is-active) .header__navBtnWrap .header__navBtn{
		pointer-events: none;
	}
	body:not([data-page="top"]):not(.--contentShow) .header.is-active .header__navBtnWrap{
		opacity: 1;
		transform: translateY(0%) scale(100%);
		transition: opacity .2s ease, transform .2s ease;
	}
}



/**
* mainContent
**/
.mainContent{
	width: 100%;
	position: relative;
	padding-top: min(3.3334%, calc(40px * var(--max-percent)));/* 40 */
	padding-bottom: min(6.6667%, calc(80px * var(--max-percent)));/* 80 */
}
@media screen and (max-width:768px){
	.mainContent{
		padding-top: calc(48 / var(--vw-min) * 100vw);
		padding-bottom: calc(96 / var(--vw-min) * 100vw);
	}
}



/*-----------------------------------------------
 * STAFFCAST > commentModal
-------------------------------------------------*/
.commentWrap{
	width: 86.6667vw;
	max-width: 1040px;
	margin: 0 auto;
}
.comment__title{
	display: flex;
	align-items: flex-end;
	line-height: 1;
	font-weight: 700;
	padding-bottom: min(calc(24 / var(--vw-min) * 100vw), calc(24px * var(--max-percent)));
}
.comment__title_job{
	display: inline-block;
	font-size: min(calc(20 / var(--vw-min) * 100vw), calc(20px * var(--max-percent)));
	color: var(--color-orange);
}
.comment__title_name{
	display: inline-block;
	font-size: min(calc(24 / var(--vw-min) * 100vw), calc(24px * var(--max-percent)));
	color: var(--color-blue);
	padding-left: 1em;
}
.comment__title_name small{
	font-size: 60%;
}
.comment__img img{
	width: 100%;
}
.comment__text{
	line-height: 2;
	font-size: min(calc(16 / var(--vw-min) * 100vw), calc(16px * var(--max-percent)));
	font-weight: 700;
}

/* cast */
.commentWrap[data-comment="cast01"] .comment__title_job{
	color: var(--color-chara-satsuki);
}
.commentWrap[data-comment="cast02"] .comment__title_job{
	color: var(--color-chara-an);
}
.commentWrap[data-comment="cast03"] .comment__title_job{
	color: var(--color-chara-sakurako);
}
.commentWrap[data-comment="cast04"] .comment__title_job{
	color: var(--color-chara-haruno_lightdark);
}
.commentWrap[data-comment="cast05"] .comment__title_job{
	color: var(--color-chara-kako);
}
.commentWrap[data-comment="cast01"] .comment__title_name,
.commentWrap[data-comment="cast02"] .comment__title_name,
.commentWrap[data-comment="cast03"] .comment__title_name,
.commentWrap[data-comment="cast04"] .comment__title_name,
.commentWrap[data-comment="cast05"] .comment__title_name{
	color: var(--color-black);
}


/* flex */
.commentInWrap.-flex{
	display: flex;
	flex-wrap: wrap;
}
.commentInWrap.-flex .comment__title{
	width: 100%;
}
.commentInWrap.-flex .comment__img{
	width: 50%;
	padding-right: 5%;
}
.commentInWrap.-flex .comment__text{
	width: 50%;
}



@media screen and (max-width:768px){
	.commentWrap{
		width: 100%;
		padding: calc(96 / var(--vw-min) * 100vw) calc(48 / var(--vw-min) * 100vw);
	}
	.comment__title{
		padding-bottom: calc(48 / var(--vw-min) * 100vw);
		flex-direction: column;
		align-items: unset;
	}
	.comment__title_job{
		font-size: calc(32/ var(--vw-min) * 100vw);
		flex-shrink: 0;
		padding-bottom: calc(20 / var(--vw-min) * 100vw);
	}
	.comment__title_name{
		font-size: calc(40 / var(--vw-min) * 100vw);
		padding-left: 0;
	}
	.comment__text{
		font-size: calc(24 / var(--vw-min) * 100vw);
	}

/* flex */
	.commentInWrap.-flex{
		flex-direction: column;
	}
	.commentInWrap.-flex .comment__title{
		width: 100%;
	}
	.commentInWrap.-flex .comment__img{
		width: 100%;
		padding-right: 0;
		padding-bottom: calc(48 / var(--vw-min) * 100vw);
	}
	.commentInWrap.-flex .comment__text{
		width: 100%;
	}
}





/*-----------------------------------------------
 * LOADING
-------------------------------------------------*/
.loading{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10002;
	
}
.loading:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.loadingElement{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

/**
* imageSet
**/
.loadingSet{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #fafaeb;
	clip-path:circle(min(150vh,150vw) at center);
}

/**
 * TOP向け
**/
.tLoading_catch{
	width: min(calc(80 / var(--vw-min) * 100vw), calc(80px * 1.6));/* 80 */
	opacity: 0;
	transform: rotateY(15deg) rotateX(30deg) translate(-50%, -50%);
	animation: ani_loading_catch_start .4s ease-in-out forwards;
	animation-delay: 0.4s;
}
@media screen and (max-width:768px){
	.tLoading_catch{
		width: calc(96 / var(--vw-min) * 100vw);
	}
}

.tLoading_catch img{
	width: 100%;
	animation: ani_loading_move_img 1.4s infinite ease-in-out alternate;
	animation-delay: 0.5s;
}
@keyframes ani_loading_catch_start {
	0%{
		opacity: 0;
		transform: rotateY(15deg) rotateX(15deg) translate(5%, 5%);
	}
	100%{
		opacity: 1;
		transform: rotateY(0deg) rotateX(0deg) translate(0%, 0%);
	}
}

@keyframes ani_loading_move_img {
	0% {transform:translate(0, 0) rotate(0deg);}
	42% {transform:translate(0, 0) rotate(0deg);}

	44% {transform:translate(0, 0) rotate(-3deg);}
	46% {transform:translate(0, -1px) rotate(0deg);}
	48% {transform:translate(0, -1px) rotate(3deg);}

	50% {transform:translate(1px, 0) rotate(-2deg);}
	52% {transform:translate(0, 1px) rotate(0deg);}
	54% {transform:translate(0, 0) rotate(3deg);}

	56% {transform:translate(0, 0) rotate(0deg);}
	100% {transform:translate(0, 0) rotate(0deg);}
}

@keyframes ani_loading_catch_end {
	0%{
		opacity: 1;
		transform: rotateY(0deg) rotateX(0deg) translate(0%, 0%);
	}
	100%{
		opacity: 0;
		transform: rotateY(0deg) rotateX(0deg) translate(0%, 0%) scale(25%);
	}
}

body.--is-loading .tLoading_catch img{
	animation-play-state: paused;
}
body.--is-loading .tLoading_catch{
	animation: ani_loading_catch_end .4s cubic-bezier(.6,-0.69,.59,1.02) forwards;
	animation-delay: 0s;
}

/* LOGO */
.tLoading_logo{
	width: min(calc(240 / var(--vw-min) * 100vw), calc(240px * 1.6));
	opacity: 0;
	animation: ani_loading_logo_start .4s cubic-bezier(.54,1.82,.81,1.06) forwards;
	animation-delay: 0.2s;
}
.tLoading_logo img{
	width: 100%;
	animation: ani_loading_move_img 1.4s infinite ease-in-out alternate;
	animation-delay: 0.5s;
}
@media screen and (max-width:768px){
	.tLoading_logo{
		width: calc(288 / var(--vw-min) * 100vw);
	}
}

@keyframes ani_loading_logo_start {
	0%{
		opacity: 0;
		transform: scale(25%) translateX(7.0834%) translateY(-7.6087%);
	}
	100%{
		opacity: 1;
		transform: scale(100%) translateX(7.0834%) translateY(-7.6087%);/* 17 -7 */
	}
}
@keyframes ani_loading_logo_end {
	0%{
		opacity: 1;
		transform: scale(100%) translateX(7.0834%) translateY(-7.6087%);/* 17 -7 */
	}
	100%{
		opacity: 0;
		transform: scale(25%) translateX(7.0834%) translateY(-7.6087%);
	}
}

/* body.--is-loading .tLoading_logo{
	opacity: 1;
	transform: scale(100%) translateX(7.0834%) translateY(-7.6087%);
	transition-delay: .2s;
} */

body.--is-loaded .tLoading_logo img{
	animation-play-state: paused;
}
/* body.--is-loading .tLoading_logo{
	animation: ani_loading_logo_end .4s cubic-bezier(.6,-0.69,.59,1.02) forwards;
	animation-delay: .1s;
} */


/**
* 下層ページ
**/
.loading_logo{
	width: min(calc(240 / var(--vw-min) * 100vw), calc(240px * 1.6));
	opacity: 0;
	transform: scale(25%) translateX(7.0834%) translateY(-7.6087%);
	animation: ani_loading_logo_start .4s cubic-bezier(.54,1.82,.81,1.06) forwards;
	animation-delay: .4s;
}
.loading_logo-img{
	transition: .4s cubic-bezier(.6,-0.69,.59,1.02);
}
.loading_logo img{
	width: 100%;
	animation: ani_loading_move_img 1.4s infinite ease-in-out alternate;
}

body.--is-loading .loading_logo-img{
	transition-delay: 0s;
	transform: scale(150%);
}
body.--is-loading .loading_logo img{
	animation-play-state: paused;
}


/**
* 共通
**/
.loadingCircle.-orange{
	background-color: var(--color-orange);
}
.loadingCircle.-blue{
	background-color: var(--color-blue);
}
.loadingCircle.-white{
	background-color: #fafaeb;
}


@keyframes ani_loading_circle {
	0% {
		clip-path: circle(0px at center);
	}
	100% {
		clip-path:circle(min(200vh,200vw) at center);
	}
}
.loadingCircle {
	clip-path: circle(0px at center);
	animation: ani_loading_circle 0.8s ease forwards;
	animation-play-state: paused;
}


.loading_chara{
	width: min(calc(160 / var(--vw-min) * 100vw), calc(160px * 1.6));
	padding-top: min(calc(160 / var(--vw-min) * 100vw), calc(160px * 1.6));
	position: relative;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	border-radius: 50%;
	background-color: #fff;
}
@media screen and (max-width:768px){
	.loading_chara{
		width: calc(192 / var(--vw-min) * 100vw);
		height: calc(192 / var(--vw-min) * 100vw)
	}
}
.loading_chara[data-chara="0"]{
	background-image: url(../img/introduction/about_img1.png);
}
.loading_chara[data-chara="1"]{
	background-image: url(../img/introduction/about_img2.png);
}
.loading_chara[data-chara="2"]{
	background-image: url(../img/introduction/about_img3.png);
}
.loading_chara[data-chara="3"]{
	background-image: url(../img/introduction/about_img4.png);
}
.loading_chara[data-chara="4"]{
	background-image: url(../img/introduction/about_img5.png);
}


.loading_chara{
	animation: ani_loading_logo_end .3s cubic-bezier(.6,-0.69,.59,1.02) forwards;
	animation-play-state: paused;
}

@keyframes ani_loading_logo_end {
	0%{
		opacity: 1;
		transform: scale(100%);
	}
	100%{
		opacity: 0;
		transform: scale(25%);
	}
}

@keyframes ani_loading_closeCircle {
	0% {
		clip-path:circle(min(150vh,150vw) at center);
	}
	100% {
		clip-path: circle(0px at center);
	}
}


/**
* loading - Animation
**/
.loading{
	clip-path:circle(min(150vh,150vw) at center);
	animation: ani_loading_closeCircle 0.6s ease forwards;
	animation-play-state: paused;
}


/**
* Animation - Active
**/
body.--is-loading .loadingCircle{
	animation-play-state: running;
}
body.--is-loading .loading_chara{
	animation-play-state: running;
}
/* body.--is-loading .loading{
	animation-play-state: running;
} */

/* top */
body[data-page="top"].--is-loading .loadingCircle.-orange{
	animation-delay: .2s;
}
body[data-page="top"].--is-loading .loadingCircle.-blue{
	animation-delay: .5s;
}
body[data-page="top"].--is-loading .loadingCircle.-white{
	animation-delay: 0.7s;
}
body[data-page="top"].--is-loading .loading_chara{
	animation-delay: 1.0s;
}
/* body[data-page="top"].--is-loading .loading{
	animation-delay: 1.4s;
	animation-play-state: running;
} */





/* inPage */
body:not([data-page="top"]) .loadingCircle.-white,
body:not([data-page="top"]) .loadingCircle.-orange,
body:not([data-page="top"]) .loadingCircle.-blue{
	clip-path:circle(min(150vh,150vw) at center);
	animation: ani_loading_closeCircle 0.5s ease forwards;
	animation-play-state: paused;
}
body:not([data-page="top"]).--is-loading .loadingCircle.-white,
body:not([data-page="top"]).--is-loading .loadingCircle.-orange,
body:not([data-page="top"]).--is-loading .loadingCircle.-blue{
	animation-play-state: running;
}
body:not([data-page="top"]) .loadingSet{
	z-index: 1;
}
body:not([data-page="top"]) .loadingCircle.-orange{
	z-index: 2;
}
body:not([data-page="top"]) .loadingCircle.-blue{
	z-index: 3;
}
body:not([data-page="top"]) .loadingCircle.-white{
	z-index: 4;
}


body:not([data-page="top"]).--is-loading .loadingCircle.-orange{
	animation-delay: .5s;
}
body:not([data-page="top"]).--is-loading .loadingCircle.-blue{
	animation-delay: .3s;
}
body:not([data-page="top"]).--is-loading .loadingCircle.-white{
	animation-delay: 0s;
}
body:not([data-page="top"]).--is-loading .loading_chara{
	animation-delay: 1.1s;
}
body:not([data-page="top"]).--is-loading .loading{
	animation-delay: 0.7s;
	animation: unset;
}






/**
* 下層ページアニメーション - _setting
**/
.mainNavWrap{
	transform: translateY(-100%);
	transition: transform .6s ease;
}
.mainContent{
	opacity: 0;
	transition: opacity .4s ease;
}

.mainHead__logo{
	transform: scale(50%);
	opacity: 0;
	transition: transform .4s cubic-bezier(.54,1.82,.81,1.06), opacity .3s ease;
}

.mainHead__txt-num span,
.mainHead__title-en span{
	display: inline-block;
	transition: transform .4s ease-in-out;
	transform: translateY(100%);
}
.mainHead__title-ja span{
	display: inline-block;
	transition: transform .4s ease-in-out, opacity .4s ease-in-out;
	transform: translateY(100%);
	opacity: 0;
}


.mainHead__txt-num span:nth-of-type(1),
.mainHead__title-en span:nth-of-type(1),
.mainHead__title-ja span:nth-of-type(1){
	transition-delay: .2s;
}
.mainHead__txt-num span:nth-of-type(2),
.mainHead__title-en span:nth-of-type(2),
.mainHead__title-ja span:nth-of-type(2){
	transition-delay: .25s;
}
.mainHead__txt-num span:nth-of-type(3),
.mainHead__title-en span:nth-of-type(3),
.mainHead__title-ja span:nth-of-type(3){
	transition-delay: .3s;
}
.mainHead__txt-num span:nth-of-type(4),
.mainHead__title-en span:nth-of-type(4),
.mainHead__title-ja span:nth-of-type(4){
	transition-delay: .35s;
}
.mainHead__txt-num span:nth-of-type(5),
.mainHead__title-en span:nth-of-type(5),
.mainHead__title-ja span:nth-of-type(5){
	transition-delay: .4s;
}
.mainHead__txt-num span:nth-of-type(6),
.mainHead__title-en span:nth-of-type(6),
.mainHead__title-ja span:nth-of-type(6){
	transition-delay: .45s;
}
.mainHead__txt-num span:nth-of-type(7),
.mainHead__title-en span:nth-of-type(7),
.mainHead__title-ja span:nth-of-type(7){
	transition-delay: .5s;
}
.mainHead__txt-num span:nth-of-type(8),
.mainHead__title-en span:nth-of-type(8),
.mainHead__title-ja span:nth-of-type(8){
	transition-delay: .55s;
}
.mainHead__txt-num span:nth-of-type(9),
.mainHead__title-en span:nth-of-type(9),
.mainHead__title-ja span:nth-of-type(9){
	transition-delay: 0.6s;
}
.mainHead__txt-num span:nth-of-type(10),
.mainHead__title-en span:nth-of-type(10),
.mainHead__title-ja span:nth-of-type(10){
	transition-delay: 0.65s;
}
.mainHead__txt-num span:nth-of-type(11),
.mainHead__title-en span:nth-of-type(11),
.mainHead__title-ja span:nth-of-type(11){
	transition-delay: 0.7s;
}
.mainHead__txt-num span:nth-of-type(12),
.mainHead__title-en span:nth-of-type(12),
.mainHead__title-ja span:nth-of-type(12){
	transition-delay: 0.75s;
}
.mainHead__txt-num span:nth-of-type(13),
.mainHead__title-en span:nth-of-type(13),
.mainHead__title-ja span:nth-of-type(13){
	transition-delay: 0.8s;
}

.mainHead__txt-numTitle,
.mainHead__txt-numAll{
	overflow: hidden;
}
.mainHead__txt-numTitle span,
.mainHead__txt-numAll span{
	display: inline-block;
	transform: translateY(100%);
	transition: transform .4s ease-in-out;
}

.mainHead__txt-numAll:before{
	/* top: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent)));
	bottom: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent))); */
	top: 50%;
	bottom: 50%;
	transition: .3s ease;
}

.mainHead:after{
	transform: translateY(50%) rotateX(20deg);
	opacity: 0;
	transition: opacity .4s ease, transform .5s ease;
}


/**
* 下層ページアニメーション - _active
**/
body.--is-loaded .mainNavWrap{
	transform: translateY(0%);
	/* transition-delay: .2s; */
}
body.--is-loaded .mainContent{
	opacity: 1;
	transition-delay: .3s;
}



body.--is-loaded .mainHead__txt-num span,
body.--is-loaded .mainHead__title-en span,
body.--is-loaded .mainHead__txt-numTitle span,
body.--is-loaded .mainHead__txt-numAll span{
	transform: translateY(0%);
}
body.--is-loaded .mainHead__title-ja span{
	transform: translateY(0%);
	opacity: 1;
}
body.--is-loaded .mainHead__txt-numAll:before{
	top: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent)));
	bottom: min(calc(2 / var(--vw-min) * 100vw), calc(2px * var(--max-percent)));
}

body.--is-loaded .mainHead__logo{
	transform: scale(100%);
	opacity: 1;
	transition-delay: .1s;
}
body.--is-loaded .mainHead:after{
	transform: translateY(0%) rotateX(0deg);
	opacity: 1;
	transition-delay: .1s;
}



/*-----------------------------------------------
 * page transition
-------------------------------------------------*/
.pTranAniElement{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10002;
	display: none;
}
:root{
	--mouseClientX:50%;
	--mouseClientY:50%;
}
.pTranAni_circle{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.pTranAni_circle.-orange{
	background-color: var(--color-orange);
}
.pTranAni_circle.-blue{
	background-color: var(--color-blue);
}
.pTranAni_circle.-white{
	background-color: #fafaeb;
}


@keyframes ani_pt_circle {
	0% {
		clip-path: circle(0px at var(--mouseClientX) var(--mouseClientY));
	}
	100% {
		clip-path:circle(min(250vh,250vw) at var(--mouseClientX) var(--mouseClientY));
	}
}
.pTranAni_circle {
	clip-path: circle(0px at var(--mouseClientX) var(--mouseClientY));
	animation: ani_pt_circle 0.8s ease forwards;
	animation-play-state: paused;
}

body.--is-transition .pTranAni_circle{
	animation-play-state: running;
}

body.--is-transition .pTranAni_circle.-orange{
	animation-delay: .05s;
}
body.--is-transition .pTranAni_circle.-blue{
	animation-delay: .35s;
}
body.--is-transition .pTranAni_circle.-white{
	animation-delay: .55s;
}
body.--is-transition{
	cursor: wait;
}