@charset "UTF-8";
/* CSS Document */

@import url("../HuiFont29/stylesheet.css");
#story,#story2,.works_title {
	font-family: HuiFont29;
}

@font-face {
  font-family: 'Daniel';
    src:  url('font/Daniel.ttf.woff') format('woff'),
    url('font/Daniel.ttf.svg#Daniel') format('svg'),
    url('font/Daniel.ttf.eot'),
    url('font/Daniel.eot?#iefix') format('embedded-opentype'); 
    font-weight: normal;
    font-style: normal;
}

.font_space {letter-spacing: -3.5px;}

#demo01 a{
	display: block;
	width: 211px;
	height: 35px;
	background: url(../img/all.png) no-repeat 0 0;
	margin:0 auto;
	-webkit-transition: 0.3s ease-in-out;
	   -moz-transition: 0.3s ease-in-out;
	     -o-transition: 0.3s ease-in-out;
	        transition: 0.3s ease-in-out;
}
#demo01 a:hover {
	background-position: 0 bottom;
}


/* #filter
--------------------------- */
#filter {
	margin: 0 auto;
	padding: 15px 0;
	width: 1050px;
	text-align: center;
}
#filter a:link { text-decoration:underline; color: #000;}
#filter a:visited { text-decoration:none; color: #000;}
#filter a:active { text-decoration:none; color: #000;}
#filter a:hover { text-decoration:none; color: #000;}

#filter .active {
	font-weight: bold;
}
#filter a.active:link { text-decoration:none; color: #000;}
#filter a.active:visited { text-decoration:none; color: #000;}
#filter a.active:active { text-decoration:none; color: #000;}
#filter a.active:hover { text-decoration:none; color: #000;}

/* #filterlist
--------------------------- */
#filterlist {
	margin: 0 auto;
	text-align: left;
}

#filterlist ul {
	margin: 0 auto;
	padding: 0;	
	text-align: left;
}

#filterlist ul li {
	margin: 5px;
	width: 340px;
	text-align: left;
	float: left;
	display: inline;
	overflow: hidden;
	
}

#filterlist ul li a{
	opacity: 0.5;
}

#filterlist ul li img{
	width: 340px;
	float: left;
	opacity: 0.5;
	
}





/* =======================================
	ClearFixElements
======================================= */
#filterlist ul:after {
	content: ".";
	height: 0;
	clear: both;
	display: block;
	visibility: hidden;
}

#filterlist ul {
	display: inline-block;
	overflow: hidden;
}

.works_bt{margin:50px auto;
text-align:center;}






::selection {
  background-color: #ffff00;
  color: #000;
}

/* Firefox */
::-moz-selection {
  background-color: #ffff00;
  color: #000;
}


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, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font-family: inherit;
	font-style: inherit;
	font-weight: inherit;
/*	outline: 0;*/
}

a:link{
  color: #000;
  text-decoration: underline;
}
a:visited{
   color: #000;
  text-decoration: underline;
}
a:hover{
  color: #000;
}
a:active{
  color: #000;
  text-decoration: underline;
}


html { font-size: 62.5%; }


strong {
  background: linear-gradient(transparent 0%, #ffffff 0%);
}

.clear{ clear: both; line-height: 0}

body {
	overflow-x: hidden;
font-size: 1.2rem;
}

#wrapper {
margin:0 auto;
width:1050px;
}


#top_menu{
	padding-top:50px;
	text-align:right;
    top: 0;
    right:0;
  z-index: 999;height: 50px;
margin:0 auto;
width:1050px;  
  }


#header_img{
position: relative ;
min-height:600px;
margin:0 auto;
width:1050px;  }


.story_pic1{
	  position: absolute;
  left: 350px;z-index: 1;}
  
  
 .thinking_pic1{
	  position: absolute;
  left: 350px;z-index: 1;} 
  

  
 .story_pic2{
	  position: absolute;
  left: -200px;
  top:350px;z-index: 1;} 
#logo  {
	  position: absolute;
  top: 100px;z-index: 2;}
 
