@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;color:#000;}
/*-----------------------------------------------
 * Bace
 * Modal
 * Header
 * Parts
-------------------------------------------------*/
/*-----------------------------------------------
 * Bace
-------------------------------------------------*/
:root{
	/* color */
	--color-main-yellow: #ffd200;
	--color-main-red: #c30a14;
	--color-main-blue: #0082c6;

	/* min-ww */
	--min-ww: 1200;
	--min-wh: 640;

	--max-percent: 1.6;

	/* font */
	--font: source-han-sans-japanese, sans-serif;
	--font-en: "urw-din-condensed", 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-44: min(5.8667vw, 44px);
	--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: 767px){
	:root{
		/* min-ww */
		--min-ww: 750;
		--min-wh: 1280;
	}
}
@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: #000;
	font-family: source-han-sans-japanese, "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
	font-size: 14px;
	font-weight: normal;
	letter-spacing: 0.05em;
	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: #202020;
	color: #fff;
}
::-moz-selection{
	background: #202020;
	color:#fff;
}
@media screen and (max-width:767px){ 
	html{ 
		font-size: 62.5%;
	}
	body{
		font-size: 10px; 
		font-size: 1rem;
		min-width: 320px;
	}
	.sp{ display: block; }
	.pc{ display: none; }
	.ah:hover { opacity: 1; }
}


/* ScrollBar Setting */
::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}
::-webkit-scrollbar-track {
  border-radius: 4px;
  background: rgb(0, 0, 0);
}
::-webkit-scrollbar-thumb {
	background: var(--color-main-orange);
	border-radius: 2px;
	margin: 2px;
	box-shadow: none;
}
/* firefox Only Scrollbar */
@-moz-document url-prefix() {
	html{
		scrollbar-color: var(--color-main-orange) rgb(0, 0, 0);
		scrollbar-width: thin;
	}
}

#fullWrap{
	width: 100%;
	min-height: 100vh;
	position: relative;
}


/*-----------------------------------------------
 * NAVLIST - NO
-------------------------------------------------*/
/* TOP */
.headerNavLists .navList[data-nav="top"]::before,
.cont_h2[data-nav="top"]::before{
	content: '';
}

/* NEWS */
.headerNavLists .navList[data-nav="news"]::before,
.cont_h2[data-nav="about"]::before{
	content: '01';
}

/* INTRODUCTION */
.headerNavLists .navList[data-nav="introduction"]::before,
.cont_h2[data-nav="concept"]::before{
	content: '02';
}

/* STORY */
.headerNavLists .navList[data-nav="story"]::before,
.cont_h2[data-nav="viewpoint"]::before{
	content: '03';
}

/* CHARACTER */
.headerNavLists .navList[data-nav="character"]::before,
.cont_h2[data-nav="service"]::before{
	content: '04';
}

/* STAFFCAST */
.headerNavLists .navList[data-nav="staffcast"]::before,
.cont_h2[data-nav="join"]::before{
	content: '05';
}

/* MUSIC */
.headerNavLists .navList[data-nav="music"]::before,
.cont_h2[data-nav="consultation"]::before{
	content: '06';
}

/* MOVIE */
.headerNavLists .navList[data-nav="movie"]::before,
.cont_h2[data-nav="movie"]::before{
	content: '08';
}

/* ONAIR */
.headerNavLists .navList[data-nav="onair"]::before,
.cont_h2[data-nav="onair"]::before{
	content: '09';
}

/* Blu-ray */
.headerNavLists .navList[data-nav="pkg"]::before,
.cont_h2[data-nav="pkg"]::before{
	content: '10';
}

/* GALLERY */
.headerNavLists .navList[data-nav="gallery"]::before,
.cont_h2[data-nav="gallery"]::before{
	content: '09';
}

/* GOODS */
.headerNavLists .navList[data-nav="goods"]::before,
.cont_h2[data-nav="goods"]::before{
	content: '11';
}

/* COMICS */
.headerNavLists .navList[data-nav="comics"]::before,
.cont_h2[data-nav="comics"]::before{
	content: '12';
}

/* SPECIAL */
.headerNavLists .navList[data-nav="special"]::before,
.cont_h2[data-nav="special"]::before{
	content: '13';
}

/*-----------------------------------------------
 * Modal
-------------------------------------------------*/

/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox{
	-webkit-overflow-scrolling: touch;
	background: var(--color-main-orange);
	display: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
.modalBox:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../images/common/bg_txtur.png) repeat center / 1200px 863px;
}
.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:767px){
	.oneModalIn{
		min-width: 100%;
	}
	.oneModalIn__cont{
		width: 100%;
		padding: var(--sp-size-48) 0;
	}
}

/**
 * closeBtn
 */
.closeBtn{
	width: 80px;
	height: 80px;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 2;
	overflow: hidden;
}
.closeBtn a{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	pointer-events: auto;
	transform: skewY(345deg);
	transform-origin: top left;
	background-color: #000;
}

.closeBtn__lineWrap {
	width: 50%;/* 40 */
	height: 15%;/* 12 */
	position: relative;
	z-index: 2;
}
.closeBtn--line {
	background-color: var(--color-main-orange);
	display: block;
	width: 100%;
	height: 2px;
	margin: auto;
	position: absolute;
	transition: top .4s ease, bottom .4s ease, transform .4s ease .2s, background-color .4s ease;
}
.closeBtn--line:nth-child(1) {
	top: calc(50% - 1px);
	bottom: calc(50% - 1px);
	transform: rotate(30deg);
}
.closeBtn--line:nth-child(2) {
	top: calc(50% - 1px);
	bottom: calc(50% - 1px);
	transform: rotate(-30deg);
}
@media (hover: hover) and (pointer: fine){
	.closeBtn a:hover .closeBtn--line:nth-child(1){
		top: 0;
		bottom: calc(100% - 2px);
		transform: rotate(0deg);
		transition: top .4s ease, bottom .4s ease, transform .4s ease, background-color .4s ease;
	}
	.closeBtn a:hover .closeBtn--line:nth-child(2) {
		top: calc(100% - 2px);
		bottom: 0;
		transform: rotate(0deg);
		transition: top .4s ease, bottom .4s ease, transform .4s ease, background-color .4s ease;
	}
}
@media screen and (max-width: 767px){
	.closeBtn{
		width: var(--sp-size-96);
		height: var(--sp-size-96);
	}
}


/**
 * iframe
 */
/* common */
.commonIframe{
	width: 100%;
	height: 100%;
	display: block;
}

/* youtube */
.youtubeIframeWrap {
	width: 70%;
	max-width: 159.993vh;
	position: relative;
}
@media screen and (max-width:767px){
	.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;
}


