@charset "utf-8";

/***********************************************************************************************************************
* 基本構造
***********************************************************************************************************************/

body {
	color:#fff;
	font-weight: 300;
	letter-spacing: 0.07em;
}
body *{	-webkit-box-sizing: border-box; box-sizing: border-box;}
a,button{cursor: pointer; -webkit-transition: opacity 0.3s ease; transition: opacity 0.3s ease;}
a:hover,button:hover{ opacity: 0.5;}
picture,main{ display: block;}


/*画像幅100%*/
img{ max-width: 100%; height: auto;}
img.wide{ width: 100%; height: auto;}
/*table*/
table{width: 100%;}
th{text-align: left; font-weight: bold;}

/*見出し*/
h1,h2,h3,h4,h5,h6,th{font-weight:300; letter-spacing: 0.07em; }


/*フレックスボックス*/
.flex{ display: -ms-flexbox; display: -webkit-flex; display: flex;}
.flex-wrap{ -webkit-flex-wrap: wrap; flex-wrap: wrap;}
.flex.revs{ -webkit-flex-direction: row-reverse; flex-direction:row-reverse;}
.flex.va-cent{ -webkit-align-items: center; align-items:center;}
.flex.jc-cent{ -webkit-justify-content: center; justify-content: center;}
.flex.jc-right{ -webkit-justify-content: flex-end; justify-content: flex-end;}

/*画像切り替えなど*/
.sp{ display: none !important; }
.pc{ display:block !important; 
}

/*ローディング*/
#loader-bg { position: fixed; width: 100%; height: 100%; top: 0px; left: 0px; background: transparent; z-index: 10;}/**/
#loader {display: block;position: absolute;top: 45%;width: 100%;height: 60px;left: 0;-webkit-transform: translate(0, -50%);transform: translate(0, -50%);text-align: center;z-index: 100;}
/*ローダー・サークル*/
.loader1{ width:45px; height:45px; border-radius:50%; border:2px solid rgba(0,0,0,0.2); border-top-color:rgba(0,0,0,0.4); box-sizing:border-box; display: inline-block; animation:loading 0.6s linear infinite; -webkit-animation:loading 0.6s linear infinite;}
	@keyframes loading{ 0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)}}
	@-webkit-keyframes loading{0%{-webkit-transform:rotate(0deg)}100%{-webkit-transform:rotate(360deg)}}

.opa{
	-webkit-transition: opacity 1.2s ease-out ;
	transition: opacity 1.2s ease-out ;
	opacity:1;
}
.opa.animated{
	opacity: 0;
}


html.lock body{
	overflow: hidden;
	height: 100vh;
}
html{
	overflow-y: scroll;
	height: auto;
}


#all-wrap{
	position: relative;
	opacity: 0;
	z-index: 1;
	overflow: hidden;
}
#all-wrap.active{
	opacity: 1;
	-webkit-transition: opacity 1s cubic-bezier(0.810, 0.140, 0.420, 0.630) 0.5s;
	transition: opacity 1s cubic-bezier(0.810, 0.140, 0.420, 0.630)  0.5s;
}


.wrap{
	max-width: 900px;
	margin:0 auto;
	padding:  0 50px;
}


.page-ttl{
	margin-bottom: 50px;
	opacity: 0;
}

.page-ttl img {
    width: 427px;
}

.page-ttl.active{
	-webkit-transition: opacity 0.8s ease-out ;
	transition: opacity 0.8s ease-out ;
	opacity: 1;
}

#progress-frame{
	position: relative;
	max-width: 140px;
	height: 1px;
	background:#c0c0c0;
	margin: 0 auto;
	opacity: 0;
	overflow: hidden;
}

#progress-frame.active{
	-webkit-transition: opacity 0.5s ease-out 0.8s ;
	-moz-transition: opacity 0.5s ease-out 0.8s ;
	-ms-transition: opacity 0.5s ease-out 0.8s ;
	-o-transition: opacity 0.5s ease-out 0.8s ;
	transition: opacity 0.5s ease-out 0.8s ;
	opacity: 1;
}

#progress-bar{
	height: 1px;
	width: 1%;
	background:#3c3c3c;
}


/*リサイズ時アニメーション回避*/
body.noduration *,
body .fin{ transition-delay: 0 !important; transition-duration: 0 !important;}