#logo2  {
	  position: absolute;
  top: 100px;z-index: 2;}  
 .story_text1{	  
	  padding:10px;margin-top:10px;
	  } 
	  
	  
#work{margin:0 auto;
width:1050px; }

.work_left{
	float:left;
	width:24%;
	line-height: 200%;
	}
.work_right{
float:left;
	width:66%;
	margin-left:10%;	
}

 .works_photo{
	 margin-bottom:20px;}  
	 
 .works_photo2{
	 margin-bottom:60px;}  	 
 .works_title{
	 margin-top:60px; font-size: 200%;line-height: 150%;}   
 .works_info{
	 margin-top:10px;margin-left:10px;}  
	 
 .works_info2{
	 margin-top:60px;border-bottom:1px #999999 dashed;font-size: 120%;}  	  	 
  

#story{position: relative ;
line-height: 150%;
font-size: 150%;
min-height:1550px;
}
.story_pic3{
	  position: absolute;
  left: 400px;z-index: 1;}
.story_pic4{
	  position: absolute;
  left: 0px;
  top:350px;z-index: 1;}
.story_pic5{
	  position: absolute;
  left: 550px;
  top:700px;z-index: 1;} 
.story_pic6{
	  position: absolute;
  left: -100px;
  top:1050px;z-index: 1;}  
.story_pic7{
	  position: absolute;
  left:500px;
  top:1150px;z-index: 1;}  
  
  
 .story_text2{
	  position: absolute;
  top: 120px;z-index: 2;font-size: 110%;} 
  .story_text3{
	  position: absolute;
  top: 500px;
  left: 450px;z-index: 2;} 
  .story_text4{
	  position: absolute;
  top: 850px;
  left: 50px;
  z-index: 2;}
  .story_text5{
	  position: absolute;
  top: 1425px;
  left: 50px;
  z-index: 2;} 





  
 #story2{position: relative ;
line-height: 150%;
font-size: 150%;
text-align:center;
margin-bottom:100px;
} 

.story_pic8{
	  margin-top:50px;
	   margin-bottom:50px;} 

.story_text6{} 	
.story_text7{} 	
   
   
#works_top {
margin:0px auto;
width:1050px;
} 
#works_top ul {
	margin: 0;	
	list-style: none;
	line-height: normal;
}
#works_top li {
}  
#works_top li.list1 {
	float: left;
}    
#works_top li.list2 {
	float: right;margin-top:80px;
}     
	   
	
#slide, .slide {
	width: 100%;
	margin: 25px auto 50px;
}
#slide div {
	height: 300px;
}
.slide .contents span {
	display: block;
	height: 300px;
	margin: 0 10px;
}
.slide .nav span {
	display: block;
	margin: 0 10px;
}
#slide div:nth-child(1), .contents01 span, .nav01 span {
	
}
.slick-prev::before, .slick-next::before {
	color: #000000;
}


 #company_top {
margin:100px auto 30px;
width:1050px;
}  
  
 #company_top ul {
	margin: 0;	
	list-style: none;
	line-height: normal;
}
#company_top li {
}  
#company_top li.list1 {
	float: left;
}    
#company_top li.list2 {
	float: right;
}     
	
  
  
 #company_bottom{
	 background-color:#ebebeb;
	 background-image: url("../img/company_back.png");
	 background-position: center; 
	 width:100%;
	 padding-top:50px;
	
	 } 
	 
 #company_bottom ul {
	margin: 0;	
	list-style: none;
	line-height: normal;
	width:100%;
}
 #company_bottom li {float: left;
}  
 #company_bottom li.list3 {
	width:50%;
}    
 #company_bottom li.list4 {
	width:50%;
} 

.company_info{padding:10px;}	 
	 
.company_bottom_inner {
margin:0px auto;
width:1050px;
}   
  

.company_bottom_inner ul {
	margin: 0;	
	list-style: none;
	line-height: normal;
	width:1050px;
}
.company_bottom_inner li {float: left;
}  
.company_bottom_inner li.list1 {
	width:60%;
}    
.company_bottom_inner li.list2 {
	width:40%; margin-top:10px;
} 



    

