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


body {
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	color:#333;
	font-size:13px;
	line-height:1.8;
	letter-spacing:0.05em;
	text-align:justify;
}

a {
	color: #333;
	text-decoration: none;
	transition:0.3s ease-in-out;
}
a:hover {
	color:#888;
}

::selection{ background-color:#555; color: #FFF; }
::-moz-selection{ background-color:#555; color: #FFF; }

body , header , footer{ min-width:1080px; }



/*============================================================================

	header

============================================================================*/
header {
	position: relative;
	width:1080px;
	height:53px;
	margin: auto;
	padding-top: 40px;
	padding-bottom: 35px;
}
header h1 {
	position: absolute;
}
header h1 img {
	width: 240px;
	height: 53px;
}

/* ---------------------------------------- nav ---------------------------------------- */
nav {
	position: absolute;
	top:63px;
	right: 0;
	width: 410px;
}
nav li {
	position:relative;
	display:inline-block;
	padding: 0 15px;
	font-weight:bold;
}
nav li:nth-child(5) {
	padding-left: 5px;
}
nav li:nth-child(6) {
	padding-left: 4px;
	padding-right: 0;
	font-size: 12px;
}
nav li:nth-child(n+4) {
	position: relative;
	top: -5px;
}


/* ---------------------------------------- hover ---------------------------------------- */
nav li a span{
	position:relative;
}
nav li a span::before{
    position: absolute;
	left: 0;
	right:0;
	bottom: -7px;
	width:100%;
	height:1px;
	margin:auto;
	background-color: #888;
	transition: 0.15s  ease-out;
	transform: scaleX(0);
	content: "";
	z-index: 1;
}
nav li a:hover span::before{
	transform: scaleX(1);
}



/*============================================================================

	#mainvisual

============================================================================*/
#mainvisual{
	display:block;
	position:relative;
	width: 1080px;
	margin: auto;
}



/*============================================================================

	h2

============================================================================*/

/* ---------------------------------------- green / blue /red ---------------------------------------- */
h2.green , h2.blue , h2.red {
	position: relative;
	width: 200px;
	height: 65px;
	font-size: 15px;
	font-weight: bold;
	text-align: center;
}
h2.green::after , h2.blue::after , h2.red::after {
	content: "";
	position: absolute;
	top: 30px;
	left: 0;
	right: 0;
	width: 60px;
	height: 8px;
	margin: auto;
}
h2.green::after { background: url(../images/h2_green.png); background-size: 60px 8px; }
h2.blue::after { background: url(../images/h2_blue.png); background-size: 60px 8px; }
h2.red::after { background: url(../images/h2_red.png); background-size: 60px 8px; }



/*============================================================================

	#news

============================================================================*/
#news {
	width: 1080px;
	margin: 0 auto 70px;
	padding-top: 60px;
}
#news section {
	float: left;
	width: 540px;
	height: 320px;
	box-sizing: border-box;
	padding: 20px 40px;
	border-right: 1px solid #ddd;
}
#news section h2 {
	margin: auto;
}

/* ---------------------------------------- News ---------------------------------------- */
#news section:first-child {
	border-left: 1px solid #ddd;
}
#news section:first-child p:first-of-type {
	padding-bottom: 10px;
}
#news section:first-child p:first-of-type span {
	color: #888;
	font-size: 12px;
	padding-right: 10px;
}

/* ---------------------------------------- NewProject ---------------------------------------- */
#news section:last-child {
	text-align: center;
}
#news section:last-child img {
	margin-top: 5px;
	margin-bottom: 10px;
}



/*============================================================================

	#project

============================================================================*/
#project {
	width: 100%;
	background: url(../images/bg01.jpg);
}
#project .inner {
	width: 1080px;
	margin: auto;
	padding-top: 80px;
	padding-bottom: 40px;
}
#project .inner section {
	position: relative;
	float: left;
	width: 330px;
	height: 340px;
	margin-right: 45px;
	margin-bottom: 45px;
	background: #FFF;
}
#project .inner section:nth-child(3n) {
	margin-right: 0;
}
#project .inner section .date {
	position: absolute;
	display: inline-block;
	top: 164px;
	padding: 7px 20px 8px 19px;
	height: 36px;
	box-sizing: border-box;
	background: #000;
	color: #eee;
	font-size: 12px;
}
#project .inner section img {
	width: 330px;
	height: 200px;
}
#project .inner section h2 {
	padding-top: 17px;
	padding-left: 15px;
	font-size: 15px;
	font-weight: bold;
}
#project .inner section .tag {
	padding-top: 5px;
	padding-left: 15px;
	color: #888;
}
#project .inner section .tag i {
	padding-right: 5px;
}
#project .inner section a {
	display: block;
	float: left;
	width: 165px;
	height: 50px;
	margin-top: 18px;
	padding-top: 13px;
	box-sizing: border-box;
	border-top: 1px solid #ccc;
	text-align: center;
}
#project .inner section a:first-of-type {
	border-right: 1px solid #ccc;
}
#project .inner section a:hover {
	background: #6d72b2;
	color: #FFF;
}
#project .inner section a:last-of-type:hover {
	background: #85b895;
}
#project .inner section a.single {
	width: 100%;
	border-right: 0;
}
#project .inner section a.single:hover {
	background: #6d72b2;
	color: #FFF;
}



/*==================================================================

	#information

==================================================================*/ 
#information {
	width: 1080px;
	margin: auto;
	padding-top: 80px;
	padding-bottom: 80px;
}
#information h2 {
	margin: auto;
}
#information p {
	text-align: center;
	margin-top: 15px;
}
#information p:nth-child(4) {
	padding-bottom: 60px;
}
#information dl {
	float: left;
	width: 200px;
	height: 150px;
	margin-bottom: 20px;
	margin-right: 20px;
	box-sizing: border-box;
	padding: 25px 20px;
	background: url(../images/bg02.jpg);
}
#information dl:nth-of-type(5n) {
	margin-right: 0;
}
#information dl dt {
	position: relative;
	padding-bottom: 15px;
	border-bottom: 1px solid #fff;
}
#information dl dt a:nth-of-type(1) {
	position: absolute;
	top: -6px;
	right: 25px;
	color: #85b895;
}
#information dl dt a:nth-of-type(2) {
	position: absolute;
	top: -5px;
	right: 0;
	color: #689bcb;
}
#information dl dd {
	padding-top: 18px;
	letter-spacing: 0;
	line-height: 2;
}



/*============================================================================

	footer

============================================================================*/
footer {
	position:relative;
	width:100%;
	background: #333;
	color: #ddd;
	text-align: center;
	font-size: 12px;
}
footer .inner {
	width: 1080px;
	margin: auto;
}
footer .inner section {
	float: left;
	width: 270px;
	height: 290px;
	margin-top: 60px;
	box-sizing: border-box;
	padding-top: 30px;
	border-left: 1px solid #222;
}
footer .inner section:last-child {
	border-right: 1px solid #222;
}
footer .inner section h2 {
	margin: auto;
}
footer .inner section p {
	margin-bottom: 15px;
	line-height: 2;
}
footer .inner section:nth-child(3) p {
	margin-bottom: 10px;
}
footer .inner section p a {
	color: #ddd;
}
footer .inner section p a:hover {
	color: #aaa;
}

/* ---------------------------------------- copyright ---------------------------------------- */
.copy{
	padding: 60px 0 40px;
	color:#eee;
	font-size:11px;
}




