/*-----
* basic-style.css ver1.0.0
* all pages
-----*/
/***** variable *****/
:root{
	--basic-font-size:16px;
	--basic-font:"Noto Serif JP", serif;
	--sans-font:"Noto Sans JP", sans-serif;
	--key-color:#46413d;
	--key-color-2:#71972e;
	--font-color-1:#707070;
	--border-color:#cfcfcf;
}
/***** common *****/
html,body{
	font-size:var(--basic-font-size, 16px);
	font-family:var(--basic-font);
	font-style: normal;
}
img{
	max-width: 100%;
}
.icon-size img{
	width:calc(var(--basic-font-size) * 1.5);
}
.pc-br{
	display:block;
}
.sp-br{
	display:none;
}
.w1100-br,
.w1200-br{
	display:block;
}
.basic-box .nr{
	display: inline-block;
	word-break: keep-all;
}
#header-space-h{
	display:none;
}
@media screen and (min-width:769px) and ( max-width:1100px){
	
}
@media screen and (max-width:1100px){
	.w1100-br{
		display:none;
	}
}
@media screen and (max-width:1200px){
	.w1200-br{
		display:none;
	}
}
@media screen and (max-width:768px){
	.pc-br{
		display:none;
	}
	.sp-br{
		display:block;
	}
	.basic-box .nr{
		display: inline;
		word-break: normal;
	}
}
/***** default css *****/
.dammy-h{
	height:1000px;
}
/***** header *****/
.site-header{
	width:100%;
	position: fixed;
	z-index: 2;
}
.site-header.opacity-delay{
	opacity:0;
}
.site-header>.inner{
	width: 100%;
	margin: auto;
	position: relative;
}
.site-header>.inner>.logo-box{
	position: absolute;
	top: 0;
	left: 2vw;
	height: 100%;
	z-index: 1;
}
.site-header .gmenu-box>.wrap>.sp-logo-box{
	display:none;
	position: relative;
	background-color: #faf7f5;
}
.site-header>.inner>.logo-box>a{
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	height: inherit;
}
.site-header .gmenu-box>.wrap>.sp-logo-box>a{
	display: inline-flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	height: inherit;
}
.site-header>.inner>.logo-box>a>div,
.site-header .gmenu-box>.wrap>.sp-logo-box>a>div{
	display: flex;
	align-items: center;
	height: inherit;
}
.site-header>.inner>.logo-box>a>div>img,
.site-header .gmenu-box>.wrap>.sp-logo-box>a>div>img{
	max-height: 70px;
	height: inherit;
	object-fit: contain;
}
.site-header>.inner>.logo-box>a>.l-1,
.site-header .gmenu-box>.wrap>.sp-logo-box>a>.l-1{
	font-size: 1rem;
	color: #fff;
	font-weight: 300;
	line-height: 1.4em;
	padding-left: 5px;
}
.site-header .gmenu-box>.wrap>.sp-logo-box>.close-menu-button{
	position: absolute;
	right: 10px;
	top: 10px;
	font-size: 35px;
	line-height: 1em;
	cursor: pointer;
}
.site-header .default-menu{
	width: 100%;
	min-height: 50px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	position: relative;
}
.site-header .default-menu>ul{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.site-header .default-menu>ul>li{
	padding-left: 1rem;
	display: flex;
	align-items: center;
}
.site-header .default-menu>ul>li>a:hover{
	opacity:0.5;
}
.site-header .default-menu>ul>li>a>img{
	max-width: 1.5rem;
}
.site-header .gmenu-box{
	border-bottom: 1px solid #fff;
	transition: all 300ms 0s ease;
}
.site-header .gmenu-box.tg-active-color{
	/*background-color: rgb(250 247 245 / 80%);*/
	/*border-bottom: none;*/
}
.site-header .gmenu-box>.wrap{
	width: 100%;
}
.site-header .gmenu-box>.wrap>ul{
	height: 100%;
	display: flex;
	justify-content: flex-end;
	padding-right: 2vw;
}
.site-header .gmenu-box>.wrap>ul>li{
	padding-left: 2rem;
}
.site-header .gmenu-box>.wrap>ul>li>.head-menu{
	height: 100%;
	display: flex;
	align-items: center;
}
.site-header .gmenu-box>.wrap>ul>li>.head-menu>a{
	display: block;
	font-size: 1rem;
	color: #fff;
	font-weight: 300;
	line-height: 1em;
	position: relative;
}
.site-header .gmenu-box>.wrap>ul>li.color-button>.head-menu>a{
	font-size: 0.9em;
	background-color: var(--font-color-1);
	padding: 0.5em 2em;
	border-radius: 12px / 50%;
	transition: all 300ms 0s ease;
}
.site-header .gmenu-box>.wrap>ul>li>.head-menu>a::after,
.site-header .gmenu-box>.wrap>ul>li>.head-menu.active>a::after{
	content: "";
	display: block;
	position: absolute;
	bottom: -3px;
	left: 0;
	width: 100%;
}
.site-header .gmenu-box>.wrap>ul>li>.head-menu.tg-active>a::after,
.site-header .gmenu-box>.wrap>ul>li>.head-menu>a:hover::after,
.site-header .gmenu-box>.wrap>ul>li>.head-menu.active>a::after{
	border-bottom: 1px solid #fff;
}
.site-header .gmenu-box>.wrap>ul>li.color-button>.head-menu>a:hover{
	filter: brightness(0.8);
}
.site-header .gmenu-box>.wrap>ul>li.color-button>.head-menu>a:hover::after{
	border-bottom: none;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu{
	position: absolute;
	left: 0;
	width: 100%;
	height:0;
	overflow:hidden;
	background-color: rgb(250 247 245 / 0%);
	transition:all 300ms 0ms ease;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu.open{
	background-color: rgb(250 247 245 / 90%);
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1,
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2{
	width: 100%;
	max-width: 1200px;
	display: flex;
	margin: auto;
	padding: 2rem 2%;
	flex-direction: row;
	flex-wrap: nowrap;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.image{
	width: 25%;
	min-width: 210px;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list{
	width: 75%;
	padding-left: 8vw;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul{
	width: 45%;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul>li:not(:last-child){
	margin-bottom: 0.6rem;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul>li>a,
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a>p{
	display: inline-block;
	font-size: 1rem;
	color: var(--font-color-1);
	position: relative;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul>li>a::after,
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a>p::after{
	content: "";
	display: block;
	position: absolute;
	bottom: 0px;
	left: 0;
	width: 100%;
	height: 1px;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul>li>a:hover::after,
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a:hover>p::after{
	border-bottom: 1px solid var(--font-color-1);
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list{
	width: 100%;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li{
	padding: 0 1rem;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a{
	display: block;
	width: 100%;
	text-align: center;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a>.image{
	margin-bottom: 0.5rem;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a>.image>img{
	width: 100%;
	object-fit: contain;
	transition: all 300ms 0s ease;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a:hover>.image>img{
	filter: brightness(0.8);
}
.site-header .humbrger{
	display:none;
	width: 35px;
	height: 30px;
}
.site-header .humbrger>div{
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	flex-wrap: nowrap;
	cursor: pointer;
}
.site-header .humbrger>div>span{
	display: block;
	width: 100%;
	height: 3px;
	background: #fff;
	border: 1px solid rgb(0 0 0 / 10%);
}
/***** 以下は同じ数値を設定 *****/
.site-header .gmenu-box>.wrap>ul>li>.head-menu{
	min-height: 60px;
}
.site-header .gmenu-box>.wrap>ul>li>.submenu{
	top: 60px;
}
@media screen and (min-width:769px) and ( max-width:1220px){
	.site-header .gmenu-box>.wrap{
		display: flex;
		justify-content: flex-end;
	}
	.site-header .gmenu-box>.wrap>ul{
		max-width: 520px;
		flex-direction: row;
		flex-wrap: wrap;
	}
	.site-header .gmenu-box>.wrap>ul>li>.head-menu{
		min-height: 40px;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu{
		top: 80px;/*上記heightの2倍*/
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list{
		padding-left: 5vw;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul{
		width: 50%;
	}
}
@media screen and (max-width:768px){
	.site-header>.inner>.logo-box{
		position: relative;
		left: 0vw;
	}
	.site-header>.inner>.logo-box>a{
		display: inline-flex;
	}
	.site-header .gmenu-box{
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		height: 100%;
		z-index: 3;
	}
	.site-header .gmenu-box>.wrap{
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		top:0;
		right: -100%;
		height: 100%;
		position: relative;
		transition: all 300ms 0s ease;
	}
	.site-header .gmenu-box.sp-active>.wrap{
		right: 0%;
		background-color: #faf7f5;
	}
	.site-header .gmenu-box>.wrap>.sp-logo-box{
		display:block;
	}
	.site-header .gmenu-box>.wrap>.sp-logo-box>a>.l-1{
		color: var(--font-color-1);
	}
	.site-header .gmenu-box>.wrap>ul{
		height: 100%;
		display: flex;
		justify-content: flex-start;
		flex-direction: column;
		padding: 1rem 0 1rem;
			overflow: scroll;
	}
	.site-header .gmenu-box>.wrap>ul>li{
		display: flex;
		align-items: flex-start;
		flex-direction: column;
	}
	.site-header .gmenu-box>.wrap>ul>li>.head-menu{
		min-height: auto;
		height: auto;
		padding: 0.7rem 0;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu{
		height:100%;
	}
	.site-header .gmenu-box>.wrap>ul>li>.head-menu>a{
		color: var(--font-color-1);
	}
	.site-header .gmenu-box>.wrap>ul>li.color-button>.head-menu>a{
		color: #fff;
	}
	.site-header .gmenu-box>.wrap>ul>li>.head-menu.tg-active>a::after,
	.site-header .gmenu-box>.wrap>ul>li>.head-menu>a:hover::after{
		border-bottom: 1px solid var(--font-color-1);
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu{
		position: relative;
		top: 0;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1{
		padding: 0;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.image{
		display: none;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list{
		width: 100%;
		padding-left: 5vw;
		margin: 0.5rem 0 1rem;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div{
		flex-direction: column;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type1>.menu-list>div>ul{
		width: 100%;
		margin-bottom: 0.6rem;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2{
		padding: 1rem 5vw 0 0;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list{
		margin: 0rem 0 1rem;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul{
		flex-wrap: wrap;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li{
		width: 100%;
		margin-bottom: 0.6rem;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a{
		text-align: left;
	}
	.site-header .gmenu-box>.wrap>ul>li>.submenu>.menu-type2>.menu-list>ul>li>a>.image{
		display: none;
	}
	.site-header .humbrger{
		display: block;
		position: fixed;
		top: 15px;
		right: 15px;
		z-index: 2;
	}
}
/***** footer *****/
.site-footer{
	width:100%;
}
.site-footer.color1{
	background-color: var(--key-color);
}
.site-footer>.inner{
	width: 100%;
	max-width: 1200px;
	margin: auto;
	padding: 3rem 2% 5rem;
}
.site-footer .footer-box{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
.site-footer .footer-box>.left{
	width: 40%;
}
.site-footer .footer-box>.left>.wrap.mb1{
	margin-bottom: 2rem;
}
.site-footer .footer-box>.left>.wrap>.t-1{
	font-size: 0.9rem;
	font-weight: 300;
	color: #fff;
	margin-bottom: 1rem;
}
.site-footer .footer-box>.left>.wrap>.t-2{
	font-size: 1.5rem;
	color: #fff;
	margin-bottom: 1.5rem;
}
.site-footer .footer-box>.left>.wrap>.t-3{
	font-size: 0.9rem;
	font-weight: 300;
	color: #fff;
	line-height: 1.7em;
	margin-bottom: 1rem;
}
.site-footer .footer-box>.left>.wrap>.t-4{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
}
.site-footer .footer-box>.left>.wrap>.t-4>li:not(:last-child){
	padding-right: 0.5rem;
}
.site-footer .footer-box>.left>.wrap>.t-4>li>a{
	display: block;
	transition: all 300ms 0s ease;
}
.site-footer .footer-box>.left>.wrap>.t-4>li>a:hover{
	opacity:0.5;
}
.site-footer .footer-box>.left>.wrap>.t-4>li>a>div{
	width: 30px;
	height: 25px;
}
.site-footer .footer-box>.left>.wrap>.t-4>li>a>div>svg{
	display: block;
	width: 100%;
	height: 100%;
}
.site-footer .footer-box>.left>.wrap>.t-4>li>a>div>svg path{
	fill:#fff;
}
.site-footer .footer-box>.left>.wrap2>.list-box>.block1>.l-2>li:not(:last-child){
	margin-bottom: 0.4rem;
}
.site-footer .footer-box>.left>.wrap2>.list-box>.block1>.l-2>li>.text>a{
	display: inline-block;
	font-size: 0.8rem;
	color: #fff;
	font-weight: 300;
	transition: all 300ms 0s ease;
}
.site-footer .footer-box>.left>.wrap2>.list-box>.block1>.l-2>li>.text>a:hover{
	opacity: 0.5;
}
.site-footer .footer-box>.left>.wrap3{
	
}
.site-footer .footer-box>.left>.wrap3.mb1{
	margin-bottom: 2rem;
}
.site-footer .footer-box>.left>.wrap3>.image{
	
}
.site-footer .footer-box>.left>.wrap3>.image>a{
	display: inline-block;
	transition: all 300ms 0s ease;
}
.site-footer .footer-box>.left>.wrap3>.image>a:hover{
	filter: brightness(0.8);
}
.site-footer .footer-box>.left>.wrap3>.image>a>img{
	display: block;
	width: 100%;
	max-width: 250px;
}
.site-footer .footer-box>.right{
	width: 60%;
}
.site-footer .footer-box>.right>.list-box{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.site-footer .footer-box>.right>.list-box>.block1{
	width: 30%;
	padding-left: 2rem;
	margin-bottom: 2rem;
}
.site-footer .footer-box>.right>.list-box>.block1>.l-1{
	font-size: 0.9rem;
	color: #fff;
	font-weight: 300;
	border-bottom: 1px solid #fff;
	padding-bottom: 0.5rem;
	margin-bottom: 1.3rem;
}
.site-footer .footer-box>.right>.list-box>.block1>.l-2>li:not(:last-child){
	margin-bottom: 0.4rem;
}
.site-footer .footer-box>.right>.list-box>.block1>.l-2>li>.text>a{
	display: inline-block;
	font-size: 0.8rem;
	color: #fff;
	font-weight: 300;
	transition: all 300ms 0s ease;
}
.site-footer .footer-box>.right>.list-box>.block1>.l-2>li>.text>a:hover{
	opacity:0.5;
}
.site-footer .copyright{
	width: 100%;
	max-width: 1200px;
	margin: auto;
	padding: 0 2% 5px;
}
.site-footer .copyright>p{
	font-family: var(--sans-font);
	font-size: 0.8rem;
	color: #fff;
	line-height: 1em;
	font-weight: 200;
}
@media screen and (max-width:768px){
	.site-footer>.inner{
		padding: 3rem 5% 2rem;
	}
	.site-footer .footer-box{
		flex-direction: column;
	}
	.site-footer .footer-box>.left,
	.site-footer .footer-box>.right{
		width: 100%;
	}
	.site-footer .footer-box>.left{
		margin-bottom: 3rem;
	}
	.site-footer .footer-box>.right>.list-box{
		justify-content: flex-start;
	}
	.site-footer .footer-box>.right>.list-box.mb1{
		margin-bottom: 2rem;
	}
	.site-footer .footer-box>.right>.list-box>.block1{
		width: 50%;
	}
	.site-footer .footer-box>.right>.list-box>.block1:nth-child(odd){
		padding: 0 0.5rem 0 0;
	}
	.site-footer .footer-box>.right>.list-box>.block1:nth-child(even){
		padding: 0 0 0 0.5rem;
	}
	.site-footer .copyright{
		padding: 0 5% 5px;
	}
}
/***** content common *****/
.layer-bg-color{
	background-color: rgb(0 0 0 / 25%);
}
.basic-box.color-b{
	background-color: #000;
}
.basic-box.color-w{
	background-color: #fff;
}
.basic-box.color-k{
	background-color:#fcf8e6;
}
.basic-box>.inner{
	width: 100%;
	max-width: 1200px;
	margin: auto;
	padding: 2rem 2%;
}
#event-disp-pos{
	display: block;
	height:16px;
}
@media screen and (max-width:768px){
	.basic-box>.inner{
		padding: 2rem 5%;
	}
}
/***** head-title-box *****/
.head-title-box{
	position: relative;
	width: 100%;
	height: auto;
}
.head-title-box>.bg-image{
	width: 100%;
	height: 100vh;
}
.head-title-box>.bg-image.underlayer-bg{
	height: auto;
}
.head-title-box>.bg-image>.movie-box{
	width: 100%;
	height: 100vh;
	position: fixed;
	left: 0;
	top: 0;
	z-index: -1;
	overflow: hidden;
}
.head-title-box>.bg-image>.movie-box>video{
	min-width: 100%;
	min-height: 100vh;
	position: absolute;
	bottom: 70%;
	right: 20%;
	transform: translateY(70%) translateX(20%);
}
.head-title-box>.bg-image.underlayer-bg>.under>.basic-h{
	width: 100%;
	height: 50vh;
	min-height: 430px;
}
.head-title-box>.bg-image.underlayer-bg>.under>img.image-bg{
	object-fit: cover;
	object-position: 50% 50%;
}
.head-title-box>.bg-image.underlayer-bg>.under>img.flick-c{
	opacity: 0;
}
.head-title-box>.bg-image.underlayer-bg>.under>.plain-bg{
	background-color: var(--key-color);
}
.head-title-box>.title-box{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
}
.head-title-box>.title-box.over-layer-bg{
	background-color: rgb(0 0 0 / 25%);
}
.head-title-box>.title-box.flick-c{
	background-color: #fff;
}
.head-title-box>.title-box.touka-clear{
	background-color: rgb(0 0 0 / 0%);
}
.head-title-box>.title-box>.t-1{
	font-size: 3.4rem;
	font-weight: 500;
	color: #fff;
	line-height: 1em;
	letter-spacing: 6px;
	margin-bottom: 4rem;
}
.head-title-box>.title-box>.t-2{
	font-size: 1.9rem;
	font-weight: 600;
	line-height: 1em;
	color: #fff;
	margin-bottom: 4rem;
}
.head-title-box>.title-box>.t-3{
	width: 100%;
}
.head-title-box>.title-box>.t-3>.wrap{
	font-size: 2.2rem;
	font-weight: 600;
	color: #fff;
	line-height: 1em;
	width: 100%;
	display: flex;
	justify-content: center;
	position: relative;
	text-align: center;
}
.head-title-box>.title-box>.t-3>.wrap>.n-base{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
}
.head-title-box>.title-box>.t-3>.wrap>.n-1{
	animation-name:top-text-anim-1;
	animation-duration: 12000ms;
	animation-delay: 0ms;
	animation-timing-function: ease-in;
	animation-fill-mode: backwards;
	animation-iteration-count: infinite;
}
.head-title-box>.title-box>.t-3>.wrap>.n-2{
	opacity:0;
	animation-name:top-text-anim-2;
	animation-duration: 12000ms;
	animation-delay: 0ms;
	animation-timing-function: ease-in;
	animation-fill-mode: backwards;
	animation-iteration-count: infinite;
}
.head-title-box>.title-box>.t-3>.wrap>.n-3{
	opacity:0;
	animation-name:top-text-anim-3;
	animation-duration: 12000ms;
	animation-delay: 0ms;
	animation-timing-function: ease-in;
	animation-fill-mode: backwards;
	animation-iteration-count: infinite;
}
@keyframes top-text-anim-1{
	0%{
		opacity:1;
	}
	11%{
		opacity:1;
	}
	22.2%{
		opacity:0;
	}
	33.3%{
		opacity:0;
	}
	44.4%{
		opacity:0;
	}
	55.5%{
		opacity:0;
	}
	66.6%{
		opacity:0;
	}
	77.7%{
		opacity:0;
	}
	88.8%{
		opacity:0;
	}
	100%{
		opacity:1;
	}
}
@keyframes top-text-anim-2{
	0%{
		opacity:0;
	}
	11%{
		opacity:0;
	}
	22.2%{
		opacity:0;
	}
	33.3%{
		opacity:1;
	}
	44.4%{
		opacity:1;
	}
	55.5%{
		opacity:0;
	}
	66.6%{
		opacity:0;
	}
	77.7%{
		opacity:0;
	}
	88.8%{
		opacity:0;
	}
	100%{
		opacity:0;
	}
}
@keyframes top-text-anim-3{
	0%{
		opacity:0;
	}
	11%{
		opacity:0;
	}
	22.2%{
		opacity:0;
	}
	33.3%{
		opacity:0;
	}
	44.4%{
		opacity:0;
	}
	55.5%{
		opacity:0;
	}
	66.6%{
		opacity:1;
	}
	77.7%{
		opacity:1;
	}
	88.8%{
		opacity:0;
	}
	100%{
		opacity:0;
	}
}
.head-title-box>.title-box>.text{
	text-align: center;
}
.head-title-box>.title-box>.text>.t-1{
	font-size: 1.9rem;
	color: #fff;
	font-weight: 300;
	line-height: 1em;
}
.head-title-box>.title-box>.text>.t-2{
	font-size: 2.4rem;
	color: #fff;
	font-weight: 400;
	line-height: 1em;
	margin-bottom: 1.5rem;
}
.head-title-box>.bg-image>.sc-bg{
	display:none;
}
@media screen and (max-width:768px){
	.head-title-box>.bg-image>.movie-box{
		height: 100vh;
	}
	.head-title-box>.bg-image>.movie-box>video{
		min-height: 50vh;
		height: 77vh;
		bottom: 68%;
	}
	.head-title-box>.bg-image.underlayer-bg>.under>.basic-h{
		height: 30vh;
		min-height: 300px;
	}
	.head-title-box>.front-title{
		padding-bottom: 10vh;
		align-items: center;
	}
	.head-title-box>.title-box>.t-1{
		text-align: center;
		font-size: 2rem;
		padding: 0 5%;
		line-height: 1.3em;
	}
	.head-title-box>.title-box>.t-2{
		font-size: 1.2rem;
		line-height: 1.7em;
		text-align: center;
	}
	.head-title-box>.title-box>.t-3>.wrap{
		font-size: 1.6rem;
	}
	.head-title-box>.title-box>.text{
		padding: 0 2%;
	}
	.head-title-box>.title-box>.text>.t-1{
		font-size: 1.6rem;
		line-height: 1.5em;
		text-align: center;
	}
	.head-title-box>.title-box>.text>.t-2{
		font-size: 1.9rem;
		margin-bottom: 1rem;
	}
	.head-title-box>.bg-image>.sc-bg{
		display:none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height:100%;
		height: 100vh;
		align-items: flex-end;
		z-index: -1;
	}
	.head-title-box>.bg-image>.sc-bg>div{
		background-color: #fff;
		width: 100%;
		height: 50vh;
	}
}
/***** spacer1 *****/
.spacer1{
	width: 100%;
	height: 7rem;
}
.spacer1.height-1{
	height: 3rem;
}
.spacer1.color-w{
	background-color: #fff;
}
@media screen and (max-width:768px){
	.spacer1.height-1{
		height: 3rem;
	}
	.spacer1.sp-hid{
		display:none;
	}
}
/***** box2 *****/
.box2>.inner{
	max-width: unset;
	padding: 0;
}
.box2 .item-box>.block-list{
	display: flex;
	flex-direction: row;
}
.box2 .item-box>.block-list>.block1{
	width: 50%;
}
.box2 .item-box>.block-list>.block1.wide-block{
	width: 100%;
}
.box2 .item-box>.block-list>.block1>.block-base{
	width: 100%;
	height: calc(100vw / 2);
	overflow: hidden;
}
.box2 .item-box>.block-list>.block1>.block-s{
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	height: calc(100vw / 4);
}
.box2 .item-box>.block-list>.block1>.block-m{
	height: calc(100vw / 4);
}
.box2 .item-box>.block-list>.block1.wide-block>.block-l{
	height: calc(100vw / 3);
	min-height: 400px;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set{
	height: inherit;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div{
	position: relative;
	height: inherit;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a{
	display: block;
	height: inherit;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a.no-link{
	cursor: default;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.image{
	height: inherit;
	overflow: hidden;
}
.box2 .item-box>.block-list>.block1.wide-block>.block-base>.image-set>div>a>.image{
	min-height: 400px;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.image>img{
	display: block;
	max-width: none;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.5;
	transition: all 300ms 0s ease;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a:hover>.image>img{
	opacity: 0.6;
	transform: scale(1.02);
}
.box2 .item-box>.block-list>.block1>.block-s>.image-set>div>a>.image>img{
	object-fit: cover;
	object-position: 50% 50%;
}
.box2 .item-box>.block-list>.block1>.block-m>.image-set>div>a>.image>img{
	object-fit: cover;
	object-position: 50% 0%;
}
.box2 .item-box>.block-list>.block1>.block-m>.image-set>div>a>.image>img.pos1{
	object-position: 50% 10%;
}
.box2 .item-box>.block-list>.block1.wide-block>.block-l>.image-set>div>a>.image>img{
	object-fit: cover;
	object-position: 50% 70%;
	opacity: 1;
	transition: unset;
}
.box2 .item-box>.block-list>.block1.wide-block>.block-l>.image-set>div>a:hover>.image>img{
	transform: scale(1);
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text.pos-l{
	padding: 0 5% 10%;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap{
	text-align: center;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text.pos-l>.t-wrap{
	text-align: left;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-1{
	font-size: 2.5rem;
	color: rgb(255 255 255 / 60%);
	font-weight: 400;
	margin-bottom: 0.5rem;
	transition: all 300ms 0s ease;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2{
	font-size: 1.5rem;
	color: rgb(255 255 255 / 60%);
	font-weight: 300;
	transition: all 300ms 0s ease;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2.mb1{
	margin-bottom: 3rem;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap.weight1>.t-1,
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap.weight1>.t-2{
	font-weight: 600;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a:hover>.text>.t-wrap>.t-1,
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a:hover>.text>.t-wrap>.t-2{
	color: rgb(255 255 255 / 100%);
	text-shadow: 0 0 3px #fff;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2>.sp1{
	font-size: 0.7em;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2>.sp2{
	font-size: 1.2em;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-3{
	font-size: 1rem;
	color: rgb(255 255 255 / 60%);
	font-weight: 300;
	line-height: 2em;
	transition: all 300ms 0s ease;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a:hover>.text>.t-wrap>.t-3{
	color: rgb(255 255 255 / 100%);
	text-shadow: 0 0 3px #fff;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.arrow{
	position: absolute;
	bottom: 1rem;
	right: 1rem;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.arrow>div{
	background-color: #fff;
	border-radius: 50%;
	font-size: 1rem;
	width: 1.3em;
	height: 1.3em;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all 300ms 0s ease;
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a:hover>.arrow>div{
    transform: scale(1.2);
}
.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.arrow>div>span{
	display: block;
	font-size: 0.6em;
	color: var(--font-color-1);
	line-height: 1em;
	transform: rotateZ(90deg);
}
/*ブロックのフォントサイズ用*/
@media screen and (min-width:1700px){
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-1{
		font-size: 2.5vw;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2{
		font-size: 1.5vw;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.arrow>div{
		font-size: 1.4vw;
	}
}
@media screen and (min-width:769px) and ( max-width:950px){
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-1{
		font-size: 2rem;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2{
		font-size: 1.3rem;
	}
}
@media screen and (max-width:768px){
	.box2 .item-box>.block-list{
	    flex-direction: column;
	}
	.box2 .item-box>.block-list>.block1 {
	    width: 100%;
	}
	.box2 .item-box>.block-list>.block1>.block-s{
		height: calc(100vh / 4);
	}
	.box2 .item-box>.block-list>.block1>.block-m,
	.box2 .item-box>.block-list>.block1>.block-l{
	    height: calc(100vh / 4);
	}
	.box2 .item-box>.block-list>.block1>.block-t{
		height: calc(100vh / 2.3);
		min-height: 350px;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set{
		height: 100%;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set.cj-active>div>a>.image>img{
		opacity: 0.6;
		transform: scale(1.02);
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text.pos-l{
		padding: 0 5% 0%;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-1{
		font-size: 1.8rem;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-2{
		font-size: 1.2rem;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set.cj-active>div>a>.text>.t-wrap>.t-1,
	.box2 .item-box>.block-list>.block1>.block-base>.image-set.cj-active>div>a>.text>.t-wrap>.t-2,
	.box2 .item-box>.block-list>.block1>.block-base>.image-set.cj-active>div>a>.text>.t-wrap>.t-3{
		color: rgb(255 255 255 / 100%);
		text-shadow: 0 0 3px #fff;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set>div>a>.text>.t-wrap>.t-3{
		font-size: 0.9rem;
	}
	.box2 .item-box>.block-list>.block1>.block-base>.image-set.cj-active>div>a>.arrow>div{
		transform: scale(1.2);
	}
	.box2 .item-box>.block-list>.block1.wide-block>.block-l{
		height: calc(100vw / 2);
		min-height: 300px;
	}
	.box2 .item-box>.block-list>.block1.wide-block>.block-base>.image-set>div>a>.image{
		min-height: 300px;
	}
}
/***** banner-box *****/
.banner-box{
	
}
.banner-box>.inner.pd1{
	padding: 2rem 2% 4rem;
}
.banner-box .list-box{
	
}
.banner-box .list-box>ul{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
}
.banner-box .list-box>ul>li{
	width: 30%;
}
.banner-box .list-box>ul>li>a{
	display: inline-block;
	transition: all 300ms 0s ease;
}
.banner-box .list-box>ul>li>a:hover{
	filter: brightness(0.8);
}
.banner-box .list-box>ul>li>a>img{
	display: block;
	width: 100%;
	box-shadow: 0 0 3px var(--border-color);
}
@media screen and (max-width:768px){
	.banner-box>.inner.pd1{
		padding: 0rem 5% 4rem;
	}
	.banner-box .list-box>ul{
		flex-direction: column;
	}
	.banner-box .list-box>ul>li{
		width: 70%;
	}
	.banner-box .list-box>ul>li:not(:last-child){
		margin-bottom: 1.5rem;
	}
}



/***** back top top *****/
.backtoup{
	position: fixed;
	bottom: 10px;
	right: 10px;
	cursor: pointer;
	opacity: 0;
	transition: all 200ms 0s ease;
	z-index: 10;
}
.backtoup.btuActive{
	opacity: 1;
}
.backtoup>div{
	width: 100%;
	height: 100%;
	position: relative;
}
.backtoup>div>.text{
	position: absolute;
	top: 0;
	bottom: 0;
	font-family: var(--sans-font);
	font-size: 0.8rem;
	font-weight: 300;
	color: var(--border-color);
	line-height: 1em;
	right: calc(100% + 0.5rem);
	display: flex;
	align-items: center;
	pointer-events: none;
}
.backtoup>div>.icon{
	display: flex;
	border: 1px solid var(--border-color);
	background-color: var(--border-color);
	border-radius: 50%;
	width: 35px;
	height: 35px;
	justify-content: center;
	align-items: center;
	transform: scale(0.9);
	transition: all 200ms 0s ease;
}
.backtoup:hover>div>.icon{
	transform: scale(1);
}
@media screen and (max-width:768px){
	
}
/***** 404 *****/
.not-found-box .text-box{
	min-height: 50vh;
	text-align: center;
}
.not-found-box .text-box>.p-1{
	font-size: 2rem;
	font-weight: bold;
	font-family: monospace, monospace;
	margin-bottom: 2rem;
}
.not-found-box .text-box>div>p>a:hover{
	text-decoration: underline;
	-webkit-text-decoration: underline #000;
}
@media screen and (max-width:768px){
	
	
}
/***** scroll fade *****/
.fade-target{
	transition: all 600ms 0s ease-out;
	transform: translateY(20px);
	opacity: 0;
}
.f-active{
	transform: translateY(0);
	opacity: 1;
}
/***** top priority *****/
.disp-none{
	display: none;
}
@media screen and (max-width:768px){
	
	
}