#map_canvas { width: 99%; height: 400px;border:#aaaaaa solid 5px;} 
#map_canvas2 { width: 99%; height: 400px; border:#aaaaaa solid 5px;} 
  
   .company_bottom_prof3{width:100%;
	  background-image: url("../img/top/back.png");
background-position: center top;}
  
 .company_bottom_prof {
margin:50px auto;
width:1050px;
position:relative; 
}   
  

.company_bottom_prof ul {
	margin: 0;	
	list-style: none;
	line-height: normal;

}
.company_bottom_prof li {float: left;
}  
.company_bottom_prof li.list1 {
	width:25%;
}    
.company_bottom_prof li.list2 {
	width:35%; position: absolute;
bottom: 0; left:25%;
}     
.company_bottom_prof li.list3 {
	width:35%;position: absolute;
bottom: 0;left:65%;
}


 .company_bottom_prof2 {
margin:0 auto;
width:1050px;
position:relative; 
}   
  

.company_bottom_prof2 ul {
	margin: 0;	
	list-style: none;
	line-height: normal;
	
}
.company_bottom_prof2 li {float: left;
}  
.company_bottom_prof2 li.list1 {
	width:25%;
}    
.company_bottom_prof2 li.list2 {
	width:30%; position: absolute;
bottom: 0; left:21%;
}     
.company_bottom_prof2 li.list3 {
	width:25%;left:52%; position: absolute;
}    
.company_bottom_prof2 li.list4 {
	width:30%;position: absolute;
bottom: 0;left:73%;
}       
 
  
.copy{text-align:center;
font-size:90%;
padding:20px;
}
  
  
#bottom_logo{
text-align:center;
margin-top:100px;
margin-bottom:50px;	
	}
  
#menu{font-size:180%;font-family: 'Cutive Mono', monospace;}  
#menu a {
	position: relative;
	display: inline-block;
	transition: .3s;
	text-decoration:none;
	padding-bottom:10px;
}
#menu a::after {
	position: absolute;
	bottom: .5em;
	left: 0;
	content: '';
	width: 100%;
	height: 4px;
	background-color: #ffff00;
	opacity: 0;
	transition: .3s;
}
#menu a:hover::after {
	bottom: 0;
	opacity: 1;
}
  
  
  
  
  
  
    
    .inviewfadeIn {
        opacity: 0;
        transform: translate(-20px, 0);
        -webkit-transform: translate(-20px, 0);
        transition: 2.8s;
    }
    
    .fadeIn {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
    
    .inviewUp {
		opacity: 0;
        transform: scale(1.1, 1.1);
        -webkit-transform: scale(1.1, 1.1);
        transition: 1.8s;
    }
    
    .Up {
		opacity: 1.0;
             transform: scale(1, 1);
        -webkit-transform: scale(1, 1);
    }
    
    .inviewfadeInUp {
        opacity: 0;
        transform: translate(-20px, 0);
        -webkit-transform: translate(-20px, 0);
        transition: 2.8s;
    }
    
    .fadeInUp {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
	
	    .inviewfadeInUp2 {
        opacity: 0;
        transform: translate(-30px, 0);
        -webkit-transform: translate(-30px, 0);
        transition: 3.8s;
    }
    
    .fadeInUp2 {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
	
	    .inviewfadeInUp3 {
        opacity: 0;
        transform: translate(-40px, 0);
        -webkit-transform: translate(-40px, 0);
        transition: 4.8s;
    }
    
    .fadeInUp3 {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
	
	    .inviewfadeInUp4 {
        opacity: 0;
        transform: translate(-50px, 0);
        -webkit-transform: translate(-50px, 0);
        transition: 5.8s;
    }
    
    .fadeInUp4 {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
    
        .inviewfadeInUp5 {
        opacity: 0;
        transform: translate(50px, 0);
        -webkit-transform: translate(50px, 0);
        transition: 3.8s;
    }
    
    .fadeInUp5 {
        opacity: 1.0;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
	

.inner {
	width: 1050px;
	margin: 0 auto;
}
.inner:after {
	content: "";
	clear: both;
	display: block;
}

/* header */
#top-head {
	top: -100px;
	position: absolute;
	width: 100%;
	margin: 120px auto 0;
	padding: 20px 0 0;
	line-height: 1;
	z-index: 999;
	
	
}
#top-head a,
#top-head {
	color: #000;
	text-decoration: none;
	
}
#top-head .inner {
	position: relative;
	
}
#top-head .logo {
	float: left;
	font-size: 36px;
}

#global-nav ul {
	list-style: none;
	position: absolute;
	right: 0;
	bottom: 0;
	font-size:180%;font-family: 'Cutive Mono', monospace;
	
	
}
#global-nav ul li {
	float: left;
	position: relative;
	
	
}
#global-nav ul li a {
	padding: 0 10px;
}

