@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{
	/* font */
	--font-sans: source-han-sans-japanese, sans-serif;
	--font-serif: source-han-serif-japanese, serif;
	--font-en: acumin-pro-extra-condensed, sans-serif;

	/* color */
	--color-red:    #da0000; /* 通常のレッド */
	--color-skyblue:#149FCF; /* スカイブルー / 明るい青シアン */
	--color-orange: #EA7410; /* 鮮やかなオレンジ */
	--color-blue:   #4D62F6; /* インディゴブルー / 明るめの青紫 */
	--color-green:  #00B068; /* エメラルドグリーン / 鮮やかな緑 */

	--color-yellow: #f3c538;
	--color-black:  #000;

	/* easing */
	--easing-outquart: cubic-bezier(0.25, 1, 0.5, 1);


	/* sp-size */
	--sp-size-2: min(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);

	/* size */
	--vw-min: 1200;
	--max-percent: 1.6;
}
@media screen and (max-width:768px){
	:root{
		--vw-min: 750;
	}
}
@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: #000;
	color: #FFF;
	font-family: source-han-sans-japanese, "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	font-weight: normal;
	letter-spacing: 0.07em;
	line-height: 1.8;
	word-wrap: break-word;
}
.pc{ display: block; }
.sp{ display: none; }
a{ color: #FFF; }
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: calc(24 / var(--vw-min) * 100vw);
		min-width: 320px;
	}
	.sp{ display: block; }
	.pc{ display: none; }
	.ah:hover { opacity: 1; }
}

#fullWrap{
	width: 100%;
	min-height: 100vh;
	position: relative;
}
.fullWrapIn{
	width: 100%;
	min-height: calc(100vh - min(calc(364 / var(--vw-min) * 100vw), 364px));
	position: relative;
	display: flex;
	flex-direction: column;
}

/**
 * scroll bar
 */
 ::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}
::-webkit-scrollbar-track {
	background: #000;
}
::-webkit-scrollbar-thumb {
	background: var(--color-yellow);
	margin: 2px;
	box-shadow: none;
}



/* Animation */
@keyframes ani_rotate {
	0%{transform: rotate(0deg);}
	100%{transform: rotate(360deg);}
}


/*-----------------------------------------------
 * Modal
-------------------------------------------------*/

/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox{
	-webkit-overflow-scrolling: touch;
	display: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}
.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: 100px;
	min-height: 100%;
	margin: 0 auto;
	position: relative;
}
.oneModalIn:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../img/common/bg/bg_black_noise.jpg) repeat;
	opacity: 60%;
}
.oneModalIn__cont{
	padding: 50px 0;
}
@media screen and (max-width:768px){
	.oneModalIn{
		min-width: 100%;
	}
	.oneModalIn__cont{
		width: 100%;
		padding: 30px 0;
	}
}

/**
 * closeBtn
 */
.modalClose{
	width: min(calc(60 / var(--vw-min) * 100vw), 60px);
	height: min(calc(56 / var(--vw-min) * 100vw), 56px);
	position: fixed;
	top: 0;
	right: 0;
	margin-top: min(calc(22 / var(--vw-min) * 100vw), 22px);
	margin-right: min(calc(20 / var(--vw-min) * 100vw), 20px);
	z-index: 2;
}
.btn_modalClose{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	pointer-events: auto;
	border-radius: unset;
	border: unset;
}
.modalClose__lines{
	width: 100%;
	height: 100%;
	position: relative;
}
.modalClose__lines:before,
.modalClose__lines:after{
	content: '';
	position: absolute;
	width: 66.6667%;
	height: 2px;
	top: calc(50% - 1px);
	left: 16.6667%;
	background-color: #fff;
}
.modalClose__lines:before{
	transform: rotate(30deg);
}
.modalClose__lines:after{
	transform: rotate(-30deg);
}



/**
 * 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;
}


/*-----------------------------------------------
 * Header
-------------------------------------------------*/
.header {
	width: 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	z-index: 999;
	pointer-events: none;
}
.p-headerLogo{
	position: absolute;
	width: min(calc(324 / var(--vw-min) * 100vw), 324px);
	top: 0;
	left: 0;
	right: 0;
	margin-top: min(calc(60 / var(--vw-min) * 100vw), 60px);
	margin-left: auto;
	margin-right: auto;
}
.p-headerLogo > a{
	display: block;
	pointer-events: auto;
}
.p-headerLogo img{
	width: 100%;
}

.headerCont{
	position: sticky;
	top: 0;
	left: 0;
	width: 100%;
	height: min(100vh, 100%);
	height: min(100dvh, 100%);
}

