/* Reset */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}table{border-collapse:collapse;border-spacing:0}
body{font:13px/1.1 futura-pt,sans-serif;}

/*--------------------
	common style
 -------------------*/
@font-face {
	font-family: supria-sans, sans-serif;
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: "Koburina Gothic W3 JIS2004";
}

@font-face {
	font-family: "Koburina Gothic W6 JIS2004";
}

html{
	scroll-behavior: smooth;
}

body {
	-webkit-text-size-adjust: none;
	background: #fff;
	letter-spacing: 0.1em;
	font-family: "noto-sans-cjk-jp", sans-serif;
	font-weight: 700;
}

a{
	text-decoration: none;
}
a:hover{
	opacity: 0.4;
}
.clearfix:after{
	content: "";
	clear: both;
	display: block;
}

/* TOPページ */
.t_fv {
/*	min-height: 600px;*/
	max-height: 100vh;
	height: auto;
    width: 100%;
	position: relative;
	overflow: hidden;
	border-bottom: solid 1px #000;
}
.video_2 {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.pc_video{
	display: block !important;
}
.sp_video{
	display: none !important;
}
.openbtn2{
	position: absolute;/*ボタン内側の基点となるためrelativeを指定*/
	top:3.5%;
	right:30px;
	width: 70px;
    height:50px;
	cursor: pointer;
  }
	
 .openbtn2 span{
	display: inline-block;
	transition: all .4s;/*アニメーションの設定*/
	position: absolute;
	left: 0px;
	height: 2px;
	background-color: #000;
}

.openbtn2 span:nth-of-type(1) {
	top:12px; 
	width: 100%;
}
  
.openbtn2 span:nth-of-type(2) {
	top:29px;
	width:100%;
}

.nav{
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: 0.8;
	z-index: 11;
}

.batsu {
	display: block;
	position: absolute;
	width: 50px;
	height: 50px;
	top:4%;
	right:40px;
	cursor: pointer;
}
   
.batsu::before, .batsu::after { /* 共通設定 */
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 1px; /* 棒の幅（太さ） */
	height: 80px; /* 棒の高さ */
	background: #fff;
}

.batsu::before {
	transform: translate(-50%,-50%) rotate(45deg);
}
   
.batsu::after {
	transform: translate(-50%,-50%) rotate(-45deg);
}
.nav span a{
	color: #fff;
}

.nav ul{
	width:240px;
    width: 240px;
    margin: 0 auto;
    position: absolute;
    top: calc(50% - 172px);
    left: calc(50% - 120px);
}
.nav ul li{
	padding-bottom:25px;
	font-size: 25px;
	color: #fff;
	font-family: 'Open Sans', sans-serif;
}
.nav ul li a{
	color: #fff;
}
.nav ul .insta{
	padding-top:30px;
	position: relative;
	padding-left:45px;
}
.nav ul li img{
	position: absolute;
	top:33px;
	left:0px;
 	width:30px;
}

.t_movie{
	width: 100%;
	border-bottom: solid 1px #000;
}
.t_movie .wrap{
	width: 80%;
	margin:0 auto;
	padding:80px 0 80px 0;
}
.t_movie .wrap h1{
	font-size: 6rem;
	color: #000;
	padding-bottom:20px;
	padding-left:15px;
	font-family: 'Open Sans', sans-serif;
}
.t_movie .container {
    width: 100%;
	margin: 0 auto;
    padding-top: 20px;
    padding-bottom: 70px;
	overflow: hidden;
}
.t_movie .gridSizer {
    width: 25%;
}
.t_movie .grid-item img{
    width: 100%;
    border:0;
	transition: all 800ms 0s ease;
}
.t_movie .grid-item img:hover{
	filter:grayscale(100%);
}
.t_movie .grid-item a:hover{
	opacity: 100 !important; 
}
.t_movie .grid-item { 
	width: calc(50% - 50px); 
	padding	: 25px; 
	margin-bottom:20px;
	text-align: center;
}

.t_movie .grid-item p{
	padding-top:10px;
	font-size: 0.8rem;
}
.t_movie .grid-item a p{
	color: #000;
	transition: all 800ms 0s ease;
}
.t_movie .grid-item a p:hover{
	opacity: 0.5;;
}

.t_movie .grid-item_33 { 
	width: calc(33.3% - 20px); 
	padding	: 10px; 
	margin-bottom:20px;
	text-align: center;
}

.move{
	display: inline-block;
	padding: 10px 30px 10px 30px;
	border:solid 1px #000;
	border-radius: 40px;
	font-size: 1.2rem;
	transition: all 800ms 0s ease;
	cursor: pointer;
	color: #000;
	font-family: 'Open Sans', sans-serif;
}
.move:hover{
	color: #fff;
	background: #000;
}

.footer{
	width: 100%;
}
.footer p{
	font-size: 1rem;
	color: #000;
	text-align: center;
	padding:30px 0 30px 0;
	width: 100%;
	font-family: 'Open Sans', sans-serif;
}

.head{
	display: none;
	height: 80px;
	width: 100%;
	border-bottom: solid 1px #000;
	position: fixed;
	background: #fff;
	z-index: 10;
}

.head img{
	position: absolute;
	top:15px;
	left:30px;
	width: 100px;
}

.openbtn3{
	top:18px;
}


#loadingProgressG{
	width: 150px;
    height: 1px;
    overflow: hidden;
    background-color: red;
    position: absolute;
    top: calc(50% - 0.5px);
    left: calc(50% - 75px);
}