/*背景画像デフォルト設定*/
.bgcover{-webkit-background-size:cover;background-size:cover;background-repeat: no-repeat;background-position: center;}


.video-wrap{
	position: fixed;
	z-index: -1;
	width: 100%;
	height: 100%;
	left:0;
	top:0;
	overflow: hidden;
	  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  transform: translate3d(0, 0, 0) !important;

}

.video-wrap video {
    position: absolute;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    left: 0;
    bottom: 0;
    z-index: 1;
}


.video-wrap .movie{
	content:"";
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top:0;
	left:0;
	z-index: 1;
}


.video-wrap .black-layer{
	content:"";
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top:0;
	left:0;
	background: #000;
	opacity: 0.2;
	z-index: 2;
	-webkit-transition: opacity 0.8s ease-out;
	-moz-transition: opacity 0.8s ease-out;
	-ms-transition: opacity 0.8s ease-out;
	-o-transition: opacity 0.8s ease-out;
	transition: opacity 0.8s ease-out;
	
}
.video-wrap .black-layer.active{
	opacity: 0.5;
}

.contents{
	position:relative;
	z-index: 2;
	width: 100%;

}

.first-block{
	position: relative;
	height: 100vh;
}

.first-block .first-block-catch{
	position: absolute;
	left:50px;
	bottom:50px;
}

.first-block .first-block-catch img{
	opacity: 0;
	width: 345px;
}
.first-block .goscroll{
	opacity: 0;
}

.first-block .goscroll-img span.active{
	opacity: 1;
}


.first-block .goscroll-img{
	position: absolute;
	left:0;
	bottom:50px;
	width: 100%;
	text-align: center;
	-webkit-animation: sdb 2s infinite;
	animation: sdb 2s infinite;
	box-sizing: border-box;
}

.first-block .goscroll-img img{
	opacity: 1;

}

.first-block .goscroll-img span{
	display: inline-block;
	-webkit-transition: opacity 0.8s ease;
	transition: opacity 0.8s ease;
	opacity: 1;
}


.first-block .goscroll-img span.active{
	opacity: 0;
}






@-webkit-keyframes sdb {
  0% {
    -webkit-transform:  translate(0, 0);
  }
  20% {
    -webkit-transform:  translate(0px, 5px);
  }
  40% {
    -webkit-transform:  translate(0, 0);
  }
}



/***********************************************************************************************************************
* 基本レイアウト
***********************************************************************************************************************/

header{
	position: fixed;
	z-index: 10;
	width: 100%;
	opacity: 0;
}


header .header-logo{
	padding-top: 44px;
	padding-left: 50px;
}

header .header-logo>img{
	width: 311px;
}

header .header-info{
	position: absolute;
	right:50px;
	top: 44px;
	text-align: right;
}

header .header-place img{
	width: 266px;
}
header .header-period {
	padding: 10px 0 15px;
}
header .header-period img{
	width: 247px;
}
header .header-free img{
	width: 78px;
}




header .powered{
	margin-top: 7px;
}
header .powered>span{
	display: inline-block;
	margin-right:5px;
	font-size: 	1rem;
	padding-top: 12px;
}
header .powered i{
	width: 92px;
	display: inline-block;
}
header .powered i img{
	margin-bottom: -6px;
}

.about-catch>span {
    margin-top: -5px;
    font-size: 1.3rem;
}

/***********************************************************************************************************************
* パーツ parts
***********************************************************************************************************************/

.headline-lg{
	position: relative;
	font-size: 3rem;
	letter-spacing: 0.07em;
	line-height: 1em;
}
.headline-lg::after{
	content:"";
	position: absolute;
	display: block;
	width: 100%;
	height: 1px;
	bottom:0;
	left:0;
	background: #fff;
}



.section th>i{
	display: none;
}

.section a{
	color:#fff;
	text-decoration: underline;
}


/***********************************************************************************************************************
* トップページ
***********************************************************************************************************************/
.section{
	padding-top: 250px
}




#about{
}

.about-catch{
	font-size: 3rem;
	line-height: 1.8em;
	margin:70px 0 20px;
	white-space: nowrap;
	font-weight: 	400;
}
.about-catch>em{
	font-size: 3rem;
	font-weight: 	400;
}


.about-catch>span{
	display: block;
	margin-top: -5px;
	font-size: 1.7rem;
}