@media screen and (max-width:768px){
	.header {
		position: absolute;
		top: 0;
		bottom: unset;
	}
	.p-headerLogo{
		width: calc(324 / var(--vw-min) * 100vw);
		margin-top: calc(100 / var(--vw-min) * 100vw);
	}
}

.headerContIn{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}



/* inner */
.header__inner {
	-webkit-overflow-scrolling: touch;
	width: 100%;
	overflow: auto;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	padding: 0;
	opacity: 0;
	pointer-events: none;
	z-index: 2;
	overscroll-behavior: contain;
	transition: opacity .5s ease-in-out;
}
.header.is-active .header__inner {
	opacity: 1;
	pointer-events: auto;
}
.header__innerContent{
	width: 100%;/* 360 */
	height: auto;
	min-height: 100%;
	position: relative;
	z-index: 2;
	margin-left: auto;
	padding: min(calc(24 / var(--vw-min) * 100vw), 24px) 0 min(calc(80 / var(--vw-min) * 100vw), 80px);
	display: flex;
	flex-direction: column;
}

.header__navWrap{
	z-index: 3;
}

.headerLogo{
	position: relative;
	z-index: 1;
	width: min(calc(208 / var(--vw-min) * 100vw), 208px);
	margin-left: min(calc(24 / var(--vw-min) * 100vw), 24px);
}
.headerLogo > a{
	display: block;
}
.headerLogo img{
	width: 100%;
}