/*-----------------------------------------------
 * Header
-------------------------------------------------*/
.header {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 999;
}

/* inner */
.header__inner {
	min-height: 100vh;
	min-height: 100dvh;
	position: absolute;
	width: 100%;
	padding: 0;
	display: block;
	pointer-events: auto;
	transform: translateX(100%);
	transition: transform 0.3s ease;
	overflow: auto;
	overscroll-behavior: contain;
	bottom: 0;
	left: 0;
    top: 0;
	z-index: 2;
	padding: 40px 3.3334%;
}
.header.is-active .header__inner {
	transform: translateX(0%);
}

.headerLogo{
	width: 35.7143%;/* 400 */
}
.headerLogo img{
	width: 100%;
}

.header_linkContents{
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding-right: 80px;
	padding-top: 20px;
}

.header_linkCont{
	display: flex;
	align-items: center;
	padding: 0 20px;
}
.header_linkCont:first-of-type{
	padding-left: 40px;
}
.header_linkCont:last-of-type{
	padding-right: 40px;
}
.header_linkCont__title{
	font-family: var(--font-en);
	font-size: 12px;
	font-weight: 300;
	line-height: 1;
	letter-spacing: 1px;
	margin-right: 12px;
}
.header_linkCont__title > span{
	position: relative;
	display: inline-block;
	padding: 7px;
	border: 1px #FAD689 solid;
	background: #330066;
	color: #FFF;
}

@media (hover: hover) and (pointer: fine){
	.headerLogo a{
		display: block;
		transition: transform .2s ease;
	}
	.headerLogo a:hover{
		transform: rotate(-3.75deg) scale(105%);
	}
}

@media screen and (max-width: 767px){
	.header__inner {
		padding: 6.4% 6.4% 25.6% 3.2%;/* 48 48 192 24 */
	}
	.header__innerCont{
		width: 100%;
		display: flex;
		flex-wrap: wrap;
	}
	.headerLogo{
		width: 56.9322%;/* 386 */
		padding-bottom: var(--sp-size-96);
	}

	.header_linkContents{
		position: relative;
		flex-direction: column;
		justify-content: unset;
		align-items: flex-end;
		padding-top: 0;
		padding-right: 0;
		margin-left: auto;
		min-width: calc(150 / var(--min-ww) * 100vw);
	}
	.header_linkCont{
		display: block;
		padding: 0;
	}
	.header_linkCont:first-of-type{
		padding-left: 0px;
		padding-bottom: 0;
	}
	.header_sns{
		order: 2;
		padding-top: var(--sp-size-56);
	}
	.header_sns .comSNSLists{
		margin-top: var(--sp-size-24);
	}
	.header_linkCont:last-of-type{
		padding-right: 0;
	}
	.header_linkCont__title{
		font-size: var(--sp-size-20);
		margin-right: 0;
		text-align: right;
	}
	.header_linkCont__title > span{
		padding: var(--sp-size-4);
	}
}


/**
 * headerNav
 */
.headerNav {
	position: relative;
	z-index: 1;
	padding-top: min(5.7143%, 64px);
	padding-left: 20px;
}
.headerNavLists{
	height: calc(76px * 5);
	display: inline-flex;
    flex-direction: column;
    flex-wrap: wrap;
}
@media screen and (max-width: 851px){
	.headerNavLists{
		height: calc(76px * 7);
	}
}
.headerNavLists .navList{
	display: inline-block;
	padding: 0 40px 0 20px;
	margin: 16px 0;
	line-height: 0.85;
	position: relative;
}
.headerNavLists .navList::before{
	position: absolute;
	top: 2px;
	left: 0;
	padding-top: 4px;
	font-family: var(--font-en);
	font-size: 10px;
	font-weight: 700;
	line-height: 0.85;
	letter-spacing: 0;
	display: inline-block;
	color: #FF6B00;
	border-top: 1px solid #FF6B00;
}
.headerNavLists .navList > a{
	display: inline-block;
	text-decoration: none;
	font-family: var(--font-en);
	font-size: 44px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 0.85;
	color: #FFF;
	transition: .3s ease;
	position: relative;
}
.headerNavLists .navList > a span{
	position: relative;
	z-index: 2;
}
.headerNavLists .navList > a::before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(#000, #000) right bottom / 0 100% no-repeat;
	transition: background-size .3s ease;
}
@media (hover: hover) and (pointer: fine){
	.headerNavLists .navList > a:hover{
		color:  #FFF;
	}
	.headerNavLists .navList > a:hover::before {
		background-position: left bottom;
		background-size: 100% 100%;
	}
}
.headerNavLists .navList > a.is-active{
	color: var(--color-main-orange);
}
.headerNavLists .navList > a.is-active::before {
	background-position: left bottom;
	background-size: 100% 100%;
}

@media screen and (max-width: 767px){
	.headerNav {
		padding-top: 0;
		padding-left: 0;
	}
	.headerNavLists{
		height: auto;
	}
	.headerNavLists .navList{
		padding: 0 var(--sp-size-24) 0 var(--sp-size-48);
		margin: var(--sp-size-24) 0;
	}
	.headerNavLists .navList:first-of-type{
		margin-top: 0;
	}
	.headerNavLists .navList:before{
		left: var(--sp-size-16);
		padding-top: var(--sp-size-8);
		border-top-width: var(--sp-size-2);
		font-size: var(--sp-size-20);
	}
	.headerNavLists .navList > a{
		font-size: calc(67 / var(--min-ww) * 100vw);
	}
}


/**
 * header__bgWrap
 */
.header__bgWrap{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: unset;
	z-index: 1;
	background: var(--color-main-orange);
	overflow: hidden;
}
.header__bgWrap:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../images/common/bg_txtur.png) repeat center / 1200px 863px;
	opacity: 0;
	transition: opacity .3s ease;
}
.header__bgInWrap{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 33.3334%;/* 400 */
	min-width: min(401px, 100%);
	background: url(../images/common/nav_bg.png) no-repeat right bottom / contain;
}
@supports (background-image: url(../images/common/nav_bg.webp)){
	.header__bgInWrap{
		background-image: url(../images/common/nav_bg.webp);
	}
}
.header.is-active .header__bgWrap:before{
	opacity: 1;
	transition: .6s ease .2s;
}

@media screen and (max-width: 767px){
	.header__bgInWrap{
		width: 53.3334%;/* 400 */
		min-width: unset;
	}
}


/**
 * navBtn
 */
