@charset "utf-8";

body {
	line-height: 1.6;
	color: #333333;
	background: #fff url(../img/bg.jpg) repeat-x;
}

/* Anchors
---------------------------------------- */
a:link {
	color: #43677E;
	text-decoration: none;
}

a:visited {
	color: #43677E;
	text-decoration: none;
}

a:hover,
a:active {
	text-decoration: none;
}

/* *******************************************************
layout
******************************************************** */

/* header
---------------------------------------- */
#headArea {
	height: 107px;
	margin: 0 auto;
	background: url(../img/head_bg1.jpg) 50% 0% no-repeat;
}

#headArea #header {
	width: 800px;
	height: 55px;
	margin: 0 auto;
	overflow: hidden;
}

#headArea #header h1 {
	width: 176px;
	float: left;
}

#headArea #header h1 img {
	margin-top: 19px;
}

#headArea #header #header-r {
	float: right;
	text-align: right;
	vertical-align: middle;
	margin-top: 19px;
}

/* gnavi1
---------------------------------------- */
#headArea #header #header-r ul.gnavi1 {
	padding: 0;
	float: right;
}

#headArea #header #header-r ul.gnavi1 li {
    float: left;
	display: inline;
}

#headArea #header #header-r ul.gnavi1 li.nv {
	float: left;
	display: inline;
	font-size: 1em;
	line-height: 1.3;
	color: #43677E;
	background: url(../img/arrow1.gif) 0% 40% no-repeat;
	margin-left: 1.5em;
	padding: 0 0 0 10px;
}

#headArea #header #header-r ul.gnavi1 li.nv a {
	color: #43677E;
}

#headArea #header #header-r ul.gnavi1 li.nv a:hover {
	color: #A1B3BE;
}

#headArea #header #header-r p.lang-english {
	width: 54px;
	margin-left: 1.5em;
	float: right;
}
#headArea #header #header-r p.lang-english img {
	margin: 0;
}



/* gnavi2
---------------------------------------- */
#headArea #gnavi2 {
	width: 800px;
	height: 39px;
	margin: 0 auto;
	padding: 0 auto;
	border-top: 5px solid #800D27;
}

#headArea #gnavi2 li {
	float: left;
	text-indent: -9999px;
}

#headArea #gnavi2 li a {
	height: 39px;
	display: block;
	outline: none;
}

#headArea #gnavi2 li.home a {
	width: 130px;
	background: url(../img/gnavi2_01.jpg) no-repeat;
	margin: 0 1px 0 0;
}

#headArea #gnavi2 li.service a {
	width: 133px;
	background: url(../img/gnavi2_02.jpg) no-repeat;
	margin: 0 1px 0 0;
}

#headArea #gnavi2 li.column a {
	width: 133px;
	background: url(../img/gnavi2_03.jpg) no-repeat;
	margin: 0 1px 0 0;
}

#headArea #gnavi2 li.project a {
	width: 133px;
	background: url(../img/gnavi2_04.jpg) no-repeat;
	margin: 0 1px 0 0;
}

#headArea #gnavi2 li.about a {
	width: 133px;
	background: url(../img/gnavi2_05.jpg) no-repeat;
	margin: 0 1px 0 0;
}

#headArea #gnavi2 li.recruit a {
	width: 133px;
	background: url(../img/gnavi2_06.jpg) no-repeat;
	margin: 0;
}

#headArea #gnavi2 li a:hover {
	background-position: 0 -39px;
}

#headArea #gnavi2 li.current a,
#headArea #gnavi2 li.current a:hover {
	background-position: 0 -78px;
}


/* headlineArea
---------------------------------------- */
#headlineArea {
	background: url(../img/headline_bg1.jpg) 50% 0% no-repeat;
}

#headline {
	width: 800px;
	height: 99px;
	margin: 0 auto;
}

#headlineInner {
	width: 800px;
	height: 62px;
	margin: 0 auto;
	background: url(../img/headline_bg2.gif) no-repeat;
}

#headlineInner h2 {
	width: 788px;
}

#headlineInner h2 img {
	margin: 21px 0 0 6px;
}

#headline .topicpath {
	width: 784px;
	height: 37px;
	padding: 0 8px 0 8px;
	display: table-cell;
	vertical-align: middle;
	color: #777777;
	font-size: 0.85em;
}

