/*
Theme Name:  XXXXXXXXXXXXXXXXXXXXXXX
Theme URI:
Description:
Version: 1.0
Author: 
Author URI:
*/


body {
	font-family: "Shippori Mincho", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	color: #222;
	font-size: 16px;
	font-weight: 400;
  	font-style: normal;
	line-height: 1.75;
	letter-spacing: 0.05em;
	text-align:justify;
}
a {
	color: #333;
	text-decoration: none;
	transition: 0.3s ease-out;
}
a:hover {
	color:#9d7f6a;
}

::selection{background-color:#cfa972; color: #FFF;}
::-moz-selection{background-color:#cfa972; color: #FFF;}

body , header , footer{
	min-width: 1300px;
	max-width: 1920px;
	margin: auto;
}
@media screen and (max-width:640px) {
	body , header , footer { min-width: 400px; font-size: 14px;}
}





/*=======================================================================

	header

=======================================================================*/
#header {
	position: relative;
	width: 100%;
	height: 80px;
	background: url("../images/bg_03.png") no-repeat;
	background-size: cover;
	text-align: right;
	z-index: 2;
}
#header h1 {
	line-height: 80px;
	font-size: 12px;
	padding-right: 40px;
}
@media screen and (max-width:640px) {
	#header {
		text-align: center;
		height: 40px;
	}
	#header h1 {
		display: none;
	}
}





/*=======================================================================

	#top_mv

=======================================================================*/
#top_mv {
	position: relative;
	background: #FFF;
	height: 770px;
	overflow-x: clip;
}
@media screen and (max-width:640px) {
	#top_mv {
		height: 550px;
	}
}
@media screen and (max-width:460px) {
	#top_mv {
		height: 490px;
	}
}


#top_mv h2 {
	position: absolute;
	top: 80px;
	left: 50%; margin-left: 400px;
	z-index: 4;
}
#top_mv h3 {
	position: absolute;
	top: 245px;
	left: 50%; margin-left: -610px;
	z-index: 4;
}
#top_mv .chara01 {
	position: absolute;
	left: 50%; margin-left: -250px;
	bottom: 25px;
	z-index: 3;
}
@media screen and (max-width:640px) {
	#top_mv h2 {
		top: 30px;
		left: auto; margin-left: 0;
		right: 8%;
		width: 18%;
		max-width: 90px;
	}
	#top_mv h3 {
		position: absolute;
		top: auto; bottom: 20px;
		left: 0; margin-left: 0;
		right: 0; margin: auto;
		width: 70%; max-width: 360px;
	}
	#top_mv .chara01 {
		left: 50%; margin-left: -250px;
		bottom: auto;
		top: -40px;
	}
}


#top_mv .chara02 { /*ハクタク*/
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -960px;
	z-index: 2;
}
#top_mv .chara03 { /*ダリア*/
	position: absolute;
	bottom: 25px;
	left: 50%;
	margin-left: -790px;
	z-index: 2;
}
#top_mv .chara04 { /*レーヴェ*/
	position: absolute;
	bottom: 25px;
	left: 50%;
	margin-left: 650px;
	z-index: 2;
}
#top_mv .chara05 { /*アザミ*/
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: 820px;
	z-index: 2;
}
@media screen and (max-width:640px) {
	#top_mv .chara02 { /*ハクタク*/
		display: none;
	}
	#top_mv .chara03 { /*ダリア*/
		display: none;
	}
	#top_mv .chara04 { /*レーヴェ*/
		display: none;
	}
	#top_mv .chara05 { /*アザミ*/
		display: none;
	}
}


/*---------- 文字スライダー ----------*/
.slider-wrapper {
	position: absolute;
  	display: flex;
  	overflow: hidden;
	top: -10px;
	z-index: 1;
}
.slider-wrapper:last-of-type { bottom: 0; top: auto;}
.slider-wrapper ul { display: flex;}
.slider-wrapper ul li { padding-right: 150px;}