.header__navBtnWrap {
	width: 80px;
	height: 80px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	overflow: hidden;
}
.header__toTOP{
	width: 80px;
	height: 80px;
	position: fixed;
	bottom: 0;	
	left: 0;
	z-index: 2;
	overflow: hidden;
}
body.--navOpen .header__navBtnWrap{
	position: fixed;
}
.header__navBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	pointer-events: auto;
	transform: skewY(345deg);
	transform-origin: top left;
	background-color: var(--color-main-orange);
}
.header__toTOP .header__navBtn{
	transform: skewY(345deg);
	transform-origin: bottom right;
	background: var(--web-bg2);
	color: #FFF;
	text-decoration: none;
}

.header__navBtn::before{
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	right: 50%;
	bottom: 0;
	transition: .4s ease;
	background-color: #000;
}
.header__toTOP .header__navBtn::before{
	content: '';
	position: absolute;
	top: 20%;
	left: 50%;
	right: 50%;
	bottom: 0;
	transition: .4s ease;
	background-color: #000;
	text-align: center;
}
.header__toTOP:hover .header__navBtn::before{
	content: 'TOP';
}
.header__navBtn__lineWrap {
	width: 50%;/* 40 */
	height: 15%;/* 12 */
	position: relative;
	z-index: 2;
}
.header__navBtn--line {
	background-color: #fff;
	display: block;
	width: 100%;
	height: 2px;
	margin: auto;
	position: absolute;
	transition: top .4s ease, bottom .4s ease, transform .4s ease .2s, background-color .4s ease;
}
.header__navBtn--line:nth-child(1) {
	top: 0;
	bottom: calc(100% - 2px);
}
.header__navBtn--line:nth-child(2) {
	top: calc(100% - 2px);
	bottom: 0;
}

/* is-active */
.header__navBtn.is-active::before{
	left: 0;
	right: 0;
}
/* is-active */
.header__navBtn.is-active .header__navBtn--line:nth-child(1),
.header__navBtn.is-active .header__navBtn--line:nth-child(2){
	top: calc(50% - 1px);
	bottom: calc(50% - 1px);
	background-color: var(--color-main-orange);
}
.header__navBtn.is-active .header__navBtn--line:nth-child(1){
	transform: rotate(30deg);
}
.header__navBtn.is-active .header__navBtn--line:nth-child(2){
	transform: rotate(-30deg);
}

@media (hover: hover) and (pointer: fine){
	.header__navBtn:hover::before{
		left: 0;
		right: 0;
	}
	.header__navBtn.is-active:hover .header__navBtn--line:nth-child(1){
		top: 0;
		bottom: calc(100% - 2px);
		transform: rotate(0deg);
		transition: top .4s ease, bottom .4s ease, transform .4s ease, background-color .4s ease;
	}
	.header__navBtn.is-active:hover .header__navBtn--line:nth-child(2) {
		top: calc(100% - 2px);
		bottom: 0;
		transform: rotate(0deg);
		transition: top .4s ease, bottom .4s ease, transform .4s ease, background-color .4s ease;
	}
}

@media screen and (max-width: 767px){
	.header__navBtnWrap {
		width: var(--sp-size-96);
		height: var(--sp-size-96);
	}
}


/**
* HEADER ANIMATION
**/
/* headerLogo */
.headerLogo{
	opacity: 0;
	transform: translateX(50%);
	transition: transform .3s ease, opacity .3s ease;
}
.header.is-active .headerLogo{
	opacity: 1;
	transform: translateX(0%);
	transition-delay: .3s;
}

/* headerNavLists -> navList */
.headerNavLists .navList{
	opacity: 0;
	transform: translate(20px, 10px);
	transform-origin: left bottom;
	transition: transform .4s ease, opacity .4s ease;
}
.header.is-active .headerNavLists .navList:nth-of-type(1){
	transition-delay: .45s;
}
.header.is-active .headerNavLists .navList:nth-of-type(2){
	transition-delay: .5s;
}
.header.is-active .headerNavLists .navList:nth-of-type(3){
	transition-delay: .55s;
}
.header.is-active .headerNavLists .navList:nth-of-type(4){
	transition-delay: .6s;
}
.header.is-active .headerNavLists .navList:nth-of-type(5){
	transition-delay: .65s;
}
.header.is-active .headerNavLists .navList:nth-of-type(6){
	transition-delay: .7s;
}
.header.is-active .headerNavLists .navList:nth-of-type(7){
	transition-delay: .75s;
}
.header.is-active .headerNavLists .navList:nth-of-type(8){
	transition-delay: .8s;
}
.header.is-active .headerNavLists .navList:nth-of-type(9){
	transition-delay: .85s;
}
.header.is-active .headerNavLists .navList:nth-of-type(10){
	transition-delay: .9s;
}
.header.is-active .headerNavLists .navList:nth-of-type(11){
	transition-delay: .95s;
}
.header.is-active .headerNavLists .navList:nth-of-type(12){
	transition-delay: 1s;
}
.header.is-active .headerNavLists .navList:nth-of-type(13){
	transition-delay: 1.05s;
}

.header.is-active .headerNavLists .navList{
	opacity: 1;
	transform: translate(0, 0);
}


/* header_linkCont */
.header_linkContents .header_linkCont{
	opacity: 0;
	transform: translateY(50%);
	transition: transform .4s ease, opacity .4s ease;
}
.header.is-active .header_linkContents .header_linkCont:nth-of-type(1){
	transition-delay: .4s;
}
.header.is-active .header_linkContents .header_linkCont:nth-of-type(2){
	transition-delay: .5s;
}
.header.is-active .header_linkContents .header_linkCont{
	opacity: 1;
	transform: translateY(0%);
}


/* header__bgInWrap */
.header__bgInWrap{
	opacity: 0;
	transform: translate(20%, 20%) rotate(-7.5deg);
	transition: transform .3s ease, opacity .3s ease;
}
.header.is-active .header__bgInWrap{
	opacity: 1;
	transform: translate(0%, 0%) rotate(0deg);
	transition-delay: .3s;
}


/*-----------------------------------------------
 * common Animation
-------------------------------------------------*/
@keyframes ani_rotate360 {
	0%	{transform: rotate(0deg)}
	100%{transform: rotate(360deg)}
}



/*-----------------------------------------------
 * Parts
-------------------------------------------------*/

/**
 * shareLists
 */
.shareLists {
	display: flex;
}

/* item */
.shareLists__item {
	width: 40px;
	height: 40px;
}

/* link */
.shareLists__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
	background-color: #000;
	transition: background-color .4s ease;
}
.shareLists__link:before {
	content: "";
	width: 50%;
	height: 50%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	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%;
}

@media (hover: hover) and (pointer: fine){
	.shareLists__link:hover{
		background: var(--color-main-orange);
	}
}

