@charset "UTF-8";
/*-----------------------------
　リセットCSS
------------------------------*/

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;
}
/* HTML5 display-role reset for older browsers */
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 {
	margin:0 auto;
	padding: 0;
	background-color:#000;
	font-size:15px;
	font-family:	"ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	font-family: 'Palatino Linotype', 'Book Antiqua', Palatino, serif;
	color:#FFF;
	line-height:1.5;
	list-style-type:none;
	overflow-y: scroll;
}
a {
	color:#fff;
	text-decoration: none;
}
h1, p {
	margin: 0;
	padding:0;
}
h1 {
	font-size:22px;
	font-weight:bold;
}
h2 {
	font-size:20px;
	font-weight:bold;
}
/*---------	header ----------*/
#header {
	padding: 0;
	margin-left:30px;
}
#logo {
	margin-bottom: 10px;
	width:165px;
	float:left;
}
.button-toggle {
	display: none;
}
/*-----	nav1 -----*/
#nav1 {
	margin-top:22px;
	position:relative;
}
#nav1 ul {
	font-size:18px;
}
#nav1 ul li {
	list-style-type: none;
	display: inline;
}
#nav1 ul li a {
	display: block;
	float: left;
	padding: 1px 0 10px 0;
	margin: 0 50px;
	margin-right: -1px;
	color: #fff;
	/*text-decoration: none;*/
	text-shadow:0 0 5px #313131;
}
#nav1 li a:hover {
	border-top:dotted 1px #fff;
}
#nav1 li span {
	display: none;
	float: left;
	width: 600px;
	position: absolute;
	left:213px;
	top: 30px;
	font-size:14px;
	color: #fff;
	font-family:Arial, Helvetica, sans-serif;
	background-image:url(img/glid1.png);
	background-repeat: no-repeat;
}
#nav1 li span.jp {
	width: 380px;
	background-image:url(img/glid2.png);
}
#nav1 li span a {
	display: inline;
	text-shadow:0 0 5px #313131;
	margin:15px 14px 3px 14px;
	padding:3px 0 4px 0;
}
#nav1 li span a:hover {
	border-top:none;
	border-bottom:dotted 1px #fff;
}
#nav1 li span .span_first {
	margin-left:0;
}
#nav1 li span .span_last {
	margin-right:0;
}
#nav1 li:hover span {
	display: block;
}
#nav1 li .current {
	font-weight: bold;
	border-top:dotted 1px #fff;
}
/*-----	nav2 -----*/
#nav2 ul {
	margin-top:22px;
	margin-right: 30px;
	font-size:14px
}
#nav2 ul li {
	display: inline;
}
#nav2 ul li a {
	display: block;
	float: right;
	padding: 3px 2px;
	margin-right: 15px;
	color: #ffffff;
	text-shadow:0 0 5px #313131;
}

#nav2 ul li a:hover {
	border-bottom:dotted 1px #fff;
}
/*-----	nav1 & nav2-----*/
#nav1 li span .current, #nav2 li .current {
	border-top:none;
	font-weight: bold;
	border-bottom:dotted 1px #fff;
}
/*---------	footer ----------*/
#footer {
	margin-top:80px;
	padding:10px 0;
}
#footer .inner {
	width:90%;
	margin:0 auto;
	overflow:hidden;
}
/*---------	etc ----------*/
.pagename {
	display:none;
}
#page-top {
	position: fixed;
	bottom: 20px;
	right: 30px;
	text-align:center;
}
#page-top a {
	display: block;
	/*text-decoration: none;*/
	width: 30px;
	padding: 12px 0;
	text-align: center;
	color: #FFF;
	text-shadow:1px 1px 6px #000;
}
#page-top a:hover {
/*text-decoration: none;*/
}
.bgslideshow {
	position:fixed;
	left:0;
	top:0;
	z-index: -1;
	height:100%;
	width:100%;
}
.bgslideshow img {
	position: absolute;
	left:0;
	top:0;
	min-height:100%;
	min-width:100%;
	height: auto;
	width:100%;
}
#loader {
    width: 48px;
    height: 48px;
    display: none;
    position: fixed;
    _position: absolute; /* IE6対策 */
    top: 50%;
    left: 50%;
    margin-top: -24px; /* heightの半分のマイナス値 */
    margin-left: -24px; /* widthの半分のマイナス値 */
    z-index: 100;
}