@media screen and (max-width:768px){
	.header__innerContent{
		padding: calc(120 / var(--vw-min) * 100vw) 0 calc(96 / var(--vw-min) * 100vw);
		overflow: hidden;
	}
	.headerLogo{
		width: calc(480 / var(--vw-min) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
}
@media screen and (hover:hover) and (pointer: fine){
	.headerLogo > a,
	.p-headerLogo > a{
		transition: transform .2s ease;
	}
	.headerLogo > a:hover,
	.p-headerLogo > a:hover{
		transform: scale(102.5%);
	}
}



/**
 * headerNav
 */
.header__navArea {
	position: relative;
	z-index: 1;
	padding-top: min(calc(64 / var(--vw-min) * 100vw), 64px);
	padding-left: min(calc(160 / var(--vw-min) * 100vw), 160px);
	color: #000;
}
@media screen and (max-width:768px){
	.header__navArea{
		padding-top: calc(80 / var(--vw-min) * 100vw);
		padding-left: 0;
	}
}


/**
* navLists
**/
.navLists{
	font-family: var(--font-en);
	font-weight: 900;
	line-height: 1;
}
.navList__link{
	display: inline-block;
	text-decoration: none;
}

.header__navArea .navLists{
	display: flex;
	flex-wrap: wrap;
	width: min(calc(560 / var(--vw-min) * 100vw), 560px);
	font-size: min(calc(50 / var(--vw-min) * 100vw), 50px);
	letter-spacing: 0;
	line-height: 0.8;
}
.header__navArea .navList{
	width: 50%;
	padding-right: min(calc(32 / var(--vw-min) * 100vw), 32px);
	padding-bottom: min(calc(32 / var(--vw-min) * 100vw), 32px);
}
.header__navArea .navList__link{
	color: #000;
	background: linear-gradient(#000 , #000) right bottom / 0 100% no-repeat;
	transition: background-size 0.4s ease, color 0.4s ease;
}
@media screen and (hover:hover) and (pointer: fine){
	.header__navArea .navList__link:hover{
		background-size: 100% 100%;
		background-position: left center;
		color: #fff;
	}
}

/* current */
.header__navArea .navList__link.--is-current{
	background-size: 100% 100%;
	background-position: left center;
	color: var(--color-red);
}

@media screen and (max-width:768px){
	.header__navArea .navLists{
		text-align: center;
		flex-direction: column;
		width: 100%;
		font-size: calc(70 / var(--vw-min) * 100vw);
		gap: calc(48 / var(--vw-min) * 100vw);
	}
	.header__navArea .navList{
		width: 100%;
		padding-right: unset;
		padding-bottom: unset;
	}
}




/**
* snsListsArea
**/
.snsLists{
	display: flex;
	align-items: center;
	gap: min(calc(25 / var(--vw-min) * 100vw), 25px);
}
.snsList__dt{
	font-family: var(--font-en);
	font-weight: 900;
	font-size: min(calc(26 / var(--vw-min) * 100vw), 26px);
	line-height: 1;
}
.snsList__dd{
	width: min(calc(28 / var(--vw-min) * 100vw), 28px);
	height: min(calc(28 / var(--vw-min) * 100vw), 28px);
	position: relative;
}
.snsLink{
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
}
@media screen and (hover:hover) and (pointer: fine){
	.snsLink{
		transition: background-color .3s ease;
	}
}
.snsLink[data-link="x"]{
	-webkit-mask-image: url(../img/common/icon_tw.svg);
	mask-image: url(../img/common/icon_tw.svg);
}
.snsLink[data-link="tiktok"]{
	-webkit-mask-image: url(../img/common/icon_tik.svg);
	mask-image: url(../img/common/icon_tik.svg);
}
.snsLink[data-link="insta"]{
	-webkit-mask-image: url(../img/common/icon_insta.svg);
	mask-image: url(../img/common/icon_insta.svg);
}
.snsLink[data-link="youtube"]{
	-webkit-mask-image: url(../img/common/icon_yt.svg);
	mask-image: url(../img/common/icon_yt.svg);
}

@media screen and (max-width:768px){
	.snsLists{
		gap: calc(64 / var(--vw-min) * 100vw);
	}
	.snsList__dt{
		font-size: calc(50 / var(--vw-min) * 100vw);
	}
	.snsList__dd{
		width: calc(60 / var(--vw-min) * 100vw);
		height: calc(60 / var(--vw-min) * 100vw);
	}
}



/* header - snsListsArea */
.header__navArea .snsListsArea{
	margin-top: min(calc(48 / var(--vw-min) * 100vw), 48px);
}
.header__navArea .snsLink{
	background-color: #000;
}
@media screen and (hover:hover) and (pointer: fine){
	.header__navArea .snsLink:hover{
		background-color: #FFF;
	}
}
@media screen and (max-width:768px){
	.header__navArea .snsListsArea{
		margin-top: calc(96 / var(--vw-min) * 100vw);
	}
	.header__navArea .snsLists{
		justify-content: center;
	}
}


/**
* header__innerContentBg
**/
.header__innerContentBg{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
.header__innerContentBg__bgc{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--color-red);
}
.header__innerContentBg__bgc:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../img/common/bg/tex_bg1.jpg) no-repeat center / cover;
	mix-blend-mode: multiply;
}
@supports (background-image: url(../img/common/bg/tex_bg1.webp)){
	.header__innerContentBg__bgc:before{
		background-image:url(../img/common/bg/tex_bg1.webp);
	}
}


.header__innerContentBg__circle{
	width: min(calc(760 / var(--vw-min) * 100vw), calc(760px * var(--max-percent)));
	height: min(calc(373 / var(--vw-min) * 100vw), calc(373px * var(--max-percent)));
	max-height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	background: url(../img/common/deco/deco_navCircle.svg) no-repeat center top / contain;
	opacity: 10%;
}



.header__innerContentBg__textArea{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	overflow: hidden;
}
.header__innerContentBg__text{
	width: calc(253 / var(--vw-min) * 100vw);
	height: 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	opacity: 20%;
}
.header__innerContentBg__text:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: url(../img/common/deco/deco_txt_yoroishinden.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100%;
}
.header__innerContentBg__text.-l{
	left: calc(-128 / var(--vw-min) * 100vw);
}
.header__innerContentBg__text.-r{
	right: calc(-125 / var(--vw-min) * 100vw);
}

@media screen and (max-width:768px){
	.header__innerContentBg__textArea{
		top: calc(376 / var(--vw-min) * 100vw);
		bottom: unset;
		height: calc(728 / var(--vw-min) * 100vw);
	}
}


.p-header__innerContentBg__imgArea{
	position: absolute;
	top: 0;
	left: calc(720 / var(--vw-min) * 100vw);
	bottom: 0;
	right: calc(100 / var(--vw-min) * 100vw);
	display: flex;
	justify-content: center;
}
.header__innerContentBg__img{
	width: calc(360 / var(--vw-min) * 100vw);
	height: 100%;
	background: url(../img/top/visual/visual1.jpg) no-repeat 48.5% center / cover;
}

@media screen and (max-width:768px){
	.p-header__innerContentBg__imgArea{
		display: none;
	}
}



/**
* s-header__innerContentBg__imgArea
**/
@media screen and (min-width:769px){
	.s-header__innerContentBg__imgArea{
		display: none;
	}
}
@media screen and (max-width:768px){
	.s-header__innerContentBg__imgArea{
		width: 100%;
		height: calc(495 / var(--vw-min) * 100vw);
		background-color: #000;
		transform: skewY(3deg);
		transform-origin: center top;
		overflow: hidden;
		position: relative;
		z-index: 1;
		margin-top: calc(112 / var(--vw-min) * 100vw);
	}
	.s-header__innerContentBg__imgAreaIn{
		position: absolute;
		top: calc(-20 / var(--vw-min) * 100vw);
		left: 0;
		right: 0;
		bottom: calc(-20 / var(--vw-min) * 100vw);
		transform: skewY(-3deg);
		transform-origin: center top;
	}
	.header__innerContentBg__img{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-position: center;
	}
}


/**
 * navBtn
 */

.header__navBtnWrap {
	width: min(calc(60 / var(--vw-min) * 100vw), 60px);
	height: min(calc(56 / var(--vw-min) * 100vw), 56px);
	position: fixed;
	top: 0;
	right: 0;
	margin-top: min(calc(22 / var(--vw-min) * 100vw), 22px);
	margin-right: min(calc(20 / var(--vw-min) * 100vw), 20px);
	z-index: 2;
}
.header__navBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	pointer-events: auto;
}
.header__navBtn__lineWrap {
	width: 100%;
	height: 100%;
	position: relative;
}
.header__navBtn--line {
	background-color: #000;
	display: block;
	width: 100%;
	height: 2px;
	position: absolute;
	transition: top .4s ease, left .4s ease, background-color .4s ease, width .4s ease, transform .4s ease;
}
.header__navBtn--line:nth-child(1) {
	top: 14.2858%;/* 8 */
	left: 0;
	width: 100%;
}
.header__navBtn--line:nth-child(2) {
	top: 35.7143%;
	left: 0;
	width: 66.6667%;
}