/*
.shareLists__item.is-twitter { background: url("../images/common/icon_tw.svg") 0 0 / 100% 100% no-repeat;}
.shareLists__item.is-facebook { background: url("../images/common/icon_fb.svg") 0 0 / 100% 100% no-repeat;}
.shareLists__item.is-line { background: url("../images/common/icon_line.svg") 0 0 / 100% 100% no-repeat;}

.shareLists__item.is-twitter .shareLists__link::before {
	-webkit-mask-image: url(../images/common/icon_tw.svg);
	mask-image: url(../images/common/icon_tw.svg);
}
.shareLists__item.is-facebook .shareLists__link::before {
	-webkit-mask-image: url(../images/common/icon_fb.svg);
	mask-image: url(../images/common/icon_fb.svg);
}
.shareLists__item.is-line .shareLists__link::before {
	-webkit-mask-image: url(../images/common/icon_line.svg);
	mask-image: url(../images/common/icon_line.svg);
}
*/
.shareLists__item.is-twitter .shareLists__link::before { background: url("../images/common/icon_tw.svg") 0 0 / 100% 100% no-repeat;}
.shareLists__item.is-facebook .shareLists__link::before { background: url("../images/common/icon_fb.svg") 0 0 / 100% 100% no-repeat;}
.shareLists__item.is-instagram .shareLists__link::before { background: url("../images/common/icon_ig.svg") 0 0 / 100% 100% no-repeat;}
.shareLists__item.is-line .shareLists__link::before { background: url("../images/common/icon_line.svg") 0 0 / 100% 100% no-repeat;}

@media screen and (max-width: 767px){
	/* item */
	.shareLists__item {
		width: var(--sp-size-72);
		height: var(--sp-size-72);
	}
}






/*-----------------------------------------------
 * contBG
-------------------------------------------------*/
#fullContentsWrap{
	position: relative;
	width: 100%;
}
.fullContentsIn{
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
.main{
	position: relative;
}


.fullContentFixed{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.fullContentFixed.-z2{
	z-index: 1000;
	pointer-events: none;
}
.fullContentFixedIn{
	position: sticky;
	top: 0;
	width: 100%;
	height: min(100%, 100vh);
}
body:not([data-page="top"]) .fullContentFixedIn{
	position: absolute;
}
body:not([data-page="top"]) .fullContentFixed.-z2 .fullContentFixedIn{
	position: sticky;
}

.contBG__title{
	position: absolute;
	top: 0;
	left: 0;
	width: 74.1667%;/* 890 */
	max-width: calc(890px * var(--max-percent));
	height: max(50.9375vh, 326px);/* 326 */
	background: url(../images/common/bg_side_enTitle.svg) no-repeat left top / contain;
	pointer-events: none;
	opacity: 50%;
}

.contBG__titleImg{
	position: absolute;
	top: 0;
	left: 0;
	pointer-events: none;
	width: min(calc(888.719 / var(--min-ww) * 100vw), calc(888.719px * var(--max-percent)));
	height: min(calc(323 / var(--min-ww) * 100vw), calc(323px * var(--max-percent)));
	opacity: 50%;
}
@media screen and (max-width: 767px){
	.contBG__titleImg{
		width: calc(667 / var(--min-ww)* 100vw);
		height: calc(245 / var(--min-ww)* 100vw);
	}
}

.contBG__titleImg-svg{
	width: 100%;
	height: 100%;
}
.contBG__titleImg-svg .svg-elem-1{
	stroke-dashoffset: 8208.75390625px;
	stroke-dasharray: 8208.75390625px;
	transition: stroke-dashoffset 1.2s cubic-bezier(0.895, 0.03, 0.685, 0.22) 0s;
}

html.wf-active body:not([data-page="top"]).--is-loaded .contBG__titleImg-svg .svg-elem-1{
	stroke-dashoffset: 0;
	transition-delay: .8s;
}


.contBG__color{
	position: fixed;
	top: 0;
	width: 100%;
	height: 100%;
	padding-top: calc(calc(var(--res-wh) / 2) - calc((320 / var(--min-ww) * var(--res-ww)) / 2));
	transform: scale(-1, 1);
    overflow: hidden;
}
.contBG__colorIn{
	width: 100%;
	height: 100%;
	transform: skewY(15deg);
	transform-origin: left top;
	position: relative;
	overflow: hidden;
}
.contBG__color--cont{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	background: var(--color-main-orange);
}
.contBG__color--cont:before{
	content: '';
	position: absolute;
	top: -50%;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../images/common/bg_txtur.png) repeat center / 1200px 863px;
	transform: skewY(-15deg) scale(-1, 1);
}

.contFixed__logo{
	position: absolute;
	top: 0;
	left: 0;
	margin-top: 4px;
	margin-left: 2%;
	width: min(18%, 280px);/* 200 */
	transition: opacity .3s ease;
}
body:not([data-page="top"]) .contFixed__logo{
	pointer-events: auto;
}
.contFixed__logo img{
	width: 100%;
}
body.--navOpen .contFixed__logo{
	pointer-events: none;
	opacity: 0;
}
@media (hover: hover) and (pointer: fine){
	.contFixed__logo a{
		transition: transform .2s ease;
		display: block;
	}
	.contFixed__logo a:hover{
		transform: scale(105%);
	}
}

@media screen and (max-width: 767px){
	.contBG__title{
		width: calc(667 / var(--min-ww) * 100vw);
		max-width: 100%;
		height: calc(245 / var(--min-ww) * 100vw);
	}
	.contBG__color{
		padding-top: calc(380 / var(--min-ww) * 100vw);
		margin: 0 auto;
	}
	body:not([data-page="top"]) .contBG__color{
		position: absolute;
	}
	.contBG__colorIn{
		height: max(110%, 100vh);
		transform-origin: center top;
	}
	.contFixed__logo{
		width: 38.6667%;/* 290 */
		margin-top: 3.2%;
		margin-left: 3.2%;
	}
	body[data-page="top"] .contFixed__logo{
		display: none;
	}
}



/**
* comBtn
**/
.link_combtnWrap{
	position: relative;
}
.link_combtn{
	display: inline-block;
	text-align: center;
	padding: 14px 48px;
	min-width: 200px;
	text-align: center;
	font-family: var(--font-en);
	letter-spacing: 0;
	font-size: 16px;
	text-decoration: none;
	background-color: #000;
	color: #FFF;
	line-height: 1;
	position: relative;
}
.link_combtn.-ja{
	font-family: var(--font);
}
.link_combtn--txt{
	position: relative;
}
.link_combtn.-r .link_combtn--arrow{
	position: absolute;
	top: 0;
	right: 15px;
	bottom: 0;
	margin: auto 0;
	width: 16px;
	height: 21px;
	-webkit-mask: url(../images/common/arrow_r.svg) no-repeat center / contain;
	mask: url(../images/common/arrow_r.svg) no-repeat center / contain;
	background-color: #FFF;
	transition: .3s ease;
}
.link_combtn.-l .link_combtn--arrow{
	position: absolute;
	top: 0;
	left: 15px;
	bottom: 0;
	margin: auto 0;
	width: 16px;
	height: 21px;
	-webkit-mask: url(../images/common/arrow_l.svg) no-repeat center / contain;
	mask: url(../images/common/arrow_l.svg) no-repeat center / contain;
	background-color: #FFF;
	transition: .3s ease;
}
.link_combtn--icon_blank{
	position: absolute;
	top: 0;
	right: 15px;
	bottom: 0;
	margin: auto 0;
	width: 12px;
	height: 12px;
	-webkit-mask: url(../images/common/icon_blank.svg) no-repeat center / contain;
	mask: url(../images/common/icon_blank.svg) no-repeat center / contain;
	background-color: #888888;
	transition: .3s ease;
}

@media screen and (max-width: 767px){
	.link_combtn{
		padding: var(--sp-size-26) var(--sp-size-72);
		min-width: calc(366 / var(--min-ww) * 100vw);
		font-size: var(--sp-size-24);
	}
	.link_combtn.-r .link_combtn--arrow{
		right: 0;
		width: var(--sp-size-72);
		height: var(--sp-size-12);
	}
	.link_combtn.-l .link_combtn--arrow{
		left: 0;
		width: var(--sp-size-72);
		height: var(--sp-size-12);
	}
	.link_combtn--icon_blank{
		right: 0;
		width: var(--sp-size-72);
		height: var(--sp-size-16);
	}
}

@media (hover: hover) and (pointer: fine){
	.link_combtn{
		transition: .3s ease;
	}
	.link_combtn:before{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(var(--color-main-orange), var(--color-main-orange)) right bottom / 0 100% no-repeat;
		transition: background-size 0.4s ease;
	}
	.link_combtn.-l:before{
		background-position: left bottom;
	}
	.link_combtn:hover{
		/* color: #000; */
	}
	.link_combtn:hover::before{
		background-size: 100% 100%;
		background-position: left bottom;
	}
	.link_combtn.-l:hover::before{
		background-size: 100% 100%;
		background-position: right bottom;
	}
	.link_combtn.-r:hover .link_combtn--arrow{
		transform: translateX(50%);
	}
	.link_combtn.-l:hover .link_combtn--arrow{
		transform: translateX(-50%);
	}
	.link_combtn:hover .link_combtn--icon_blank{
		background-color: #fff;
	}
	@media screen and (max-width: 767px){
		.link_combtn.-r:hover .link_combtn--arrow{
			transform: translateX(20%);
		}
		.link_combtn.-l:hover .link_combtn--arrow{
			transform: translateX(-20%);
		}
	}
}



/**
* comSNSLists
**/
.comSNSLists{
	display: inline-flex;
	position: relative;
}
.comSNSList{
	width: 40px;
	height: 40px;
}
.comSNSList > a{
	display: block;
	width: 100%;
	height: 100%;
	background-color: #FF6B00;
	position: relative;
}
.comSNSList > a::before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 50%;
	height: 50%;
	margin: auto;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: contain;
	mask-size: contain;
	background-color: #FFF;
}

