@charset "utf-8";

body {
padding: 0;
margin: 0;
background: #fff;
}
a {
color: #f58231;
}
#wrap {
color: #333;
font-size: 13px;
line-height: 1.6;
padding-top: 80px;
-webkit-text-size-adjust: 100%;
background: url(../images/visual_bg.png) no-repeat center top #fff;
background: url(../images/bg.png) repeat center top #fff;
background-size: auto auto;
}
.areaIn {
position: relative;
max-width: 960px;
margin: 0 auto;
}
.areaIn:before { content:""; display:table;}
.areaIn:after { content:""; display:table; clear:both;}
.areaIn { zoom:1;}
.areaIn img {
width: 100%;
}

/* wrapHead --------------------------------------------------------------------- */
#wrapHead {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 1;
background: #fff;
box-shadow: 0 2px 10px rgba(0,0,0,0.25);
-moz-box-shadow: 0 2px 10px rgba(0,0,0,0.25);
-webkit-box-shadow: 0 2px 10px rgba(0,0,0,0.25);
z-index: 999;
}
.wrapHeadIn {
position: relative;
height: 80px;
margin: 0 auto;
}
#wrapHead .logo {
float: left;
width: 58%;
display: table;
height: 80px;
}
#wrapHead .logo img {
vertical-align: middle;
}
#wrapHead .logo > * {
display: table-cell;
text-align: center;
vertical-align: middle;
}
#wrapHead .logo > a {
width: 28%;
}
#wrapHead .logo > a.hack8x9 {
width: 22%;
}
#wrapHead .logo > span {
width: 6%;
}
#wrapHead .logo a.mouse,
#wrapHead .logo a.hack8x9,
#wrapHead .logo a.mynavi {
}
#wrapHead .logo span {
}
    @media screen and (max-width: 768px) {
    #wrapHead .logo {
    width: 80%;
    padding: 0 10px;
    }
    }
#menu {
float: right;
width: 40%;
}
#menu ul {
width: 100%;
display: table;
}
#menu li {
display: table-cell;
position: relative;
width: 33.33%;
border-left: 1px solid #eee;
height: 80px;
}
#menu a {
display: block;
height: 80px;
line-height: 80px;
color: #7d9fd1;
text-decoration: none;
text-align: center;
transition: all 0.1s linear;
-moz-transition: all 0.1s linear;
-webkit-transition: all 0.1s linear;
-o-transition: all 0.1s linear;
-ms-transition: all 0.1s linear;
}
    @media screen and (max-width: 768px) {
    }
#menu .menu01 a,
#menu .menu02 a {
	background: #c1d743;
	color: #fff;
}
#menu .menu03 a {
	background: #f58231;
	color: #fff;
}
#menu li.btn:before { content:""; display:table;}
#menu li.btn:after { content:""; display:table; clear:both;}
#menu li.btn { zoom:1;}
#menu .fb {
	float: right;
	margin-top: 25px;
	width: 80px;
	height: 30px;
	padding: 0 5px;
	overflow: hidden;
}
#menu .tw {
	float: right;
	margin-top: 25px;
	width: 80px;
	height: 30px;
	padding: 0 5px;
	overflow: hidden;
}
#wrapHead .menu {
	display: none;
}
#menu a:hover {
	filter: alpha(opacity=70);
	-moz-opacity:0.70;
	opacity:0.70;
}
/* wrapVisual --------------------------------------------------------------------- */
#wrapVisual {
	margin-bottom: 0;
	padding: 50px 0 0 0;
}
#wrapVisual img {
vertical-align: bottom;
    box-shadow: 2px 2px 10px rgba(0,0,0,0.1);
}
/* wrapFooter --------------------------------------------------------------------- */
#wrapFooter {
	background: #f3f5f4;
    background: #f2f2f2;
}
.wrapFooterIn {
}
#wrapFooter .pagetop {
	text-align: right;
}
#wrapFooter .pagetop a {
	display:inline-block;
	*display: inline;
	*zoom: 1;
	height: 30px;
	text-align: center;
	background: url(../images/arrow02.png) no-repeat 20px center #fff;
	line-height: 30px;
	text-decoration: none;
	color: #666;
	padding: 0 20px 0 35px;
}
.footerNav {
	clear: both;
	margin-bottom: 20px;
	padding: 20px 0;
}
.footerNav ul {
	position: relative;
	float: left;
	left: 50%;
}
.footerNav li {
	position: relative;
	float: left;
	left: -50%;
}
.footerNav a {
	display: block;
	border-left: 1px solid #666;
	line-height: 1;
	color: #666;
	padding: 0 10px;
}
.footerNav li:last-child a {
	border-right: 1px solid #666;
}
.fotterProfNav {
}
.fotterProfNav ul {
	position: relative;
	bottom:  -3px;
	float: left;
	left: 50%;
}
.fotterProfNav li {
	margin: 10px 10px 0 10px;
	position: relative;
	float: left;
	left: -50%;
}
.fotterProfNav li {
	position: relative;
	background: #999;
	border: 3px solid #dadcdb;
	border-bottom: none;
}
.fotterProfNav li a {
	display: block;
	width: 120px;
	line-height: 27px;
	text-decoration: none;
	color: #fff;
	text-align: center;
}
.fotterProfNav li.current {
	background: #fff;
	border: 3px solid #dadcdb;
	border-bottom: none;
}
.fotterProfNav li.current a {
	color: #656565;
}
#wrapFooter .copy {
	clear: both;
	border-top: 3px solid #dadcdb;
	background: #fff;
	padding: 30px 0;
	text-align: center;
}
/* temp --------------------------------------------------------------------- */
.textLeft { text-align: left;}
.textCenter { text-align: center;}
.textRight { text-align: right;}
.bar01 {
	padding: 10px 0;
	margin-bottom: 30px;
	border-bottom: 1px solid #333;
	color: #333;
	font-size: 20px;
	font-weight: bold;
}
.bar02 {
	margin-bottom: 30px;
	background: #5f779c;
	color: #fff;
	line-height: 1;
	padding: 10px 20px;
	font-size: 14px;
}
.bar03 {
	margin-bottom: 30px;
	font-size: 20px;
	line-height: 1.4;
	color: #666;
	font-weight: normal;
}