.loadingProgressG{
	background-color:rgb(255,255,255);
	margin-top:0;
	margin-left:-250px;
	animation-name:bounce_loadingProgressG;
		-o-animation-name:bounce_loadingProgressG;
		-ms-animation-name:bounce_loadingProgressG;
		-webkit-animation-name:bounce_loadingProgressG;
		-moz-animation-name:bounce_loadingProgressG;
	animation-duration:1.5s;
		-o-animation-duration:1.5s;
		-ms-animation-duration:1.5s;
		-webkit-animation-duration:1.5s;
		-moz-animation-duration:1.5s;
	animation-iteration-count:infinite;
		-o-animation-iteration-count:infinite;
		-ms-animation-iteration-count:infinite;
		-webkit-animation-iteration-count:infinite;
		-moz-animation-iteration-count:infinite;
	animation-timing-function:linear;
		-o-animation-timing-function:linear;
		-ms-animation-timing-function:linear;
		-webkit-animation-timing-function:linear;
		-moz-animation-timing-function:linear;
	width:250px;
	height:19px;
}



@keyframes bounce_loadingProgressG{
	0%{
		margin-left:-250px;
	}

	100%{
		margin-left:250px;
	}
}

@-o-keyframes bounce_loadingProgressG{
	0%{
		margin-left:-250px;
	}

	100%{
		margin-left:250px;
	}
}

@-ms-keyframes bounce_loadingProgressG{
	0%{
		margin-left:-250px;
	}

	100%{
		margin-left:250px;
	}
}

@-webkit-keyframes bounce_loadingProgressG{
	0%{
		margin-left:-250px;
	}

	100%{
		margin-left:250px;
	}
}

@-moz-keyframes bounce_loadingProgressG{
	0%{
		margin-left:-250px;
	}

	100%{
		margin-left:250px;
	}
}

.loading{
	position: fixed;
	width:100%;
	height:100%;

	background: #fff;
	z-index: 111111111;
	text-align: center;
}
.loading #loadingProgressG{
}

.loading img{
	display: none;
    position: absolute;
    top: calc(50% - 101px);
    left: calc(50% - 315px);
}


/* MOVIE */
.head_fix{
	display: block;
}

.mp{
	padding-top:80px;
	padding-left:0px !important;
}

/* About */
.about{
	overflow: hidden;
	width: 100%;
	padding-top:50px;
}
.about .col{
	width: 40%;
	float:left;
}
.about .col:nth-of-type(2){
	width: 60%;
	float:left;
}