.comSNSList > a.icon_sns__x::before{ background: url("../images/common/icon_tw.svg") 0 0 / 100% 100% no-repeat;}
.comSNSList > a.icon_sns__tt::before{ background: url("../images/common/icon_tiktok.svg") 0 0 / 100% 100% no-repeat;}
.comSNSList > a.icon_sns__fb::before{ background: url("../images/common/icon_fb.svg") 0 0 / 100% 100% no-repeat;}
.comSNSList > a.icon_sns__ig::before{ background: url("../images/common/icon_ig.svg") 0 0 / 100% 100% no-repeat;}
@media (hover: hover) and (pointer: fine){
	.comSNSList > a{
		transition: .3s ease;
	}
	.comSNSList > a:hover{
		background-color: var(--color-main-orange);
	}
}

@media screen and (max-width: 767px){
	/* comSNSList */
	.comSNSList {
		width: var(--sp-size-72);
		height: var(--sp-size-72);
	}
}




/*-----------------------------------------------
 * MAIN
-------------------------------------------------*/
.main{
	position: relative;
	width: 100%;
	padding-top: 80px;
	/*padding-bottom: 80px;*/
}

.contSection{
	width: 100%;
	position: relative;
	z-index: 2;
	padding: 80px 0;
}
.contSectionIn{
	width: 93.3334%;
	min-width: min(1120px, 100%);
	max-width: min(1120px * var(--max-percent));
	margin: 0 auto;
}

@media screen and (max-width: 767px){
	.main{
		padding-top: min(19.2vw, 144px);
		padding-bottom: var(--sp-size-96);
	}
	body[data-page="top"] .main{
		padding-top: var(--sp-size-48);
	}
	.contSection{
		padding: var(--sp-size-48) 0;
	}
	.contSectionIn{
		width: 100%;
		min-width: unset;
		max-width: 100%;
	}
}



.cont_h2{
	width: 100%;
	position: relative;
	padding: 0 3.5715%;/* 0 40 */
	display: flex;
	align-items: flex-end;
	line-height: 1;
}
.cont_h2::before{
	position: absolute;
	top: 0;
	left: calc(3.5715% - 20px);
	padding-top: 4px;
	font-family: var(--font-en);
	font-size: 10px;
	font-weight: 700;
	line-height: 0.85;
	letter-spacing: 0;
	display: inline-block;
	border-top: 1px solid #000;
}