#global-nav ul li.list1 a {
	padding: 0 10px; color:#fff;

}

#global-nav ul li.list2 a {
	padding: 0 10px;
letter-spacing: -3.5px;
}

#global-nav ul li.list3 a {
	padding: 0 10px;
	text-shadow: 0px 0px 2px #fff;
}

/* Btn Hover */
#global-nav ul li:after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	bottom: -10px;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
}
#global-nav ul li:hover:after {
	background: #ffff00;
	bottom: -20px;
	
}


/* Fixed */
#top-head.fixed {
	margin-top: 0;
	top: 0;
	position: fixed;
	padding-top: 10px;
	height: 50px;
	background: #fff;
	background: rgba(255,255,255,.7);

	transition: top 0.65s ease-in;
	-webkit-transition: top 0.65s ease-in;
	-moz-transition: top 0.65s ease-in;
}
#top-head.fixed .logo {
	color: #333;
}

#top-head.fixed .logo img{
	max-width: 100px;
   height: auto;
}

#top-head.fixed #global-nav ul li a {
	color: #333;
	padding: 0 10px;
	font-size:80%;
	
}

#top-head.fixed #global-nav ul li a svg{
	width:15px;
	margin-top:1px;
}

/* Fixed Btn Hover */
#top-head.fixed #global-nav ul li:after {
	bottom: -5px;
}
#top-head.fixed #global-nav ul li:hover:after {
	background: #ffff00;
	bottom: -10px;
}


/* Transition */
/*
#top-head,
#top-head .logo,
#global-nav ul li,
#global-nav ul li a {
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
}
*/



/* Toggle Button */
#nav-toggle {
	display: none;
	position: absolute;
	right: 12px;
	top: 14px;
	width: 34px;
	height: 36px;
	cursor: pointer;
	z-index: 101;
}

#nav-toggle div {
	position: relative;
}
#nav-toggle span {
	display: block;
	position: absolute;
	height: 4px;
	width: 100%;
	background: #666;
	left: 0;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 11px;
}
#nav-toggle span:nth-child(3) {
	top: 22px;
}











@media screen and (max-width: 980px) {
	article {
		padding: 0 30px;
	}
	.inner {
		width: 100%;
		padding: 0 20px;
	}
	#global-nav ul li a {
		padding: 0 20px;
	}
	#top-head.fixed #global-nav ul li a {
		padding: 0 15px;
	}

	
	
}