@media screen and (hover:hover) and (pointer: fine){
	.header__navBtn:hover .header__navBtn--line{
		background-color: #FFF;
	}
	.header__navBtn.is-active:hover .header__navBtn--line{
		background-color: #000;
	}
}


/* active */
.header__navBtn.is-active .header__navBtn--line{
	background-color: #fff;
}
.header__navBtn.is-active .header__navBtn--line:nth-child(1){
	width: 66.6667%;
	top: calc(50% - 1px);
	left: 16.6667%;
	transform: rotate(30deg);
}
.header__navBtn.is-active .header__navBtn--line:nth-child(2){
	width: 66.6667%;
	top: calc(50% - 1px);
	left: 16.6667%;
	transform: rotate(-30deg);
}

/** LOAD ANIMATION **/
.header__navBtnWrap{
	opacity: 0;
	transition: opacity .4s cubic-bezier(.43,.4,.55,1) .4s;
}
body.--is-loaded .header__navBtnWrap{
	opacity: 1;
}


/*-----------------------------------------------
 * Parts
-------------------------------------------------*/

/**
 * shareLists
 */
.shareLists {
	display: flex;
}

/* item */
.shareLists__item {
	width: 60px;
	height: 60px;
}

/* link */
.shareLists__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
}
.shareLists__link:before {
	content: "";
	background-color: #000;
	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;
}
.shareLists__link:hover:before {
	background-color: #ff0000;
}

/* 各SNSパーツ */
.shareLists__item.is-twitter .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_tw.svg);
	mask-image: url(../img/common/icon_tw.svg);
}
.shareLists__item.is-facebook .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_fb.svg);
	mask-image: url(../img/common/icon_fb.svg);
}
.shareLists__item.is-line .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_line.svg);
	mask-image: url(../img/common/icon_line.svg);
}


/**
* comBg
**/
.comBg{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}
.comBg__movie{
	position: sticky;
	top: 0;
	width: 100%;
	height: min(100vh, 100%);
	overflow: hidden;
}
.bgYouTubePlayers{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	overflow: hidden;
	filter: blur(4px);
}
.ytPlayer{
	width: 100%;
	height: 200%;
	position: absolute;
	top: -50%;
	left: 0;
	border: unset;
}
.comBg__movie:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../img/common/bg/bg_black_noise.jpg) repeat;
	opacity: 80%;
}


/**
* Sticy
**/
.comBg.-sticky{
	z-index: 1;
	pointer-events: none;
}
.comBg__sticky{
	position: sticky;
	top: 0;
	width: 100%;
	height: min(100vh, 100%);
	height: min(100dvh, 100%);
	overflow: hidden;
}
.comBg__sticky-deco{
	position: absolute;
	background-repeat: no-repeat;
	background-size: contain;
}
.comBg__sticky-deco.-h{
	top: 0;
	right: 0;
	width: min(calc(432 / var(--vw-min) * 100vw), 432px);
	height: min(calc(152 / var(--vw-min) * 100vw), 152px);
	background-image: url(../img/common/deco/deco_h.png);
	background-position: right top;
}
.comBg__sticky-deco.-f{
	bottom: 0;
	left: 0;
	width: min(calc(560 / var(--vw-min) * 100vw), 560px);
	height: min(calc(230 / var(--vw-min) * 100vw),230px);
	background-image: url(../img/common/deco/deco_f.png);
	background-position: left top;
}
@media screen and (max-width:768px){
	.comBg__sticky-deco.-h{
		position: fixed;
		width: calc(432 / var(--vw-min) * 100vw);
		height: calc(152 / var(--vw-min) * 100vw);
	}
	.comBg__sticky-deco.-f{
		width: calc(560 / var(--vw-min) * 100vw);
		height: calc(230 / var(--vw-min) * 100vw);
	}
}