.about .col .abimg{
	display: block;
	width: 60%;	
}
.about .col .abimg2{
	display: block;
	width: 200px;		
}
.about .col .ab1{
	font-size: 1.0rem;
	color: #000;
	padding:30px 0 0 0;
}
.about .col .ab2{
	font-size: 1.2rem;
	color: #000;
	padding:10px 0 0 0;
}
.about .col .ab3{
	font-size: 1.0rem;
	color: #000;
	padding:20px 0 0 0;
}
.about .col .ab3 a{
	color: #000;
}

.about .col .ab4{
	font-size: 1.0rem;
	color: #000;
	padding:40px 0 0 0;
	line-height: 30px;
	font-weight: 400;
}
.about .col .ab5{
	line-height: 30px;
	font-size: 1.0rem;
	color: #000;
	padding:35px 0 0 0;
	font-weight: 400;
}
.ab6{
	font-size: 1.0rem;
	color: #000;
	padding:50px 0 0 0;
	font-weight: 400;
	line-height: 30px;
}
.ab7{
	font-size: 1.0rem;
	color: #000;
	padding:40px 0 40px 0;	
	font-weight: 400;
	line-height: 30px;
}
.abpad{
	margin-bottom: 40px;
}

/* CONTACT */
.contact{
	width: 100%;
	overflow: hidden;
	font-size: 1.0rem;
	padding-top: 80px;
	position: relative;
}
.contact div{
	padding:0 0 30px 0;
}
.contact div span{
	width: 200px;
	display: inline-block;
}
.contact div span{
	width: 200px;
	display: inline-block;
}
.contact div span font{
	position: relative;
}
.contact div span font::after{
	content:'※';
	position: absolute;
	top:3px;
	right:-12px;
	font-size: 0.6rem;
}

.alert::after{
	content:'必須入力の項目が未入力です。';
	position: absolute;
	top:30px;
	left:0px;
	font-size: 1.3rem;
	color: red;
}

.contact .textinput {
	font-family: "noto-sans-cjk-jp", sans-serif;
    height: 50px !important;
    line-height: 20px !important;
    width: 600px !important;;
    border: 1px solid #000;
    padding-left: 10px;
    padding-right: 10px;
    margin-top: 10px;
}
.contact .textinput_h{
	height: 300px !important;
	width: 805px !important;
}
.contact .buton {
	margin-top:20px;
    background: #000;
    display: block !important;
    color: #fff !important;
    border: solid 1px #fff;
    padding: 10px !important;
    width: 300px !important;
    cursor: pointer !important;
    padding-bottom: 10px !important;
	text-align: center;
	transition: all 500ms 0s ease;
	font-family: 'Open Sans', sans-serif;
}
.contact .buton:hover{
    background: #fff;
    border: solid 1px #000;
    color: #000 !important;
}
#mail_confirm .confirm span {
    display: none;
}
#mail_confirm{
	display: none;
	height: 100vh;
	width:100%;
	position: fixed;
	background: rgba(0,0,0,0.8);
	top:0;
	left:0;
	z-index: 11;
}
#mail_confirm .confirm{
	margin: 30px auto;
	width: 500px;
	background: #fff;
	padding: 50px 100px 50px 100px;

	color:#000;
	font-size: 1.0rem !important;
	display: block;
	padding-bottom: 50px;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
	overflow-y: scroll;
	max-width: 600px;
	height: 80%;
}
#mail_confirm .confirm h3{
	padding-bottom: 30px;
}
#mail_confirm .confirm h2{
	padding-bottom: 10px;
	font-size: 18px;
}
#mail_confirm .confirm p{
	padding-bottom: 30px;
	font-size: 18px;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
	white-space: pre-wrap;
	max-height: 150px;
}
#mail_confirm .confirm .sndBtn{
	background: #000;
	color: #fff;
	padding: 6px;
	font-size: 1.0rem;
	display: block;
	text-align: float;
	float: left;
	text-align: center;
	margin-right: 10px;
	width: 80px;
	padding-bottom: 6px;
	border:1px solid #000;
	transition: all 500ms 0s ease;
	cursor: pointer;
	margin-top: 20px;
}
#mail_confirm .confirm .sndBtn:hover{
	border:1px solid #000;
	background: #EFEEE9;
	color: #000;
}
#mail_confirm #ic7{
	overflow-y:scroll;
}
#thanks{
	display: none;
	margin:30px auto;
	width: 400px;
	background: #fff;
	padding:30px 30px 30px 30px;
	text-align: center;
}
.note2{
	padding-top:20px;
}
.chk{
	border: solid 1px red !important;
}