@media screen and (max-width: 640px) {
	#main-visual {
		height: 300px;
	}


	#top-head,
	.inner {
		width: 100%;
		padding: 0;
	}
	#top-head {
		top: 0;
		position: fixed;
		margin-top: 0;
	}
	/* Fixed reset */
	#top-head.fixed {
		padding-top: 0;
		background: transparent;
	}


	#mobile-head {
		background: #fff;
		width: 100%;
		height: 56px;
		z-index: 999;
		position: relative;
	}
	#top-head.fixed .logo,
	#top-head .logo {
		position: absolute;
		left: 13px;
		top: 13px;
		color: #333;
		font-size: 26px;
	}
	
	#top-head .logo {
		position: absolute;
		left: 13px;
		top: 13px;
		color: #333;

	}
	
	#top-head .logo img{
	max-width: 100px;
   height: auto;
}

	#global-nav {
		position: absolute;
		/* 髢九＞縺ｦ縺ｪ縺�→縺阪�逕ｻ髱｢螟悶↓驟咲ｽｮ */
		top: -500px;
		background: #333;
		width: 100%;
		text-align: center;
		padding: 10px 0;
		-webkit-transition: .5s ease-in-out;
		-moz-transition: .5s ease-in-out;
		transition: .5s ease-in-out;
	}
	#global-nav ul {
		list-style: none;
		position: static;
		right: 0;
		bottom: 0;
		font-size: 15px;
	}
	#global-nav ul li {
		float: none;
		position: static;
	}
	#global-nav ul li:after  {
		display: none;
	}
	#top-head #global-nav ul li a,
	#top-head.fixed #global-nav ul li a {
		width: 100%;
		display: block;
		color: #fff;
		padding: 18px 0;
		fill:#fff;
	}
	#top-head.fixed #global-nav ul li a svg{
		fill:#fff;
		color:#fff;
	}
	#nav-toggle {
		display: block;
	}
	/* #nav-toggle 蛻�ｊ譖ｿ縺医い繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
	.open #nav-toggle span:nth-child(1) {
		top: 11px;
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	.open #nav-toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 11px;
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}
	/* #global-nav 繧ｹ繝ｩ繧､繝峨い繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
	.open #global-nav {
		/* #global-nav top + #mobile-head height */
		-moz-transform: translateY(556px);
		-webkit-transform: translateY(556px);
		transform: translateY(556px);
	}
	
	
#top-head .logo2 {
	float: left;
	font-size: 24px;
}
#top-head.fixed .logo2 {
	color: #333;
}
#top-head.fixed .logo2,
	#top-head .logo2 {
		position: absolute;
		left: 13px;
		top: 0px;
		color: #333;
		font-size: 26px;
	}

.company_bottom_inner li.list1 {
	width:96%;padding:2%;
}    

.company_bottom_inner li.list1 img{
	width:100%;
}    

.company_bottom_inner li.list2 {
	width:96%;padding:2%;
} 


 #company_top {
margin:100px auto 30px;
width:100%;
}  

.company_info{border-bottom:1px #666 dotted;}


#company_bottom li.list3 {
	width:100%;
}    
 #company_bottom li.list4 {
	width:100%;
} 

.company_bottom_inner {
margin:0px auto;
width:100%;
} 

 .company_bottom_prof {
margin-top:25px;
margin-bottom:2%;
width:100%;
position:static; 
}     

.company_bottom_prof li.list1 {
	width:25%;position:static; 
}  
.company_bottom_prof li.list1 img{
	width:100%;
}    
.company_bottom_prof li.list2 {
width:71%;position:static; padding-left:2%;padding-right:2%;
}     
.company_bottom_prof li.list3 {
	width:92%;position:static; padding-left:4%;padding-right:4%;
}

 .company_bottom_prof2 {
margin:0 auto;
width:100%;
position:static; 
}  

.company_bottom_prof2 li.list1 {
	width:25%;position:static;
}  
.company_bottom_prof2 li.list1 img{
	width:100%;
}    
.company_bottom_prof2 li.list2 {
width:71%;position:static; padding-left:2%;padding-right:2%;
}    

  
.company_bottom_prof2 li.list3 {
	width:25%;position:static;
	clear: both; line-height: 0;
	margin-top:2%;
}  
.company_bottom_prof2 li.list3 img{
	width:100%;
}    
.company_bottom_prof2 li.list4 {
width:71%;position:static; padding-left:2%;padding-right:2%;margin-top:2%;
}    

.company_bottom_prof2 li {
}  

#wrapper{
	width:100%;}
	
#logo	{
	width:100%;position: static;}

	
#header_img{
	width:100%;min-height:10px;}

.story_text1{text-align:center;}	

.story_pic1{
	  margin-top:10px;width: 100%;
	  position: static;
	  min-height:10px;}
  
.story_pic1 img { width: 100%;} 

.works_info2{margin:10px auto; auto;width:90%} 	

#work{margin:0 auto;
width:100%;position: static;}

.work_left{
	width:100%;position: static;
	}
.work_right{
width:100%;position: static;margin:0 auto;
}





}