@charset "utf-8";

/*--------------------reset---------------------------------	*/

html {
	overflow-y: scroll;
}

body, div, dl, dt, dd, ul, ul li, h1, h2, h3, h4, h5, h6,
pre, form, fieldset, input, textarea, p, blockquote, th, td,
section, nav, article, aside, hgroup, header, address,
figure, figcaption {
	margin: 0;
	padding: 0;
}


body {
	font-family: 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
	*font-family: 'メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
	color: #333;
	background:#FFF;
	font-size: small;
	line-height: 150%;
	text-align: left;
	-webkit-text-size-adjust: none;	
}

* {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}


h1, h2, h3 {
	font-size: 100%;
	font-weight: normal;
}

ul li {
	list-style-type: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}


/*-----------------------------------------------------	*/
/*scroll design */
::-webkit-scrollbar {
	width: 8px;
}
::-webkit-scrollbar-button {
	width: 8px;
	height:5px;
}
::-webkit-scrollbar-track {
	background:#eee;
	border: thin solid lightgray;
	box-shadow: 0px 0px 3px #dfdfdf inset;
	border-radius:10px;
}
::-webkit-scrollbar-thumb {
	background:#999;
	border: thin solid gray;
	border-radius:10px;
}
::-webkit-scrollbar-thumb:hover {
	background:#7d7d7d;
}		

/*js----------------------------------------------------- */

.mfp-no-margins .mfp-figure:after {
	top: 0;
	bottom: 0;
}


/*loader----------------------------------------------------- */

#title-loader {
    width: 216px;
    height: 42px;
    display: none;
    position: fixed;
    _position: absolute; /* IE6対策 */
    top: 50%;
    left: 50%;
    margin-top: -90px; /* heightの半分のマイナス値 */
    margin-left: -108px; /* widthの半分のマイナス値 */
    z-index: 100;
}
	
#loader {
    width: 32px;
    height: 32px;
    display: none;
    position: fixed;
    _position: absolute; /* IE6対策 */
    top: 50%;
    left: 50%;
    margin-top: -16px; /* heightの半分のマイナス値 */
    margin-left: -16px; /* widthの半分のマイナス値 */
    z-index: 100;
}
 
#fade {
    width: 100%;
    height: 100%;
    display: none;
    background-color: #FFFFFF;
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 50;
}


/*js----------------------------------------------------- */

img {
	max-width: 100%;
	height: auto;
	border: 0;
}

p {
	line-height:1.5;
}


a {
	outline: none;
}

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

hr {
    border: 0;
    background: #333;
    background-image: -webkit-linear-gradient(left, #ccc, #333, #ccc);
    background-image:    -moz-linear-gradient(left, #ccc, #333, #ccc);
    background-image:     -ms-linear-gradient(left, #ccc, #333, #ccc);
    background-image:      -o-linear-gradient(left, #ccc, #333, #ccc);
}


#page-top {
	font-size:12px;
    position: fixed;
    bottom: 0;
    right: 0;
}

#page-top a {
    background: #39F;
    text-decoration: none;
    color: #fff;
    width: 100px;
    padding: 17px 8px;
    text-align: center;
    display: block;
    -webkit-border-top-left-radius: 5px;  
    -webkit-border-top-right-radius: 5px;  
    -webkit-border-bottom-right-radius: 0px;  
    -webkit-border-bottom-left-radius: 0px;  
    -moz-border-radius-topleft: 5px;  
    -moz-border-radius-topright: 5px;  
    -moz-border-radius-bottomright: 0px;  
    -moz-border-radius-bottomleft: 0px;
}

#page-top a:hover {
    background: #3CF;
}


/*-----------------------------------------------------	*/


#container {
	width: 100%;
	margin: 0 auto;
	max-width: 100%;
	background:url(../img/bg-work.jpg) repeat;	
	background-origin:content-box;
}

header {	
	width: 100%;
	background:#FFF;
}

header img {
	display:block;
}

#logo {
	float:left;
	margin: 15px 5px;
}



/*navigation*/

#main-nav {
	width: 100%;
}

#main-nav nav {
	width: 900px;
	margin: 0 auto;
	overflow: hidden;
	*zoom: 1;
	position:relative;
}



#main-nav nav ul {
	float: right;
	border-right: dotted 1px #999;
	position: absolute;
    bottom: 15px;
	right: 0;
}

#main-nav nav h3 {
	text-decoration:line-through;
}