/** LOAD ANIMATION **/
.comBg__sticky-deco{
	transition: transform .6s cubic-bezier(.44,.34,.55,1);
}
.comBg__sticky-deco.-h{
	transform: translateY(-100%);
}
.comBg__sticky-deco.-f{
	transform: translateY(100%);
}
body.--is-loaded .comBg__sticky-deco{
	transform: translateY(0%);
}




/**
* contBg__fixed
**/
.contBg__fixed{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	overflow: hidden;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.contBg__fixed img{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
}
.contBg__fixed--bgImg{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center top;
}



/**
* main
**/
.p-main{
	position: relative;
	width: 100%;
	z-index: 1;
}
body:not([data-page="top"]) .p-main{
	padding-top: min(calc(212 / var(--vw-min) * 100vw), 212px);
}
@media screen and (max-width:768px){
	body:not([data-page="top"]) .p-main{
		padding-top: calc(260 / var(--vw-min) * 100vw);
	}
}


/**
* content
**/
.content{
	width: 100%;
	position: relative;
}
.contentIn{
	position: relative;
}


.contTitle{
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	font-weight: 900;
}
.contTitle__ja{
	font-family: var(--font-serif);
	font-size: min(calc(130 / var(--vw-min) * 100vw), 130px);
	letter-spacing: 0;
	color: #FFF;
	opacity: 10%;
}
.contTitle__ja.-small{
	font-size: min(calc(100 / var(--vw-min) * 100vw), 100px);
}
.contTitle__en{
	font-family: var(--font-en);
	font-size: min(calc(80 / var(--vw-min) * 100vw), 80px);
	position: absolute;
	top: 10%;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-red);
}
.contTitle__en.-small{
	font-size: min(calc(40 / var(--vw-min) * 100vw), 40px);
}

@media screen and (max-width:768px){
	.contTitle__ja{
		font-size: calc(100 / var(--vw-min) * 100vw);
	}
	.contTitle__en{
		font-size: calc(80 / var(--vw-min) * 100vw);
		top: 12%;
	}
	.contTitle__en.-small{
		font-size: calc(60 / var(--vw-min) * 100vw);
	}
}


/** SCRANIMATION **/
.contTitle__ja{
	opacity: 100%;
	transform: scale(105%);
	transition: opacity .6s ease .2s, transform .6s ease .2s;
}
.contTitle__en{
	opacity: 0;
	transform: scale(80%);
	transition: opacity .6s ease .2s, transform .6s ease .2s;
}
.is-ani .contTitle__ja{
	opacity: 10%;
	transform: scale(100%);
}
.is-ani .contTitle__en{
	opacity: 100%;
	transform: scale(100%);
}




/**
* arrow_r
**/
.arrow_r{
	display: inline-block;
	width: min(calc(48 / var(--vw-min) * 100vw), 48px);
	height: min(calc(48 / var(--vw-min) * 100vw), 48px);
	position: relative;
}
.arrow_r:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border-radius: 50%;
	border: 1px solid #FFF;
}
.arrow_r > span{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	width: 40%;
	height: 20%;
}
.arrow_r > span:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	-webkit-mask: url(../img/common/arrow/arrow_r.png) no-repeat center / contain;
	mask: url(../img/common/arrow/arrow_r.png) no-repeat center / contain;
	background-color: #fff;
}
.arrow_r.-type_line > span:after{
	content: '';
	position: absolute;
	top: 0;
	right: 50%;
	bottom: 0;
	width: 104px;
	height: 1px;
	margin: auto 0;
	background: #FFF;
}

.arrow_r.-bk:after{
	border-color: #000;
}
.arrow_r.-bk > span:before{
	background-color: #000;
}
.arrow_r.-type_line.-bk > span:after{
	background-color: #000;
}