.scroll-left { animation: scroll-left 300s infinite linear .5s both;}
.scroll-right { animation: scroll-right 300s infinite linear .5s both;}
@keyframes scroll-left {
  from { transform: translateX(0);}
  to   { transform: translateX(-100%);}
}
@keyframes scroll-right {
  from { transform: translateX(-100%);}
  to   { transform: translateX(0);}
}
@media screen and (max-width:640px) {
	.slider-wrapper img {
		max-width: 1200px;
	}
	.slider-wrapper {
		top: -2px;
	}
}




/*=======================================================================

	#story

=======================================================================*/
#story {
	padding-top: 100px;
	background: url("../images/bg_01.jpg") no-repeat center top;
}
#story .inner {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: row-reverse;
}
#story .inner img:nth-of-type(2) {
	margin: 60px 40px 0 20px;
}
@media screen and (max-width:640px) {
	#story {
		padding-top: 30px;
		background-size: cover;
	}
	#story .inner img:nth-of-type(1) {
		margin-left: 25px;
		width: 153px;
	}
	#story .inner img:nth-of-type(3) {
		width: 175px;
	}
	#story p {
		text-align: center;
		margin-bottom: 30px;
	}
	#story p img {
		margin-top: 50px;
	}
}





/*=======================================================================

	#youtube

=======================================================================*/
#movie {
	position: relative;
  	width: 100%;
	padding-top: 100px;
}
#movie::before {
	position: absolute;
	content: "";
	width: 100%;
	height: 400px;
	background: url("../images/se05_bg.jpg");
	background-size: cover;
	left: 0;
	bottom: 0;
}
@media screen and (max-width:640px) {
	#movie {
		width: 90%;
		margin: auto;
		padding-top: 40px;
	}
}
#youtube {
  	width: 100%;
	max-width: 1280px;
	margin: auto;
  	aspect-ratio: 16 / 9;
}
#youtube iframe {
	position: relative;
  	width: 100%;
  	height: 100%;
	z-index: 99;
	border-radius: 5px;
}





/*=======================================================================

	#info

=======================================================================*/
#info {
	padding-top: 90px;
	background: url("../images/bg_02.jpg") no-repeat center top;
	background-size: cover;
}
#info .inner {
	display: flex;
	justify-content: center;
	align-items: center;
}
#info .inner figure {
	margin-bottom: 20px;
}
#info .inner dl {
	text-align: center;
	margin-left: 50px;
	margin-bottom: 110px;
}
#info .inner dl dd {
	padding-top: 20px;
}
#info .inner dl dd p {
	margin-bottom: 15px;
}
#info .inner dl dd.info_btn a {
	position: relative;
	display: block;
	width: 90%;
	margin: auto;
	border: 1px solid #111;
	padding: 15px 0;
}
#info .inner dl dd.info_btn a:hover {
	letter-spacing: 2px;
	background: #222;
	color: #FFF;
}
#info .inner dl dd.info_btn a::before {
	position: absolute; content: "";
	width: 50px; height: 1px;
	background: #222;
	top: 50%; right: 0;
	transition: 0.3s ease-out;
}
#info .inner dl dd.info_btn a:hover::before {
	width: 40px; 
	background: #FFF;
}
@media screen and (max-width:640px) {
	#info {
		padding-top: 60px;
	}
	#info .inner {
		display: block;
	}
	#info .inner figure {
		width: 70%;
		margin: 0 auto;
	}
	#info .inner dl {
		width: 90%;
		margin: 0 auto;
		padding-bottom: 80px;
	}
	#info .inner dl dt {
		position: relative;
		width: 70%;
		margin: auto;
		top: -30px;
	}
	#info .inner dl dd {
		padding-top: 0;
	}
}








/*=======================================================================

	#staff

=======================================================================*/
#staff {
	text-align: center;
	font-size: 15px;
	margin-bottom: 90px;
}
@media screen and (max-width:640px) {
	#staff {
		margin-bottom: 40px;
		padding-top: 50px;
	}
}



.banner {
	position: relative;
	top: -50px;
	z-index: 9;
}
@media screen and (max-width:640px) {
	.banner {display: none;}
}