.cont_h2--en{
	display: inline-block;
	font-family: var(--font-en);
	font-size: 56px;
	font-weight: 900;
	line-height: 0.8;
	letter-spacing: 0;
	position: relative;
}
.cont_h2--en:before{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	background: linear-gradient(180deg, transparent 0%, transparent 55%, #FFF 55%, #FFF 100%);
}
body:not([data-page="top"]) .cont_h2--en:before{
	background: linear-gradient(180deg, transparent 0%, transparent 55%, var(--color-main-orange) 55%, var(--color-main-orange) 100%);
}
.cont_h2--en span{
	position: relative;
}
.cont_h2--en span:before{
	position: absolute;
	z-index: -1;
}
.cont_h2.is-ani .cont_h2--en:before{
	background: linear-gradient(180deg, transparent 0%, transparent 55%, var(--color-main-orange) 55%, var(--color-main-orange) 100%);
}

.cont_h2--ja{
	display: block;
	margin-left: 16px;
	line-height: 1;
	font-size: 16px;
	font-weight: 700;
}
.cont_h2--ja > span{
	display: inline-block;
	padding: 4px;
	margin: 0 1px;
	background-color: #000;
	color: var(--color-main-orange);
}

@media screen and (max-width: 767px){
	.cont_h2{
		flex-direction: column;
		align-items: flex-start;
		padding: 0 var(--sp-size-48);
	}
	.cont_h2::before{
		left: var(--sp-size-16);
		padding-top: var(--sp-size-8);
		border-top-width: var(--sp-size-2);
		font-size: var(--sp-size-20);
	}
	.cont_h2--en{
		font-size: calc(100 / var(--min-ww) * 100vw);
	}
	.cont_h2--ja{
		margin-top: var(--sp-size-24);
		margin-left: 0;
		font-size: var(--sp-size-32);
	}
	.cont_h2--ja > span{
		margin: 0 var(--sp-size-2);
		padding: var(--sp-size-8);
	}
}


/**
* cont_h2-center
**/
.cont_h2-center{
	width: 100%;
	position: relative;
	padding: 0;
	text-align: center;
}
.cont_h2-center > .cont_h2{
	width: auto;
	display: inline-block;
}
.cont_h2-center > .cont_h2:before{
	left: calc(3.5715% + 20px);
}
.cont_h2-center .cont_h2--ja{
	margin-left: 0;
	margin-top: 15px;
}

@media screen and (max-width: 767px){
	.cont_h2-center > .cont_h2:before{
		left: var(--sp-size-16);
	}
	.cont_h2-center .cont_h2--ja{
		margin-top: var(--sp-size-24);
	}
}


/**
* CONT_SUBTITLE
**/
.cont_subTitle{
	width: 100%;
	position: relative;
	display: flex;
	align-items: flex-end;
	line-height: 1;
}
.cont_subTitle:before{
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 80px;
	height: 12px;
	background: url(../images/common/deco_subtitle.svg) no-repeat right top / contain;
}
.cont_subTitle--en{
	display: inline-block;
	font-family: var(--font-en);
	font-size: 56px;
	font-weight: 900;
	line-height: 0.8;
	letter-spacing: 0;
	flex-grow: 1;
	position: relative;
	padding-right: 10px;
}
.cont_subTitle--en:after{
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 1px;
	background-color: #000;
}
.cont_subTitle--ja{
	display: inline-block;
	position: relative;
	padding-left: 16px;
	font-size: 16px;
	font-weight: 700;
	flex-shrink: 0;
}

@media screen and (max-width: 767px){
	.cont_subTitle:before{
		width: var(--sp-size-80);
		height: var(--sp-size-12);
	}
	.cont_subTitle--en{
		font-size: calc(67 / var(--min-ww) * 100vw);
		padding-right: var(--sp-size-16);
	}
	.cont_subTitle--en:after{
		height: var(--sp-size-2);
	}
	.cont_subTitle--ja{
		padding-left: var(--sp-size-24);
		font-size: var(--sp-size-24);
	}
}


/**
* CONT_TxTTITLE
**/
.cont_txtTitle{
	font-size: 16px;
	font-weight: 700;
	color: #FFF;
}
.cont_txtTitle > span{
	display: inline-block;
	line-height: 1.1;
	background-color: #000;
}

.cont_txtTitle.-en{
	font-family: var(--font-en);
	font-weight: 900;
	letter-spacing: 0;
}
.cont_txtTitle.-en > span{
	line-height: 0.9;
}
.cont_txtTitle.-c_yellow{
	color: var(--color-main-orange);
}
@media screen and (max-width: 767px){
	.cont_txtTitle{
		font-size: var(--sp-size-24);
	}
}


/**
* PAGENAVI
**/
.pageNavLists{
	display: flex;
	justify-content: center;
	margin-top: 68px;
}
.pageNavList{
	width: 40px;
	height: 40px;
	margin: 12px;
}
.pageNavList__link{
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	font-family: var(--font-en);
	font-size: 16px;
	font-weight: 700;
	color: #FFF;
	letter-spacing: 0;
	position: relative;
	overflow: hidden;
	background-color: #000;
}
.pageNavList__link:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--color-main-orange);
	transform: scale(60%) skewY(345deg);
	opacity: 0;
	transition: opacity .3s ease, transform .4s ease .1s;
}
.pageNavList__link span{
	position: relative;
}

@media (hover: hover) and (pointer: fine){
	.pageNavList__link:hover::before{
		opacity: 100%;
		transform: scale(90%) skewY(352.5deg);
	}
}

.pageNavList__link.is-active:before{
	opacity: 1;
	transform: scale(100%) skewY(360deg);
}

@media screen and (max-width: 767px){
	.pageNavLists{
		margin-top: calc(84 / var(--min-ww) * 100vw);
	}
	.pageNavList{
		width: var(--sp-size-72);
		height: var(--sp-size-72);
		margin: var(--sp-size-12);
	}
	.pageNavList__link{
		font-size: var(--sp-size-24);
	}
	.pageNavList__link.is-active{
		color: var(--color-main-orange);
	}
}

/*-----------------------------------------------
 * Footer
-------------------------------------------------*/
.footer{
	width: 100%;
	position: relative;
	z-index: 2;
	margin-top: auto;
}
.footerIn{
	width: 100%;
	position: relative;
	padding-top: 160px;
	/*padding-bottom: 80px;*/
	overflow: hidden;
}
.footer_bt{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100px;
	height: 160px;
	display: flex;
	align-items: center;
	margin: 0 auto;
	z-index: 2;
}
.btn_footer_bt{
	display: block;
	position: relative;
	border-radius: 50%;
	width: 100px;
	height: 100px;
	text-decoration: none;
}
.footer_bt--circle{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	animation: ani_rotate360 12s linear infinite;
	animation-play-state: paused;
}
.footer_bt--circle:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/footer_backtotop__txt.svg) no-repeat center / contain;
	animation: ani_rotate360 16s linear infinite;
}
@media (hover: hover) and (pointer: fine){
	.btn_footer_bt:hover .footer_bt--circle{
		animation-play-state: running;
	}
}
.footer_bt--icon{
	width: 64%;
	height: 64%;
	background: url(../images/common/icon_sakamoto.svg) no-repeat center / contain;
	margin: auto;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.footer_tLines{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 160px;
	display: flex;
	align-items: center;
}
.footer_tLine{
	width: 100%;
	height: 1px;
	position: relative;
}
.footer_tLine:before,
.footer_tLine:after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: calc(50% - 66px);
	background-color: #000;
}
.footer_tLine:before{
	left: 0;
}
.footer_tLine:after{
	right: 0;
}