* html #headline .topicpath { /* IE 6 */
	margin: 0 auto;
	padding-top: 8px;
	padding-left: 8px;
	padding-right: 8px;
	height: auto;
	color: #777777;
}

*:first-child+html #headline .topicpath { /* IE 7 */
	margin: 0 auto;
	padding-top: 8px;
	padding-left: 8px;
	padding-right: 8px;
	height: auto;
	color: #777777;
}

#headline .topicpath a {
	color: #43677E;
	text-decoration: none;
}

#headline .topicpath a:hover {
	color: #43677E;
	text-decoration: underline;
}

#headline .topicpath span {
	margin: 0 0.5em;
}

#headline .topicpath strong {
	font-weight: bold;
}


/* contents layout
---------------------------------------- */
#contentsArea {
	margin: 0 auto;
	background: url(../img/contents_bg1.jpg) 50% 0% repeat-y;
}

#contents {
	width: 800px;
	margin: auto;
	padding: 0 0 30px 0;
}


/* contents/main
---------------------------------------- */
#contents #main {
	width: 561px;
	margin-bottom: 20px;
	float: right;
}

#contents #main .level1 {
	width: 561px;
	margin: 0 0 30px 0;
	border-bottom: 1px solid #800D27;
}

#contents #main .level1 img {
	padding: 0 0 5px 0;
}

#contents #main .level2 {
	width: 561px;
	margin: 0 0 20px 0;
	border-bottom: 2px solid #ccc;
}

#contents #main .level2 img {
	padding: 0 0 5px 0;
}

#contents caption {
	display: none;
}


/* contents/side
---------------------------------------- */
#contents #side {
	width: 200px;
	margin-bottom: 20px;
	float: left;
}

/* snavi
---------------------------------------- */
#contents #side #snavi {
	width: 200px;
}

#contents #side #snavi ul.sn {
	width: 198px;
	border-top: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-left: 1px solid #ccc;
}

#contents #side #snavi ul.sn li a {
	width: 158px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn li a span {
	font-size: 1em;
}

#contents #side #snavi ul.sn li a:hover {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn li.newin a {
	width: 158px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/newin.gif) 18px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn li.newin a:hover {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/newin.gif) 18px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn li.current a {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #800D27;
	border-bottom: 1px solid #ccc;
	background: #F7F0F2 url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #666666;
	font-weight: bold;
}

#contents #side #snavi ul.sn li.sn-tit {
	width: 172px;
	font-size: 1em;
	padding: 7px 0 7px 26px;
	border-bottom: 1px solid #ccc;
	background: #F7F0F2 url(../img/arrow4.gif) 8px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #800D27;
	font-weight: bold;
}

#contents #side #snavi ul.sn li.service-tit {
	width: 172px;
	font-size: 1em;
	padding: 7px 0 7px 26px;
	border-bottom: 1px solid #ccc;
	background: #F7F0F2 url(../img/arrow4.gif) 8px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #800D27;
	font-weight: bold;
}

#contents #side #snavi ul.sn2 {
	width: 198px;
	margin-top: 30px;
	border-top: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-left: 1px solid #ccc;
}

#contents #side #snavi ul.sn2 li a {
	width: 158px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn2 li a span {
	font-size: 1em;
}

#contents #side #snavi ul.sn2 li a:hover {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn2 li.newin a {
	width: 158px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/newin.gif) 18px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn2 li.newin a:hover {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/newin.gif) 18px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.sn2 li.current a {
	width: 154px;
	font-size: 1em;
	padding: 7px 0 7px 40px;
	border-right: 4px solid #800D27;
	border-bottom: 1px solid #ccc;
	background: #F7F0F2 url(../img/arrow2.gif) 30px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #666666;
	font-weight: bold;
}

#contents #side #snavi ul.sn2 li.service-tit {
	width: 172px;
	font-size: 1em;
	padding: 7px 0 7px 26px;
	border-bottom: 1px solid #ccc;
	background: #F7F0F2 url(../img/arrow4.gif) 8px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #800D27;
	font-weight: bold;
}

#contents #side #snavi ul.an {
	width: 198px;
	border-top: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-left: 1px solid #ccc;
}