/*------------------------------ スタッフクレジット ------------------------------*/
#staff .inner {
	width: 1280px;
	margin: 0 auto 25px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
@media screen and (max-width:640px) {
    #staff .inner {
        width: 90%;
        display: block;
		margin-bottom: 10px;
    }
}



#staff .inner dl {
	width: 32%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#staff .inner dl dt {
	width: 35%;
	margin-bottom: 3px;
	padding: 12px 0;
	background: #dddddd;
}
#staff .inner dl dd {
	width: 65%;
	margin-bottom: 3px;
	display: flex;
	justify-content: space-between;
}
#staff .inner dl dd p:nth-of-type(1) {
	width: 62%;
	padding: 12px 0 12px 5px;
	background: #f3f3f3;
}
#staff .inner dl dd p:nth-of-type(2) , #staff .inner dl dd p:nth-of-type(3) {
	width: 19%;
	margin-left: 3px;
	box-sizing: border-box;
	background: #f3f3f3;
	transition:0.3s ease-in-out;
	overflow: hidden;
}
#staff .inner dl dd p:nth-of-type(2) a , #staff .inner dl dd p:nth-of-type(3) a {
	position: relative;
	display: block;
	width: 100%;
	height: 149%;
}
#staff .inner dl dd p:nth-of-type(2) img , #staff .inner dl dd p:nth-of-type(3) img {
	position: relative;
	top: 5px;
}
#staff .inner dl dd p:nth-of-type(2) a:hover , #staff .inner dl dd p:nth-of-type(3) a:hover {
	background: #dbb7b8;
}
@media screen and (max-width:640px) {
    #staff .inner dl {
		width: 100%;
        margin-bottom: 2px;
		font-size: 12px;
    }
    #staff .inner dl dt {
        width: 40%;
        padding: 7px 0;
    }
    #staff .inner dl dd {
        width: 60%;
    }
    #staff .inner dl dd p:nth-of-type(1) {
        width: 72%;
        padding: 7px 0 7px 5px;
    }
    #staff .inner dl dd p:nth-of-type(2) , #staff .inner dl dd p:nth-of-type(3) {
        margin-left: 2px;
    }
}






/*=======================================================================

	footer

=======================================================================*/
#footer_mv {
	position: relative;
	width: 100%;
	height: 480px;
}
#footer_mv::after {
	position: absolute;
	content: "";
	width: 100%;
	height: 100%;
	background: url("../images/footer_01.png");
	background-size: 4px 4px;
	left: 0;
	top: 0;
	opacity: .8;
}
#footer_mv figure {
	position: relative;
	text-align: center;
	z-index: 99;
}
#video {
	position: absolute;
	top: 0;
    min-height: 100%;
    min-width: 100%;
	object-fit: cover;
	height: 100%;
	width: 100%;
}
@media screen and (max-width:640px) {
	#footer_mv { display: none;}
}




#copy {
	width: 100%;
	height: 80px;
	background: url("../images/bg_03.png") no-repeat;
	background-size: cover;
	text-align: right;
}
#copy small {
	line-height: 80px;
	font-size: 12px;
	padding-right: 40px;
}
@media screen and (max-width:640px) {
	#copy {
		text-align: center;
	}
	#copy small {
		font-size: 10px;
		padding-right: 0;
	}
}








/*=======================================================================

	Loader

=======================================================================*/
.loader-bg {
    position: fixed;
    width: 100%;
    height: 100%;
	min-width: 1300px;
    top: 0;
    left: 0;
    background: url("../images/loading.png") no-repeat center, #FFF;
	background-size: auto 60px , auto;
    z-index: 999999999;
	overflow: hidden;
}
.loader-bg::before {
	position: absolute;
	content: "LOADING...";
	width: 60px;
	height: 30px;
	font-size: 10px;
	top: 110px; bottom: 0;
	left: 0; right: 0;
	margin: auto;
	color: #bbb;
	z-index: 999;
}
@media screen and (max-width:640px) {
	.loader-bg {
		min-width: 400px;
	}
	
}