.footerContents{
	width: 100%;
	position: relative;
	padding: 0 2%;
	display: flex;
	flex-wrap: wrap;
}

.footerCont__title{
	font-family: var(--font-en);
	font-size: 12px;
	font-weight: 300;
	line-height: 1;
	letter-spacing: 1px;
}
.footerCont__title > span{
	position: relative;
	display: inline-block;
	padding: 7px;
	border: 1px #FAD689 solid;
	background: #330066;
	color: #FFF;
}

/** footer_comLists **/
.footer_comLists{
	display: flex;
	flex-wrap: wrap;
}

.footer_comLists .navList{
	display: inline-block;
	padding: 8px;
	line-height: 1;
}

.footer_comLists .navList > a{
	display: inline-block;
	text-decoration: none;
	font-family: var(--font-en);
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	color: #000;
	transition: .3s ease;
	position: relative;
}
.footer_comLists .navList > a span{
	position: relative;
	z-index: 2;
}
.footer_comLists .navList > a:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(#000, #000) right bottom / 0 100% no-repeat;
	transition: background-size .3s ease;
}
@media (hover: hover) and (pointer: fine){
	.footer_comLists .navList > a:hover{
		color:  #FFF;
	}
	.footer_comLists .navList > a:hover::before {
		background-position: left bottom;
		background-size: 100% 100%;
	}
}
.footer_comLists .navList > a.is-active{
	color: var(--color-main-orange);
}
.footer_comLists .navList > a.is-active::before {
	background-position: left bottom;
	background-size: 100% 100%;
}


/* footer - SITEMAP */
.footer_sitemapLists{
	height: calc(36px * 7);
	margin-top: 8px;
	padding-left: 8px;
	display: inline-flex;
	flex-direction: column;
	flex-wrap: wrap;
}


/**
* footerContent__center
**/
.footerContent__center{
	margin: 0 auto;
	padding-bottom: 40px;
}

/** footer_share **/
.footer_share{
	text-align: center;
}
.footer_share .footerCont__title{
	text-align: center;
}
.footer_share .shareLists{
	display: inline-flex;
	margin-top: 16px;
	background-color: #000;
}

/** p-footerLogoLists **/
.p-footerLogoLists{
	display: flex;
	justify-content: center;
	margin-top: 80px;
}
.p-footerLogoList{
	width: 120px;
	margin: 12px;
}
.p-footerLogoList a{
	display: block;
}
.p-footerLogoList img{
	width: 100%;
}
@media (hover: hover) and (pointer: fine){
	.p-footerLogoList a{
		transition: transform .2s ease;
	}
	.p-footerLogoList a:hover{
		transform: scale(108%);
	}
}



/**
* footerContent__end
**/
.footerContent__end{
	min-width: 320px;
	text-align: right;
}

/** footer_lang  **/
.footer_langLists{
	justify-content: flex-end;
	margin-top: 8px;
	padding-right: 8px;
}

/** footer_sns **/
.footer_sns{ /*margin-top: 40px;*/ }
.footer_sns .comSNSLists{
	margin-top: 16px;
	padding-right: 16px;
}


/**
* footer_copyright
**/
.footer_copyright{
	padding-top: 32px;
	text-align: center;
	font-size: 10px;
	line-height: 1;
}


/** NAVが増えたら調整 **/
@media screen and (min-width: 768px){
	.footer_sitemap,
	.footerContent__end{
		min-width: 288px;
	}
}


@media screen and (max-width: 767px){
	.footer{
		padding-top: var(--sp-size-48);
	}
	.footerIn{
		padding-top: 25.6%;/* 192 */
		padding-bottom: 12.8%;
	}
	.footer_bt{
		width: calc(120 / var(--min-ww) * 100vw);
		height: min(25.6vw, 192px);
	}
	.btn_footer_bt{
		width: calc(120 / var(--min-ww) * 100vw);
		height: calc(120 / var(--min-ww) * 100vw);
	}
	.footer_tLine{
		height: var(--sp-size-2);
	}
	.footer_tLines{
		height: min(25.6vw, 192px);
	}
	.footer_tLine:before,
	.footer_tLine:after{
		width: calc(50% - var(--sp-size-80));
	}


	.footerContents{
		padding: 0 var(--sp-size-24);
	}
	.footerCont__title{
		 font-size: var(--sp-size-20);
	}
	.footerCont__title > span{
		padding: var(--sp-size-4);
	}
	.footer_comLists .navList{
		padding: var(--sp-size-16) var(--sp-size-24);
	}
	.footer_comLists .navList > a{
		font-size: var(--sp-size-40);
	}

	/* footer - SITEMAP */
	.footer_sitemapLists{
		width: 100%;
		margin-top: var(--sp-size-8);
		padding-left: unset;
		height: calc(var(--sp-size-72) * 6);	
	}

	/**
	* footerContent__center
	**/
	.footerContent__center{
		order: 2;
		padding-top: var(--sp-size-96);
	}

	/** footer_share **/
	.footer_share .shareLists{
		margin-top: var(--sp-size-24);
	}
	
	/** p-footerLogoLists **/
	.p-footerLogoLists{
		margin-top: var(--sp-size-72);
	}
	.p-footerLogoList{
		width: calc(240 / var(--min-ww) * 100vw);
		margin: var(--sp-size-24);
	}

	/**
	* footerContent__end
	**/
	.footerContent__end{
		width: 100%;
		min-width: 100%;
		display: flex;
		padding-top: var(--sp-size-32);
	}

	/** footer_lang  **/
	.footer_lang{
		order: 2;
		margin-left: auto;
	}
	.header_langLists,
	.footer_langLists{
		justify-content: flex-end;
		margin-top: var(--sp-size-8);
		padding-right: 0;
	}
	.header_langLists .navList,
	.footer_langLists .navList{
		padding-right: 0;
	}

	/** footer_sns **/
	.footer_sns{
		margin-top: 0;
	}
	.footerContent__end .footer_sns .footerCont__title{
		text-align: left;
	}
	.footer_sns .comSNSLists{
		margin-top: var(--sp-size-24);
		padding-left: var(--sp-size-24);
		padding-left: unset;
	}
	

	/**
	* footer_copyright
	**/
	.footer_copyright{
		padding-top: var(--sp-size-72);
		font-size: var(--sp-size-20);
	}
}