#main-nav nav ul li {
	float: left;
}

#main-nav nav ul li a {
	letter-spacing:1px; /*文字の間隔*/
	display: block;
	padding: 8px 35px 6px;
	border-left: dotted 1px #999;
}

#main-nav nav li a:hover {
	background-color:#000;
	color:#FFF;
}



/*end*/

#main-visual {
	width: 100%;
	border-top: dotted 1px #999;
	position: relative;
	background:url(../img/bg2.png) repeat;
}

#main-visual-in {
	border-left: dotted 1px #999;
	border-right: dotted 1px #999;
	max-width: 900px;
	margin: 0 auto;	
	overflow: hidden;
	*zoom: 1;
	line-height:0;
	vertical-align:bottom;
	-ms-interpolation-mode: bicubic;
}



#main {
	width: 100%;
}

/*ワーク*/


#content {
	max-width: 900px;
	background:url(../img/bg.jpg) repeat;
	border-left: dotted 1px #999;
	border-right: dotted 1px #999;
	margin: 0 auto;
	overflow: hidden;
}


#work {
	width:100%;
	overflow:hidden;
	float:left;
	margin:0 0 10px 0;
}


#work ul {
	text-align:center;
}

#work li {
	display:inline-block;
}

#work ul li {
	color: #FFF;
}


.caption {
	display:block;
	overflow:hidden;
	position:relative; 
	width: 280px;
	float: left;
	margin: 5px 2px 0px;
	background:url(../img/bg2.png) repeat;
	/*	border: solid 3px #000; */
	border: 1px solid #000;
    box-shadow: 0px 0px 15px #666;
    cursor: default;
	padding: 0 0 2px 0;
	border-radius:5px;
	-webkit-border-top-right-radius: 5px; 
	-webkit-border-top-left-radius: 5px;   
    -webkit-border-bottom-right-radius: 5px;  
    -webkit-border-bottom-left-radius: 5px;  
    -moz-border-radius-topleft: 5px;  
    -moz-border-radius-topright: 5px;  
    -moz-border-radius-bottomright: 5px;  
    -moz-border-radius-bottomleft: 5px;
}


.caption img {
	color: transparent;
	font-size: 0;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	position: relative;
}

.preloader {
	background:url(../img/progress2.gif) center center no-repeat;
	position:relative;
	display:inline-block;
	z-index:30;
}


.caption p{
	letter-spacing:0.5px; /*文字の間隔*/
	line-height: 1;
	margin: 9px 4px 3px 4px;
	color:#FFF;
	text-align:left;
}



.caption img.coming {
	color: transparent;
	font-size: 0;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	position:absolute;
	z-index: 3;
	top: 0px;
	left: 0px;
}


.hover_shine {
    width: 280px;
	height: 160px;
	overflow:hidden;
	background:url(../img/link.png) no-repeat;
    position: absolute;
    background-position: 130px 50px; 
    left:0px; top:0px;
	opacity:0;
    -webkit-transition: background-position .1s ease;
    -moz-transition: background-position .1s ease;
    -o-transition: background-position .1s ease;
    transition: background-position .1s ease;	
}

.hover_shine:hover{
	opacity:1;
    /*Final position*/
    background-position: 130px 75px;
	background-color:rgba(0,0,0,0.4);
}


/*テキストボックス*/

/*プロフィール*/

.menu {
	width: 100%;
	margin: 0 0 10px 0;
	float:left;
	background:url(../img/bg2.png) repeat;
	padding: 5px 10px;
    /*-webkit-border-top-left-radius: 0px;  
    -webkit-border-top-right-radius: 0px;  
    -webkit-border-bottom-right-radius: 5px;  
    -webkit-border-bottom-left-radius: 0px;  
    -moz-border-radius-topleft: 0px;  
    -moz-border-radius-topright: 0px;  
    -moz-border-radius-bottomright: 5px;  
    -moz-border-radius-bottomleft: 0px; */
}

.menu span {
	letter-spacing:1px; /*文字の間隔*/
	color:#FFF;
	font-weight:bold;
}


.menu2 {
	width: 100%;
	margin: 0 0 5px 0;
	float:left;
	display:inline;
	background:url(../img/bg2.png) repeat;
	padding: 9px 10px;

    /*-webkit-border-top-left-radius: 0px;  
    -webkit-border-top-right-radius: 0px;  
    -webkit-border-bottom-right-radius: 5px;  
    -webkit-border-bottom-left-radius: 0px;  
    -moz-border-radius-topleft: 0px;  
    -moz-border-radius-topright: 5px;  
    -moz-border-radius-bottomright: 5px;  
    -moz-border-radius-bottomleft: 0px; */
}