#fade {
    width: 100%;
    height: 100%;
    display: none;
    background-color: #000;
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 50;
}
/*---------	clearfix  ----------*/
.clearfix:after {/*for modern browser*/
	content: "";
	display: block;
	clear: both;
}
* html .clearfix {
	zoom:1;
} /*for IE6*/
*:first-child+html .clearfix {
	zoom:1;
} /*for IE7*/
/*-----------------------------
	TOP
------------------------------*/
#top #logo {
	text-indent:0;
	background-image:none;
	width:210px;
}
#top #nav1, #top #nav2 {
	margin-top:30px;
}
#top #nav1 li span {
	left:260px;
	top: 30px;
}
#top #main {
	position: absolute;
	right:30px;
	bottom:30px;
}
#top h2 {
	font-size:18px;
	font-weight:normal;
	border-bottom:1px dotted #fff;
	margin-bottom:5px;
}
#top h3 {
	font-size:13px;
}
/*-----------------------------
	NEWS
------------------------------*/
#news #main {
	width:90%;
	margin:auto;
	overflow:hidden;
}
#main #news_right {
	color:#000;
	width:70%;
	background-color: rgba(255, 255, 255, 0.9);
	float:right;
}
#news h2 {
	border-bottom:1px dotted #000;
	margin-bottom:10px;
	font-size:17px;
}
#news h3 {
	line-height:1;
	margin-bottom:10px;
	font-size:16px;
	font-weight:bold;
}
#news h4 {
	font-size:15px;
	border-bottom:1px dotted #FFF;
	margin-bottom:10px;
}
#news .article_1 {
	padding:30px;
	margin:10px 0;
}
#main #news_left {
	display:block;
	width:200px;
	float:left;
}
.recent {
	margin-top:0px;
}
.archive, .category {
	margin-top:40px;
}
aside .day {
	font-size:11px;
	text-align:left;
}
.day {
	font-size:14px;
	text-align:right;
}
/*-----------------------------
	ABOUT
------------------------------*/
#about #main {
	margin-left:40px;
	line-height:2.3;
	font-size:15.5px;
}
#about h2 {
	margin-bottom:8px;
	font-size:18px;
}
#about #main .about_text1 {
	margin-top:20px;
}
#about #main .about_text2 {
	margin-top:30px;
}
#about #main dl{
	overflow:hidden;
}
#about #main dt{
	float:left;
	margin-right:20px;
}
#about #main .meme{
	padding-top:20px;
}
#about #main .about_text3 {
	margin-top:40px;
}
#about #main .about_text3 p {
	width:600px;
	border-bottom:dotted 1px #fff;
	padding:4px 0 0 0;
	font-size:14px;
}
#about #main .about_text4 {
	margin-top:40px;
}
#about #main .about_text4_sub {
	width:600px;
	box-sizing:border-box;
	border:dotted 1px;
	padding:8px;
}
#about #main .about_text4_sub a{
	border-bottom:dotted 1px;
}
#about #main .about_text4_sub a:hover{
	background-color: rgba(0, 0, 0,0.7);
}
/*-----------------------------
	WORKS
------------------------------*/

#works #nav1 li span {
	display: block;
}
#works #main {
	margin:auto;
	margin-top:60px;
}
#works_1, #works_2, #works_3, #works_4 {
	position: relative;
	width: 25%;
	float:left;
}
#works h2 {
	position:absolute;
	width:100%;
	top:48%;
	padding:15px 0px;
	text-shadow:0 0 7px #000;
	text-align:center;
	font-size:18.5px;
	font-weight:bolder;
	letter-spacing: 0.11em;
}
#works figure {
	overflow: hidden;
	height:450px;
	background-size: cover;
}
#works_1 figure {
	background-image: url(img/works_1.jpg);
}
#works_2 figure {
	background-image: url(img/works_2.jpg);
}
#works_3 figure {
	background-image: url(img/works_3.jpg);
}
#works_4 figure {
	background-image: url(img/works_4.jpg);
}
#works figcaption {
	position: absolute;
	display:table;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	height:450px;
	background: rgba(0,0,0,1);
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	-ms-transition: 0.3s;
	transition: 0.3s;
	opacity: 0;
	text-align:left;
}
#works figcaption .figcaption_inner {
	display:table-cell;
	padding:20px;
	vertical-align:middle;
	line-height:1.6em;
}
#works figure:hover figcaption {
	opacity: 1;
}
/*-----------------------------
	WORKS_GROUP
------------------------------*/
#works_group #nav1 li span {
	display: block;
}
#works_group #main {
	width:100%;
}
#works_text {
	margin:auto;
	width:1100px;
	margin-top:30px;
	margin-bottom:30px;
	overflow:hidden;
}
#works_text .w_title {
}
#works_text h1 {
	margin-bottom: 5px;
}
#works_group h2 {
	font-size:17px;
	font-weight:bold;
	letter-spacing: 0.1em;
}
#works_text_right .caption {
	font-size:15px;
	letter-spacing: 0.1em;
}
.caption {
	font-size:17px;
	letter-spacing: 0.1em;
}
.size {
	font-size:13px;
}
/* サムネイル
------------------------- */
#works_group #main .listCover {
	margin:auto;
	width:1100px;
	text-align: left;
	position: relative;
	overflow:hidden;
}
/* サムネイル画像
------------------------- */