.about-period{
	display: block;
	font-size: 2.2rem;
	line-height: 2.4em;
	margin-bottom: 40px;
}


.about-txt p{
	font-size: 1.8rem;
	line-height: 2.4em;
	letter-spacing:0.08em;
}

#works{}
.works-catch{
	margin:67px 0 57px;
	font-size: 2.2rem;
	line-height: 2em;

}
.works-list{
	margin-top:80px;
}

.works-list>li{
	width: 31.13%;
	margin-right: 3.3%;
	margin-bottom: 34px;
}

.works-list>li:nth-child(3n){
	margin-right: 0;
}

.works-subttl{
	margin: 30px 0 15px;
}

.works-intro-txt{

	margin-bottom: 30px;
}
.works-intro-txt p{

	font-size: 1.6rem;
	line-height: 1.875em;
	letter-spacing: 0.05em;
}

.works-intro-txt .author{
}


.works-txt p{
	font-size: 1.6rem;
	line-height: 1.875em;
	letter-spacing: 0.05em;
}

#profile{}
.host{
	margin-bottom: 60px;
}
.host-post{
	margin-top: 80px;

}
.host-name{
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
}
.host-name>.jp{
	font-size: 4.2rem;
	letter-spacing: 0.195em;
}
.host-name>.rm{
	padding-top: 18px;
	padding-left: 27px;
}

.profile-txt{}
.profile-txt p{
	line-height: 2.25em;
}
.profile-txt a{
	color:#fff;
	
	text-decoration: underline;
}

.profile-tbl{
	margin-top: 80px;
	width: 100%;
}
.profile-tbl>tbody{}
.profile-tbl>tbody>tr{}
.profile-tbl>tbody>tr>th{
	width: 30%;
	line-height: 2.25em;
}
.profile-tbl>tbody>tr>td{
	line-height: 2.25em;
	width: 70%;
	padding-bottom: 45px;
}

.profile-img{
	margin-top: 40px;
}

.profile-tbl>tbody>tr>th{
display: none;
}

.outline-box{
	margin-bottom: 40px;
}


.outline-mail{
	margin-top:70px;
}

.outline-mail .cel1{
	padding-right: 1em;
}

.outline-mail .cel2{
	text-decoration: none;
}
.outline-inr-tbl {
    width: 100%;
    margin-top: 40px;
}

.outline-inr-tbl .mgn {
    width: 100%;
    margin-left: -0.5em;
}


.outline-main-tbl{
	width: 100%;
}
.outline-main-tbl{

}
.outline-main-tbl>tbody>tr{
}
.outline-main-tbl>tbody>tr>th{
	width: 180px;
	white-space: nowrap;
	line-height: 1.875em;
}
.outline-main-tbl>tbody>tr>td{

}

.outline-inr-tbl{
	width: 100%;
	margin-top: 80px;
}
.outline-inr-tbl>tbody{}
.outline-inr-tbl>tbody>tr{}
.outline-inr-tbl>tbody>tr>th{
	width: 20%;
	line-height: 1.875em;
	white-space: nowrap;
}
.outline-inr-tbl>tbody>tr>td{
	line-height: 1.875em;
}

.outline-address{
	margin-bottom: 40px;	
}
.outline-mwrap{}
.outline-map a:hover{
	opacity: 1;
}
.outline-map-link{
	color:#fff;
	font-size: 1.4rem;
	text-decoration: underline;
}

.outline-subttl{
	margin-bottom: 15px;
}

.outline-inr-logo img{
	width: 130px;
	margin-left: -8px;
	margin-bottom: -2px;
}


.short-tbl{}
.short-tbl>tbody{}
.short-tbl>tbody>tr{}
.short-tbl>tbody>tr>th{
	white-space: nowrap;
}
.short-tbl>tbody>tr>td{
	padding-bottom: 20px;
}

.short-tbl>tbody>tr>th {
    padding-right: 1em;
}

.short-tbl>tbody>tr{
}

.short-tbl-list{
	margin:20px 0;
}
.short-tbl-list>li{
	position: relative;
	padding-left: 150px;
}
.short-tbl-list>li i{
	display: inline-block;
	width: 1em;
}
.short-tbl-list>li>span{
	position: absolute;
	left:0;
	top:0;
}


footer {
    position: relative;
    padding: 250px 0 55px;
    z-index: 1000;
    text-align: center;
}

footer .gotop{}