#contents #side #snavi ul.an li.an-tit {
	width: 191px;
	font-size: 1em;
	padding: 7px 0 7px 7px;
	border-bottom: 1px solid #ccc;
	background: #EEEEEE url(../img/arrow6.gif) 175px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #333333;
	font-weight: bold;
}
#contents #side #snavi ul.an li a {
	width: 182px;
	font-size: 1em;
	padding: 7px 0 7px 16px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/arrow2.gif) 180px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.an li a span {
	font-size: 0.85em;
}

#contents #side #snavi ul.an li a:hover {
	width: 182px;
	font-size: 1em;
	padding: 7px 0 7px 12px;
	border-left: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/arrow2.gif) 176px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.bh {
	width: 198px;
	margin-top: 40px;
	border-top: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-left: 1px solid #ccc;
}

#contents #side #snavi ul.bh li a {
	width: 168px;
	font-size: 1em;
	padding: 7px 0 7px 30px;
	border-bottom: 1px solid #ccc;
	background: #fff url(../img/arrow3.gif) 15px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}

#contents #side #snavi ul.bh li a span {
	font-size: 1em;
}

#contents #side #snavi ul.bh li a:hover {
	width: 168px;
	font-size: 1em;
	padding: 7px 0 7px 26px;
	border-left: 4px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #F9F9F9 url(../img/arrow3.gif) 11px 50% no-repeat;
	display: block;
	text-decoration: none;
	color: #43677E;
}




/* footer
---------------------------------------- */
#footerArea {
	margin: 0 auto;
	background: url(../img/foot_bg.jpg) 50% 0% no-repeat;
	clear: both;
}

#footerArea #footer {
	width: 880px;
	height: 124px;
	margin: 0 auto;
	border-bottom: 5px solid #800D27;
}

#footerArea #footer .footerInner {
	width: 800px;
	margin: 0 auto;
}

#footerArea #footer p.pagetop {
	width: 200px;
	float: right;
}

#footerArea #footer p.pagetop img {
	display: block;
	margin: 0;
}

#footerArea #footer .footerIn1 {
	width: 800px;
	height: 45px;
	margin: 0 auto;
	padding-top: 13px;
	overflow: hidden;
	border-top: 1px solid #800D27;
	clear: both;
}

#footerArea #footer .footerIn2 {
	width: 800px;
	height: 40px;
	margin: 0 auto;
	overflow: hidden;
}

#footerArea #footer p.getadobe {
	width: 103px;
	float: right;
}

#footerArea #footer p.getadobe img {
	margin: 0;
}

#footerArea #footer p.copyright {
	width: 263px;
	float: right;
}

#footerArea #footer p.copyright img {
	margin-top: 18px;
}

/* gnavi3
---------------------------------------- */
#footerArea #footer ul.gnavi3 {
	margin-top: 0.8em;
	margin-left: 8px;
	padding: 0;
	float: left;
}

#footerArea #footer ul.gnavi3 li {
    float: left;
	display: inline;
}

#footerArea #footer ul.gnavi3 li.nv {
    float: left;
	display: inline;
	font-size: 0.9em;
	line-height: 1.3;
	color: #777777;
	background: url(../img/arrow8.gif) 0% 40% no-repeat;
	margin-right: 1.5em;
	padding: 0 0 0 10px;
}

#footerArea #footer ul.gnavi3 li.nv a {
	color: #777777;
}

#footerArea #footer ul.gnavi3 li.nv a:hover {
	color: #333333;
}

/* gnavi4
---------------------------------------- */
#footerArea #footer ul.gnavi4 {
	margin-top: 16px;
	margin-left: 8px;
	padding: 0;
	float: left;
}

#footerArea #footer ul.gnavi4 li {
    float: left;
	display: inline;
}

#footerArea #footer ul.gnavi4 li.nv {
    float: left;
	display: inline;
	font-size: 0.9em;
	line-height: 1.3;
	color: #43677E;
	background: url(../img/arrow1.gif) 0% 40% no-repeat;
	margin-right: 1.5em;
	padding: 0 0 0 10px;
}

#footerArea #footer ul.gnavi4 li.nv a {
	color: #43677E;
}

#footerArea #footer ul.gnavi4 li.nv a:hover {
	color: #A1B3BE;
}



/* *******************************************************
common
******************************************************** */





/* clearfix
---------------------------------------- */
.clearfix:after {
	content: "."; 
	display: block; 
	height: 0; 
	clear: both; 
	visibility: hidden;
	font-size: 0;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/* Mac版IEのみに適用 \*//*/
	height: auto;
	overflow: hidden;
	/**/
}