.bar05 {
	margin-bottom: 10px;
	background: #666;
	color: #fff;
	line-height: 1;
	padding: 10px 20px;
	font-size: 14px;
}
.bar06 {
	clear: both;
	margin-bottom: 30px;
	border-bottom: 3px double #dadcdb;
	font-size: 18px;
	font-weight: bold;
	color: #666;
}
.bar07 {
	margin-bottom: 1em;
}
.bar07 b {
	display:inline-block;
	*display: inline;
	*zoom: 1;
	background: #c1d743;
	color: #fff;
	line-height: 1;
	padding: 5px 10px;
	font-weight: normal;
	font-size: 13px;
}
.textBox01 p {
	margin-bottom: 2em;
}
.text01 {
	margin-bottom: 2em;
}
.profBox01 {
	margin-bottom: 30px;
	border: 1px solid #dadcdb;
	background: url(../images/box_bg01.png) #eee;
}
.profBar01 {
	background: #fff;
	line-height: 1;
	color: #666;
	font-size: 14px;
	padding: 20px;
}
.profBox01 .layoutBox01 {
	padding: 20px;
}
.profBox01 .layoutBox01 .fix { width: 25%; margin-right: -25%;}
.profBox01 .layoutBox01 .varIn { margin-left: 25%;}
.info {
	margin: 0 100px;
}
.profBox01.typeVoice {
	margin-top: 70px;
	padding: 10px;
	background: #fff;
	position: relative;
	border: 3px solid #84a4d3;
}
.profBox01.typeVoice .layoutBox01 {
	background: url(../images/box_bg01.png) #d9e3f2;
}
.profBox01.typeVoice .bar07 b {
    background: #e8718d;
}
.profBox01.typeVoice .text01 b {
	color: #e8718d;
	font-size: 120%;
	display: inline-block;
	margin-bottom: 0.4em;
}
.voiceTitle {
	position: absolute;
	left: 0;
	top: -65px;
	width: 100%;
	text-align: center;
}
.voiceTitle img {
	max-width: 260px;
}
.tableDlBox01 {
	font-size: 14px;
	border: 3px solid #dadcdb;
	margin-bottom: 10px;
    background: #fff;
}
.tableDlBox01 dl {
	display: table;
	width: 100%;
	border-collapse: collapse;
}
.tableDlBox01 dt {
	display: table-cell;
	width: 25%;
	border-right: 1px solid #dadcdb;
	font-weight: bold;
	text-align: center;
	padding: 15px;
	vertical-align: middle;
	color: #656565;
}
.tableDlBox01 dd {
	display: table-cell;
	text-align: left;
	padding: 15px;
}
.tableDlBox01 dl:nth-child(even) {
	background: #f3f5f4;
    background: #f2f2f2;
}
.tableBox01 {
	font-size: 14px;
}
.tableBox01 table {
	margin-bottom: 10px;
	border: 3px solid #ccc;
	border-collapse: collapse;
}
.tableBox01 th {
	width: 180px;
	border-right: 1px solid #ccc;
	font-weight: bold;
	text-align: center;
	padding: 15px;
}
.tableBox01 td {
	text-align: left;
	padding: 15px;
}
.tableBox01 tr:nth-child(even) th,
.tableBox01 tr:nth-child(even) td {
	background: #f3f5f4;
}
.layoutBox01 {
	clear: both;
}
.layoutBox01:before { content:""; display:table;}
.layoutBox01:after { content:""; display:table; clear:both;}
.layoutBox01 { zoom:1;}
.layoutBox01 .fix {
	width: 20%;
	float: left;
	margin-right: -20%;
}
.layoutBox01 .fixIn {
	padding: 0 20px 0 0;
}
.layoutBox01 .var {
	float: right;
	width: 100%;
}
.layoutBox01 .varIn {
	margin-left: 20%;
}
.layoutBox02 {
	clear: both;
}
.layoutBox02:before { content:""; display:table;}
.layoutBox02:after { content:""; display:table; clear:both;}
.layoutBox02 { zoom:1;}
.layoutBox02 .item {
	float: left;
	width: 100%;
}
.layoutBox02.col2 .item { width: 50%;}
.layoutBox02.col3 .item { width: 33.33%;}
.layoutBox02.col4 .item { width: 25%;}
.layoutBox02 .itemIn {
	padding: 0 10px 10px 10px;
}
.layoutBox03 {
	display: table;
	width: 100%;
	table-layout: fixed;
}
.bar07.pl20 {
	padding-left: 20px;
}
.layoutBox03 > .item {
	display: table-cell;
	vertical-align: top;
}
.profBox01 .layoutBox03 .layoutBox01 {
	background: none;
}
.profBox01 .layoutBox03 .layoutBox01 .fix {
	width: 50%;
    margin-right: -50%;
}
.profBox01 .layoutBox03 .layoutBox01 .varIn {
    margin-left: 50%;
}
/* contactArea --------------------------------------------------------------------- */
.contactArea {
	margin-bottom: 50px;
}
.contactArea .bar {
	text-align:center;
	font-size: 180%;
	margin-bottom: 20px;
	line-height: 1.2;
}
.contactAreaIn {
	background: #f3f5f4;
	border-top: 1px solid #dadcdb;
	padding: 20px 90px;
}
.contactAreaIn:before { content:""; display:table;}
.contactAreaIn:after { content:""; display:table; clear:both;}
.contactAreaIn { zoom:1;}
.contactInfo {
	width: 50%;
	float: left;
	line-height: 1.1;
}
.contactArea .text {
	font-size: 100%;
	margin-bottom: 10px;
	vertical-align: middle;
}
.contactArea .tel img {
	vertical-align: middle;
}
.contactArea .tel span {
	color: #ccc;
	font-size: 350%;
	display:inline-block;
	*display: inline;
	*zoom: 1;
	margin-right: 5px;
	vertical-align: middle;
}
.contactArea .tel b {
	color: #666;
	font-weight: normal;
	font-size: 350%;
	letter-spacing: -2px;
	vertical-align: middle;
}
.contactArea .tel.mail b {
	font-size: 300%;
}
.contactArea .contactBtn {
	width: 50%;
	float: right;
}
.contactArea .btn a {
	display: block;
	color: #fff;
	font-size: 200%;
	background: url(../images/btn_bg02.png) repeat-x left top #fcc02e;
	background-size: auto 50%;
	text-align: center;
	padding-bottom: 5px;
    box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
    -webkit-box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
}
.contactArea .btn span {
	display:inline-block;
	*display: inline;
	*zoom: 1;
	background: url(../images/btn_arrow01.png) no-repeat right center;
	padding: 10px 30px 10px 10px;
}
.contactBtnArea {
    margin: 0 auto;
	margin-bottom: 50px;
}
.contactBtnArea .btn a {
	display: block;
	color: #fff;
	font-size: 250%;
    max-width: 700px;
    margin: 0 auto;
	background: url(../images/btn_bg02.png) repeat-x left top #f58231;
	background-size: auto 50%;
	text-align: center;
	padding-bottom: 5px;
    box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
    -webkit-box-shadow: inset 0 -5px 0 rgba(0,0,0,0.2);
    border-radius: 10px;
}
.contactBtnArea .btn a:hover {
opacity: 0.7;
}
.contactBtnArea .btn span {
	display:inline-block;
	*display: inline;
	*zoom: 1;
	background: url(../images/btn_arrow01.png) no-repeat right center;
	padding: 10px 80px 10px 10px;
}
.contactBtnArea .image {
	margin: 0 auto;
	max-width: 600px;
}
/* tab --------------------------------------------------------------------- */
.tab {
	position: relative;
	clear: both;
	background: #f3f5f4;
	margin-bottom: 20px;
}
.tabNav {
	width: 100%;
	height: 80px;
	position: absolute;
	z-index: 2;
	background: #f3f5f4;
}
.tabNav ul {
	margin: 20px auto 0 auto;
}
.tabNav li {
	position: relative;
	bottom: -3px;
	background: #999;
	border: 3px solid #dadcdb;
	border-bottom: none;
	float: left;
	margin-right: 20px;
	font-size: 16px;
	height: 57px;
}
.tabNav li a {
	display: block;
	background: url(../images/btn_bg01.png) repeat-x left top #999;
	color: #fff;
	text-decoration: none;
	width: 200px;
	text-align: center;
	display: block;
	height: 54px;
	line-height: 54px;
}
.tabNav li.current {
	background: #fff;
}
.tabNav li.current a {
	background: #fff;
	color: #656565;
	cursor: default;
}
.tabIn {
	position: relative;
	z-index: 1;
}
.tabIn li {
	display: none;
}
.tabIn li.current {
	display: block;
}
.tabIn li {
	position: relative;
	top: 0;
	padding-top: 80px;
	z-index: 1;
}
.tabIn li .tabBox01 {
	width: 100%;
	background: #f3f5f4;
	margin-bottom: 30px;
	padding-bottom: 30px;
}
.tabIn li .tabBox01In {
	margin: 0 auto;
	border-top: 3px solid #dadcdb;
	background: #fff;
	padding: 30px 30px 20px 30px;
	border-bottom:3px solid #dadcdb;
}
.tabIn li .tabBox02 {
	margin: 0 auto;
}
/* area --------------------------------------------------------------------- */
#area01 {
	margin-bottom: 20px;
	font-size: 120%;
    line-height: 1.6;
}
#area01 .text {
/*background: #fff;*/
padding: 20px 20px 0 20px;
}
#area02 .fix img {
	max-width: 200px;
}
#area03 {
	margin-bottom: 50px;
}
#area03 .bar01 {
	margin-left: 10px;
	margin-right: 10px;
}
#area03 .areaIn {
	padding: 0;
	max-width: 980px;
}
#area03 img {
	max-width: 300px;
	display:inline-block;
	*display: inline;
	*zoom: 1;
	margin-bottom: 10px;
}
#area04 {
	margin-bottom: 50px;
}
@media screen and (max-width: 920px) {
.contactAreaIn {
	padding: 20px;
}
}
.prevslide {
	display: inline-block;
	cursor: pointer;
	color: #7d9fd1;
}
.prevslide .close,
.prevslide.active .open {
	display: none;
	text-decoration: underline;
}
.prevslide .open,
.prevslide.active .close {
	display: inline;
	padding: 0 10px;
	text-decoration: underline;
}
.humanBox {
	margin: 0 10px;
}
.humanBox .profBox01 {
	position: relative;
	z-index: 1;
	margin: 40px 0 30px 0;
}
.humanBox .profBox01 img {
    max-width: 200px;
}
.humanBox .textCenter img {
	max-width: 520px;
	margin-bottom: 10px;
}
.humanBox .text {
	position: relative;
	padding: 20px 30px;
	margin-bottom: 20px;
	background: #f5f5f5;
    background: #fff;
	border-radius: 5px;
	font-size: 110%;
	z-index: 10;
}
.humanBox .text:before { content:""; display:table;}
.humanBox .text:after { content:""; display:table; clear:both;}
.humanBox .text { zoom:1;}
.humanBox .text img {
	position: absolute;
	max-width: 240px;
	right: 0;
	top: -80px;
}
.humanBox .text span {
	display: block;
	margin-right: 240px;
}
@media screen and (max-width: 768px) {
.humanBox {
	padding-bottom: 0;
}
.humanBox .text span {
	margin: 0;
}
.humanBox .text img {
	position: relative;
	display: block;
	margin: 0 auto;
	top: inherit;
	right: inherit;
}
.humanBox .profBox01 {
	margin: 0 0 30px 0;
}
}