/*-----------------------------------------------
 * CURSOR
-------------------------------------------------*/
@media screen and (min-width: 768px) and (hover: hover) and (pointer: fine){
	.cursor{
		position: fixed;
		width: 100px;
		height: 100px;
		mix-blend-mode: difference;
		z-index: 10001;
		pointer-events: none;
	}
	.cursorIn{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	.cursorType{
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
	}
	
	/* normal */
	.cursorType.-normal{
		width: 16px;
		height: 16px;
	}
	.cursorNormal{
		display: block;
		width: 100%;
		height: 100%;
		border-radius: 50%;
		background-color: #fff;
		transform: scale(100%);
		opacity: 1;
		transition: transform .4s ease, opacity .3s ease;
	}
	.cursor.is-hover .cursorNormal,
	.cursor.is-hover_movie .cursorNormal{
		transform: scale(20%);
		opacity: 0;
	}

	/* hover */
	.cursorType.-hover{
		width: 61px;
		height: 61px;
	}
	.cursorHover__circle{
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 100%;
		height: 100%;
		animation: ani_rotate360 16s linear infinite;
		animation-direction: reverse;
		animation-play-state: paused;
	}
	.cursorHover__circle span{
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transform: scale(0%);
		opacity: 0;
		background: url(../images/common/cursor_hover-circle.svg) no-repeat center / contain;
		transition: transform .4s ease, opacity .3s ease;
	}
	.cursorHover__center{
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
		width: 3px;
		height: 3px;
		background: url(../images/common/cursor_hover-center.svg) no-repeat center / contain;
		transform: scale(533%) rotate(30deg);
		opacity: 0;
		transition: transform .4s ease .2s, opacity .3s ease .2s;
	}

	.cursor.is-hover .cursorHover__circle{
		animation-play-state: running;
	}
	.cursor.is-hover .cursorHover__circle span{
		opacity: 1;
		transform: scale(100%);
		transition-delay: .2s, .2s;
	}
	.cursor.is-hover .cursorHover__center{
		opacity: 1;
		transform: scale(100%) rotate(0deg);
		transition-delay: .125s, 0s;
	}

	/* movieHover */
	.cursorType.-movie{
		width: 100%;
		height: 100%;
	}
	.cursorMovie{
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 100%;
		height: 100%;
		opacity: 0;
		transform: scale(20%);
		transition: transform .4s ease, opacity .3s ease;
	}
	.cursorMovie:before,
	.cursorMovie:after{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}
	.cursorMovie:before{
		width: 100%;
		height: 100%;
		background: url(../images/common/txt_playmovie.svg) no-repeat center / contain;
		animation: ani_rotate360 16s linear infinite;
		animation-play-state: paused;
	}
	.cursorMovie:after{
		width: 64%;
		height: 64%;
		-webkit-mask: url(../images/common/icon_sakamoto.svg) no-repeat center / contain;
		mask: url(../images/common/icon_sakamoto.svg) no-repeat center / contain;
		background-color: #fff;
		margin: auto;
	}
	
	.cursor.is-hover_movie .cursorMovie{
		opacity: 1;
		transform: scale(100%);
	}
	.cursor.is-hover_movie .cursorMovie:before{
		animation-play-state: running;
	}
}



/*-----------------------------------------------
 * LOADING
-------------------------------------------------*/
.cLoading{
	position: fixed;
	top: min(-25vh, -15vw);
	left: 0;
	right: 0;
	bottom: min(-25vh, -15vw);
	z-index: 1001;
	transform: skewY(-15deg);
}
.cLoading > span{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--color-main-orange);
}
.cLoading > span:after{
	content: '';
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	position: absolute;
	background-color: #000;
	transform: translateY(-100%);
}
@keyframes ani_load1 {
	0%{transform: translateY(0%);}
	100%{transform: translateY(100%);}
}
@keyframes ani_load2 {
	0%{transform: translateY(-100%);}
	100%{transform: translateY(0%);}
}
@keyframes ani_loaded {
	0%,99%{display: black;}
	100%{display: none;}
}
@keyframes ani_loaded__overflow {
	0%,99%{overflow: hidden;}
	100%{overflow: unset;}
}

/* TOP以外 */
body:not([data-page="top"]){
	overflow: hidden;
}
html.wf-active body:not([data-page="top"]).--is-loaded{
	animation: ani_loaded__overflow .8s linear forwards;
}
html.wf-active body:not([data-page="top"]).--is-loaded .cLoading > span:after{
	animation: ani_load2 .5s cubic-bezier(.66,.09,.22,1) forwards;
}
html.wf-active body:not([data-page="top"]).--is-loaded .cLoading > span{
	animation: ani_load1 .5s cubic-bezier(.66,.09,.22,1) forwards;
	animation-delay: .4s;
}
html.wf-active body:not([data-page="top"]).--is-loaded .cLoading{
	animation: ani_loaded 1s linear forwards;
}


/**
* cont_h2
**/
.cont_h2--en:before{
	width: 0%;
	transition: width .6s cubic-bezier(.17,.67,.45,1.03);
}
.cont_h2--ja > span{
	opacity: 0;
	transform: rotate(45deg) scale(0.65);
    transition: transform .6s cubic-bezier(.17,.67,.45,1.03), opacity .5s cubic-bezier(.17,.67,.45,1.03);
}
.cont_h2--ja > span:nth-of-type(1){
	transition-delay: 1.1s;
}
.cont_h2--ja > span:nth-of-type(2){
	transition-delay: 1.2s;
}
.cont_h2--ja > span:nth-of-type(3){
	transition-delay: 1.3s;
}
.cont_h2--ja > span:nth-of-type(4){
	transition-delay: 1.4s;
}
.cont_h2--ja > span:nth-of-type(5){
	transition-delay: 1.5s;
}
.cont_h2--ja > span:nth-of-type(6){
	transition-delay: 1.6s;
}
.cont_h2--ja > span:nth-of-type(7){
	transition-delay: 1.7s;
}
.cont_h2--ja > span:nth-of-type(8){
	transition-delay: 1.8s;
}
.cont_h2--ja > span:nth-of-type(9){
	transition-delay: 1.9s;
}
.cont_h2--ja > span:nth-of-type(10){
	transition-delay: 2.0s;
}
.cont_h2--ja > span:nth-of-type(11){
	transition-delay: 2.1s;
}
.cont_h2--ja > span:nth-of-type(12){
	transition-delay: 2.2s;
}
.cont_h2--ja > span:nth-of-type(13){
	transition-delay: 2.3s;
}
.cont_h2--ja > span:nth-of-type(14){
	transition-delay: 2.4s;
}
.cont_h2--ja > span:nth-of-type(15){
	transition-delay: 2.5s;
}

/* cont_h2 active[TOP以外] */
html.wf-active body:not([data-page="top"]).--is-loaded .cont_h2--en:before{
	width: 100%;
	transition-delay: .8s;
}
html.wf-active body:not([data-page="top"]).--is-loaded .cont_h2--ja > span{
	opacity: 1;
	transform: rotate(0deg) scale(1);
}