.menu2 span {
	letter-spacing:1px; /*文字の間隔*/
	color:#FFF;
	font-weight:bold;
}


.menu3 {
	width:100%;
	margin: 0 0 5px 0;
	float:left;
	display:inline;
	background:url(../img/bg2.png) repeat;
	padding: 9px 10px;
}

.menu3 span {
	letter-spacing:1px; /*文字の間隔*/
	color:#FFF;
	font-weight:bold;
}


#profile {
	position:relative;
	width: 439px;
	float:left;
	margin: 0 auto;
	overflow: hidden;
	border-top: dotted 1px #999;
}



#profile img{
	clear:both;
	margin: 0 auto;
	border: 1px solid #000;
	background:#011B04; 
	overflow: hidden;
	display:block;
	text-align:center;
}


.p-box {
	float:left;
	margin: 10px;
	padding:20px;
	background:url(../img/bg2.png) repeat;
	color:#FFF;
	border-radius:5px;
	-webkit-border-top-right-radius: 5px; 
	-webkit-border-top-left-radius: 5px;   
    -webkit-border-bottom-right-radius: 5px;  
    -webkit-border-bottom-left-radius: 5px;  
    -moz-border-radius-topleft: 5px;  
    -moz-border-radius-topright: 5px;  
    -moz-border-radius-bottomright: 5px;  
    -moz-border-radius-bottomleft: 5px;
}

.p-box p{
	display:block;
}

.p-box h2{
	margin: 0 0 5px 0;
	font-size:14px;
	font-weight:bold;
}


/*プロフィールend*/

/*コンタクト*/

#contact {
	width: 100%;
	float:left;
	margin: 0 auto;
	overflow: hidden;
	*zoom: 1;
	border-top: dotted 1px #999;
	border-left: dotted 1px #999;
}


input {
	font-size:medium;
	width: 100%;
	max-width: 330px;
	box-sizing: border-box; /*飛び出し回避*/
}

textarea {
	font-size:medium;
	width: 100%;
	max-width: 330px;
	height: 200px;
	max-height: 200px;
	box-sizing: border-box; /*飛び出し回避*/
}

textarea:focus {
	background-color: #FFF;
}


input, textarea {
	border: dotted 2px #aaaaaa;
	border-radius: 0;
	background:#999;
	-webkit-appearance: none;
}

input[type="button"] {
	letter-spacing:1px; /*文字の間隔*/
	font-weight:bold;
	border: gloob 2px #036;
	margin: 0;
	max-width: 200px;
	color: #FFF;
	background: #09C;
	padding: 2px 0;
}

input[type="button"]:hover{
	background-color:#3CF;
	color:#FFF;
}


input:focus {
	background-color: #e0e0e0;
}


.mailform {
	width:360px;
	float:left;
	margin: 10px 20px 30px 20px;
	padding: 10px 10px 30px 10px;
	background:url(../img/bg2.png) repeat;
	color:#FFF;
	border-radius:5px;
	-webkit-border-top-right-radius: 5px; 
	-webkit-border-top-left-radius: 5px;   
    -webkit-border-bottom-right-radius: 5px;  
    -webkit-border-bottom-left-radius: 5px;  
    -moz-border-radius-topleft: 5px;  
    -moz-border-radius-topright: 5px;  
    -moz-border-radius-bottomright: 5px;  
    -moz-border-radius-bottomleft: 5px;	
}

.mailform p{
	display:block;
	margin: 3px 0 0 0;
}



/*コンタクトend*/




footer {
	clear:both;
	border: dotted 1px #999;
	width: 100%;
	background: #202020;
	overflow: hidden;
}

#footer-in {
	width: 900px;
	margin: 0 auto;
	padding: 5px;
	overflow: hidden;
	*zoom: 1;
}

.social_button {
	float: left;
	margin: 5px 3px;
}


#footer-text {
	margin: 0 0 10px 2px;
	clear:both;
}

#footer-in dt{
	display:block;
	color:#FFF;
	margin:0;
}

#footer-in small {
	display:block;
	color:#FFF;
	margin:0 0 0 2px;
}

/*-----------------------------------------------------	*/