#works_group #main .listCover .listItem {
	width: 200px;
	padding:0;
	margin:0px 20px 20px 0px;
	text-align: left;
	float:left;
	cursor: pointer;
}
.listCover .listItem img {
	width: 200px;
}
#works_group #main .etc li {
	display: none;
}
.listCover .listItem .selfRep {
	display: none;
}
#works_group figure {
	position: relative;
	overflow: hidden;
	width: 200px;
}
#works_group figcaption {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	width: 190px;
	height: 190px;
	background: rgba(0,0,0,0.8);
	-webkit-transition: .3s;
	-moz-transition: .3s;
	-o-transition: .3s;
	-ms-transition: .3s;
	transition: .3s;
	opacity: 0;
	text-align:center;
	padding:5px;
}
#works_group .figcaption_inner {
	position:absolute;
	top:50%;
	left:50%;
	width:100%;
	margin:-1.5em 0 0 -50%;
}
#works_group figure:hover figcaption {
	opacity: 1;
}
/* .expandField
------------------------- */
.expandField {
	margin: 0 auto;
	padding: 5px 0px;
	width: 100%;
	text-align: left;
	display: block;
	background: #000;
	float: left;
	position: relative;
	overflow: hidden;
}
.expandField .btnClose {
	top: 0px;
	right: 0px;
	width: 20px;
	height: 20px;
	display: block;
	background: url(img/close.png) no-repeat top left;
	position: absolute;
	overflow: hidden;
	cursor: pointer;
}
.expandField .btnPrev {
	left:0px;
	top:50%;
	margin-top:-50px;
	width: 20px;
	height: 46px;
	display: block;
	background: url(img/btn_2.png) no-repeat top left;
	position: absolute;
	overflow: hidden;
	cursor: pointer;
}
.expandField .btnNext {
	right:0px;
	top:50%;
	margin-top:-50px;
	width: 20px;
	height: 46px;
	display: block;
	background: url(img/btn_1.png) no-repeat top left;
	position: absolute;
	overflow: hidden;
	cursor: pointer;
}
.expandField .selfRepInner {
	padding: 10px 30px;
	text-align: center;
	position: relative;
}
.expandField .selfRepInner .secLeft {
	text-align: center;

	position: relative;
}
.expandField .selfRepInner .secRight {
	padding:10px 0 5px 0;
	text-align: center;
	color: #fff;
}
/*	clearfix
------------------------------*/
.listCover:before, .listCover:after, .expandField .selfRepInner:before, .expandField .selfRepInner:after {
	content: " ";
	display: table;
}
.listCover:after, .expandField .selfRepInner:after {
	clear: both;
}
.listCover, .expandField .selfRepInner {
	zoom:1;
}
/* 	Paging
------------------------------*/
#paging {
	text-align: center;
	position: absolute;
	width:100%;
	bottom:10px;
	z-index:100;
}
#paging li {
	display: inline-block;
	*display: inline;
 	*zoom:1;
	width:15px;
	height:15px;
	background: url(./img/page.png);
	margin:0 5px;
	cursor:pointer;
}
#paging li.paging_active {
	background: url(./img/page_active.png);
}
/*-----------------------------
	CONTACT
------------------------------*/
#contact #main {
	margin-top:40px;
}
#contact h1, #about h2 {
	margin-bottom:8px;
}
#contactt h2 {
	font-size:18px;
}
#contact .rgba {
	width:75%;
	padding:30px 25px 25px 25px;
	margin:auto;
	background-color: rgba(255, 255, 255,0.9);
	color:#000;
}
#contact .rgba a {
	color:#000;
	border-bottom:1px #000 solid;
}
#contact .contact_text {
	font-size:14px;
}
#contact .contact_form {
	margin:40px 0;
}
#contact .contact_form h2{
	width:100%;
	border-bottom:1px #000 dashed;
	margin-bottom:10px;
}
#contact form {
	overflow:hidden;
	width:95%;
	margin:auto;
}
#contact form label{
	line-height:2.3;
}
#contact form input ,#contact form textarea{
	width:100%;
	box-sizing:border-box;
}
#contact .form_left {
	float:left;
	width:35%;
}
#contact .form_right {
	float:right;
	width:60%;
}
#contact .form_text, textarea, .dropdown {
	border:1px solid #777;
	padding: 5px;
	background: #fff;
	border-radius: 5px;
	/* Webkit */
   background: -webkit-gradient(  linear,  left top,  left bottom,  from(#eee),  to(#fff)  );
	-webkit-border-radius: 5px;
	/* Firefox */
   background: -moz-linear-gradient(  top,  #eee,  #fff  );
	-moz-border-radius: 5px;
   /* IE */
   /*filter:progid:DXImageTransform.Microsoft.gradient  (startColorstr=#ffeeeeee, endColorstr=#ffffffff);*/
	zoom: 1;
}

#contact .form_submit{
	overflow:hidden;
	width:100%;
	margin:auto;
}
#contact .submit{
	width:150px;
	margin-top:10px;
	float:right;
   border:1px solid #333;
   padding: 4px 10px;
   color: #fff;
   cursor: pointer;
   background: #000;
   border-radius: 5px;
}


@media screen and (min-width : 1700px) {
	#works #main {
		margin-top:140px;
	}
	#works_text {
		width:1440px;
		margin-top:50px;
		margin-bottom:50px;
	}
	/* サムネイル
	------------------------- */
	#works_group #main .listCover {
		width:1440px;
	}
	/* サムネイル画像
	------------------------- */
	#works_group #main .listCover .listItem {
		margin:0px 40px 40px 0px;
	}
}