@media screen and (max-width:768px){
	.arrow_r{
		width: calc(80 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
	}
	.arrow_r.-type_line > span:after{
		width: calc(120 / var(--vw-min) * 100vw);
	}
}

@media screen and (hover:hover) and (pointer: fine){
	.arrowLink .arrow_r:before{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		border-radius: 50%;
		opacity: 0;
		transform: scale(60%);
		background-color: #FFF;
		transition: opacity .3s ease, transform .45s ease;
	}
	.arrowLink:hover .arrow_r:before{
		transform: scale(100%);
		opacity: 1;
	}

	.arrow_r > span:before{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_r > span:before{
		transform: translateX(25%);
		background-color: var(--color-red);
	}

	.arrow_r.-type_line > span:after{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_r.-type_line > span:after{
		transform: translateX(12.5%);
		background-color: var(--color-red);
	}
}


/**
* arrow_l
**/
.arrow_l{
	display: inline-block;
	width: min(calc(48 / var(--vw-min) * 100vw), 48px);
	height: min(calc(48 / var(--vw-min) * 100vw), 48px);
	position: relative;
}
.arrow_l:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border-radius: 50%;
	border: 1px solid #FFF;
}
.arrow_l > span{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	width: 40%;
	height: 20%;
}
.arrow_l > span:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	-webkit-mask: url(../img/common/arrow/arrow_l.png) no-repeat center / contain;
	mask: url(../img/common/arrow/arrow_l.png) no-repeat center / contain;
	background-color: #fff;
}

.arrow_l.-type_line > span:after{
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	bottom: 0;
	width: 104px;
	height: 1px;
	margin: auto 0;
	background: #FFF;
}

.arrow_l.-bk:after{
	border-color: #000;
}
.arrow_l.-bk > span:before{
	background-color: #000;
}
.arrow_l.-type_line.-bk > span:after{
	background-color: #000;
}

.arrow_lWrap{
	width: min(calc(128 / var(--vw-min) * 100vw), 128px);
	height: min(calc(48 / var(--vw-min) * 100vw), 48px);
	text-align: left;
}

@media screen and (max-width:768px){
	.arrow_l{
		width: calc(80 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
	}
	.arrow_l.-type_line > span:after{
		width: calc(120 / var(--vw-min) * 100vw);
	}
	.arrow_lWrap{
		width: calc(160 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
	}
}

@media screen and (hover:hover) and (pointer: fine){
	.arrowLink .arrow_l:before{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		border-radius: 50%;
		opacity: 0;
		transform: scale(60%);
		background-color: #FFF;
		transition: opacity .3s ease, transform .45s ease;
	}
	.arrowLink:hover .arrow_l:before{
		transform: scale(100%);
		opacity: 1;
	}

	.arrow_l > span:before{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_l > span:before{
		transform: translateX(-25%);
		background-color: var(--color-red);
	}

	.arrow_l.-type_line > span:after{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_l.-type_line > span:after{
		transform: translateX(-12.5%);
		background-color: var(--color-red);
	}
}



/**
* arrow_t
**/
.arrow_t{
	display: inline-block;
	width: min(calc(48 / var(--vw-min) * 100vw), 48px);
	height: min(calc(48 / var(--vw-min) * 100vw), 48px);
	position: relative;
}
.arrow_t:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border-radius: 50%;
	border: 1px solid #FFF;
}
.arrow_t > span{
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	width: 20%;
	height: 40%;
}
.arrow_t > span:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	-webkit-mask: url(../img/common/arrow/arrow_t.png) no-repeat center / contain;
	mask: url(../img/common/arrow/arrow_t.png) no-repeat center / contain;
	background-color: #fff;
}

.arrow_t.-type_line > span:after{
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	right: 0;
	width: 1px;
	height: 104px;
	margin: 0 auto;
	background: #FFF;
}

.arrow_t.-bk:after{
	border-color: #000;
}
.arrow_t.-bk > span:before{
	background-color: #000;
}
.arrow_t.-type_line.-bk > span:after{
	background-color: #000;
}

.arrow_tWrap{
	width: min(calc(48 / var(--vw-min) * 100vw), 48px);
	height: min(calc(128 / var(--vw-min) * 100vw), 128px);
}

@media screen and (max-width:768px){
	.arrow_t{
		width: calc(80 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
	}
	.arrow_t.-type_line > span:after{
		height: calc(168 / var(--vw-min) * 100vw);
	}
	.arrow_tWrap{
		width: calc(80 / var(--vw-min) * 100vw);
		height: calc(208 / var(--vw-min) * 100vw);
	}
}

@media screen and (hover:hover) and (pointer: fine){
	.arrowLink .arrow_t:before{
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		border-radius: 50%;
		opacity: 0;
		transform: scale(60%);
		background-color: #FFF;
		transition: opacity .3s ease, transform .45s ease;
	}
	.arrowLink:hover .arrow_t:before{
		transform: scale(100%);
		opacity: 1;
	}

	.arrow_t > span:before{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_t > span:before{
		transform: translateY(-25%);
		background-color: var(--color-red);
	}

	.arrow_t.-type_line > span:after{
		transition: background-color .3s ease,  transform .45s ease;
	}
	.arrowLink:hover .arrow_t.-type_line > span:after{
		transform: translateY(-12.5%);
		background-color: var(--color-red);
	}

}



/*-----------------------------------------------
 * Footer - PageFooter
-------------------------------------------------*/
.pfooter{
	position: relative;
	width: 100%;
	z-index: 1;
	margin-top: auto;
}
.pfooterIn{
	padding-top: min(calc(80 / var(--vw-min) * 100vw), 80px);
	padding-left: 6.6667%;
	padding-right: 6.6667%;
	padding-bottom: min(calc(80 / var(--vw-min) * 100vw), 80px);
	position: relative;
}
.pfooter{
	padding-top: calc(40 / var(--vw-min) * 100vw);
}

.pfooter__logo{
	width: min(calc(500 / var(--vw-min) * 100vw), 500px);
	margin: 0 auto;
}
.pfooter__logo > a{
	display: block;
	width: 100%;
	text-decoration: none;
}
.pfooter__logo img{
	width: 100%;
}
.pfooter__navArea{
	margin-top: min(calc(64 / var(--vw-min) * 100vw), 64px);
}

.pfooter__navArea .navLists{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: min(calc(24 / var(--vw-min) * 100vw), 24px);
	font-size: min(calc(30 / var(--vw-min) * 100vw), 30px);
}

.pfooter__navArea .navList__link{
	background: linear-gradient(var(--color-red) , var(--color-red)) right bottom / 0 100% no-repeat;
	transition: background-size 0.4s ease, color 0.4s ease;
	padding: 0 0.125em;
}
.pfooter__navArea .navList__title{
	display: inline-block;
	line-height: 1;
}
.pfooter__navArea .navList__title > small{
	padding: 0 0.125em;
}
@media screen and (hover:hover) and (pointer: fine){
	.pfooter__navArea .navList__link:hover{
		background-size: 100% 100%;
		background-position: left center;
	}
	.pfooter__logo > a{
		transition: transform .2s ease;
	}
	.pfooter__logo > a:hover{
		transform: scale(102.5%);
	}
}

/* current */
.pfooter__navArea .navList__link.--is-current{
	background-size: 100% 100%;
	background-position: left center;
	color: #000;
}

.pfooter__navArea .snsLists{
	justify-content: center;
	margin-top: min(calc(64 / var(--vw-min) * 100vw), 64px);
}
.pfooter__navArea .snsLink{
	background-color: #fff;
}
@media screen and (hover:hover) and (pointer: fine){
	.pfooter__navArea .snsLink:hover{
		background-color: var(--color-red);
	}
}


.pfooter__bannerLists{
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: min(calc(24 / var(--vw-min) * 100vw), 24px);
	margin-top: min(calc(64 / var(--vw-min) * 100vw), 64px);
}
.pfooter__bannerList{
	width: min(calc(252 / var(--vw-min) * 100vw), 252px);
}
.pfooter__bannerList--link{
	display: block;
	position: relative;
	overflow: hidden;
}
.pfooter__bannerList--link:after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border: 1px solid #666;
}
.pfooter__bannerList--link img{
	width: 100%;
}

@media screen and (hover:hover) and (pointer: fine){
	.pfooter__bannerList--link img{
		transition: filter .3s ease;
	}
	.pfooter__bannerList--link:hover img{
		filter: brightness(125%);
	}
}


.pfooter__toTop{
	position: absolute;
	bottom: 0;
	right: 3.3334%;
}
.pfooter__toTop--link{
	display: inline-flex;
	align-items: flex-end;
	text-decoration: none;
}
.pfooter__toTop--txt{
	display: inline-block;
	padding: min(calc(30 / var(--vw-min) * 100vw), 30px) 0;
	font-family: var(--font-en);
	font-weight: 900;
	font-size: min(calc(26 / var(--vw-min) * 100vw), 26px);
	line-height: 0.8;
	margin-right: -0.5em;
}

@media screen and (max-width:768px){
	.pfooterIn{
		padding-top: calc(120 / var(--vw-min) * 100vw);
		padding-right: calc(40 / var(--vw-min) * 100vw);
		padding-left: calc(40 / var(--vw-min) * 100vw);
		padding-bottom: calc(200 / var(--vw-min) * 100vw);
	}
	body[data-page="top"] .pfooter{
		padding-top: calc(120 / var(--vw-min) * 100vw);
	}
	.pfooter__logo{
		width: calc(592 / var(--vw-min) * 100vw);
	}
	.pfooter__navArea{
		margin-top: calc(64 / var(--vw-min) * 100vw);
	}
	.pfooter__navArea .navLists{
		justify-content: flex-start;
		gap: calc(40 / var(--vw-min) * 100vw);
		font-size: calc(50 / var(--vw-min) * 100vw);
	}
	.pfooter__navArea .navList{
		width: calc((100% - (40 / var(--vw-min) * 100vw)) / 2);
		padding: 0 calc(12 / var(--vw-min) * 100vw);
	}
	.pfooter__navArea .snsLists{
		margin-top: calc(80 / var(--vw-min) * 100vw);
	}
	.pfooter__bannerLists{
		margin-top: calc(88 / var(--vw-min) * 100vw);
		gap: calc(40 / var(--vw-min) * 100vw);
	}
	.pfooter__bannerList{
		width: calc(350 / var(--vw-min) * 100vw);
	}
	.pfooter__toTop{
		right: calc(40 / var(--vw-min) * 100vw);
	}
	.pfooter__toTop--txt{
		padding: calc(56 / var(--vw-min) * 100vw) 0;
		font-size: calc(36 / var(--vw-min) * 100vw);
	}
}



/*-----------------------------------------------
 * Footer - corpFooter
-------------------------------------------------*/
.cfooter{
	position: relative;
	width: 100%;
}
.cfooterIn{
	width: 100%;
	padding: min(calc(48 / var(--vw-min) * 100vw), 48px) min(calc(80 / var(--vw-min) * 100vw), 80px) min(calc(52 / var(--vw-min) * 100vw), 52px);
	background-color: #fff;
	font-size: min(calc(14 / var(--vw-min) * 100vw), 14px);
	font-weight: 500;
	text-align: center;
	color: #000;
}
.corpLogoLists{
	display: flex;
	justify-content: center;
}
.corpLogoList{
	margin: 0 min(calc(20 / var(--vw-min) * 100vw), 20px);
}
.corpLogo__link{
	display: block;
}
.corpLogo__link.-sunrise{
	width: min(calc(227 / var(--vw-min) * 100vw), 227px);
}
.corpLogo__link.-bnfw{
	width: min(calc(260 / var(--vw-min) * 100vw), 260px);
}
.corpLogo__link img{
	width: 100%;
}

.cfooter__caution{
	margin-top: min(calc(40 / var(--vw-min) * 100vw), 40px);
	line-height: 1.5;
}

.cfooter__linkLists{
	display: flex;
	justify-content: center;
	line-height: 1;
	margin-top: 1em;
}
.cfooter__linkList{
	position: relative;
	padding: 0 min(calc(22 / var(--vw-min) * 100vw), 22px);
}
.cfooter__linkList:not(:last-child)::after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 1px;
	background-color: #000;
}
.cfooter__linkList > a{
	color: #000;
}

.copyRight{
	display: block;
	width: 100%;
	padding: min(calc(26 / var(--vw-min) * 100vw), 26px);
	background: #000 url(../img/common/bg/bg_black_noise.jpg) repeat;
	color: #FFF;
	font-size: min(calc(12 / var(--vw-min) * 100vw), 12px);
	line-height: 1;
	text-align: center;
}

@media screen and (hover:hover) and (pointer: fine){
	.corpLogo__link{
		transition: transform .2s ease;
	}
	.corpLogo__link:hover{
		transform: scale(102.5%);
	}
}

@media screen and (max-width:768px){
	.cfooterIn{
		padding: calc(80 / var(--vw-min) * 100vw) 0 calc(64 / var(--vw-min) * 100vw);
		font-size: calc(20 / var(--vw-min) * 100vw);
	}
	.corpLogoList{
		margin: 0 calc(24 / var(--vw-min) * 100vw);
	}
	.corpLogo__link.-sunrise{
		width: calc(292 / var(--vw-min) * 100vw);
	}
	.corpLogo__link.-bnfw{
		width: calc(332 / var(--vw-min) * 100vw);
	}
	.cfooter__caution{
		margin-top: calc(64 / var(--vw-min) * 100vw);
	}
	.cfooter__linkLists{
		margin-top: 2rem;
	}
	.cfooter__linkList{
		padding: 0 calc(32 / var(--vw-min) * 100vw);
	}
	.copyRight{
		font-size: calc(20 / var(--vw-min) * 100vw);
		padding: calc(40 / var(--vw-min) * 100vw);
	}
}