#mfp_hidden{
	display: none;
}

/* movie */
.video_4 {
    width: 100%;
    padding-bottom: 50px;
    filter: drop-shadow(0px 0px rgba(0,0,0,0));
    outline: none;
    border: none;
}

.mv_area{
	padding-top:150px;
	width: 100%;
	overflow: hidden;
}
.mv_area .wrap{
	width: 80%;
	margin:0 auto;
	overflow: hidden;
	border-bottom: solid 1px #000;
}
.mv_area .wrap .video{
}
.mv_area .wrap .info{
	padding-top: 40px;
}
.mv_area .wrap .title{
	font-size: 1.5rem;
	font-family: 'Open Sans', sans-serif;
}
.mv_area .wrap .note{
	padding-top: 20px;
	font-size: 1.0rem;
	line-height: 25px;
	padding-bottom: 80px;
	font-weight: 400;
}
.ow{
	font-size: 1.5rem;
	padding-left: 10px;
	font-family: 'Open Sans', sans-serif;
}

.mv_area .container {
    width: 100%;
	margin: 0 auto;
    padding-top: 20px;
    padding-bottom: 0px;
	overflow: hidden;
}
.mv_area .gridSizer {
    width: 25%;
}
.mv_area .grid-item { 
	width: calc(50% - 50px); 
	padding	: 25px; 
	margin-bottom:20px;
	overflow: hidden;
}
.mv_area .grid-item_100 { 
	width: calc(100% - 50px); 
	margin-bottom:20px;
	overflow: hidden;
	padding:0 25px 0 25px;
}
.mv_area .grid-item img{
	width: 100%;
    border:0;
	display: block;
}
.mv_area .grid-item_100 img{
	width: 100%;
	display: block;
    border:0;
}
.mtpad{
	padding-left: 25px;;
}

/* fadeUp */

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
	from {
	opacity: 0;
	transform: translateY(100px);
	}

	to {
	opacity: 1;
	transform: translateY(0);
	}
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
	
.fadeUpTrigger{
	opacity: 0;
}
	
.v_wrap{
	display: block;
	position: relative;
	transition: all 800ms 0s ease;
}
.v_wrap::after{
    content: "";
    width: 100%;
    height: 100%;
    background: #000;
	opacity:0;
    position: absolute;
    top: 0;
    left: 0;
	transition: all 800ms 0s ease;
}
.v_wrap:hover::after{
    content: "";
    width: 100%;
    height: 100%;
    background: #000;
	opacity:0.6;
    position: absolute;
    top: 0;
    left: 0;
}
.pager{
	width: 100%;
	margin:0 auto;
	border-top: 1px solid #D8D8D8;
	border-bottom: 1px solid #D8D8D8;
	padding:30px 0 30px 0;
	margin-bottom: 150px;
	position: relative;
}
.pager p{
	font-family: 'Open Sans', sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	color: #000;
}
.pager .padd{
	padding:0 30px 0 30px;
}
.pager p a{
	color: #000;
}
.pager .p1{
	position: absolute;
	top:30px;
	left:10px;
}
.pager .p2{
	text-align: center;
}
.pager .p3{
	position: absolute;
	top:30px;
	right:10px;
}