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


/*===============================================
●共通
===============================================*/
body {
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	position: relative;
  font-size: 16px;
  color: #362e2b;
}

.sp {
  display: none;
}

a {
  text-decoration: none;
}
.sanserif {
 font-family: Verdana, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; 
}



/*　定義リスト
===============================================*/
.commonList_item {
  width: 830px;
  margin-right: auto;
  margin-left: auto;
	padding: 15px 0;
  font-size: 15px;
	border-top: 1px solid #eeeeee;}
	.commonList_item:last-of-type {
		border-bottom: 1px solid #eeeeee;}
.commonList_title {
	width: 170px;
	vertical-align: top;
	font-size: 15px;
	font-weight: bold;
	color: #000;
	float: left;}
.commonList_body {
	float: left;}

.commonList_innerBody {
	width: 660px;
	padding-top: 15px;
	padding-bottom: 15px;
	border-bottom: 1px solid #eeeeee;}
	.commonList_innerBody:first-of-type {
		padding-top: 0;
		padding-bottom: 15px;}
	.commonList_innerBody:last-of-type {
		padding-top: 15px;
		padding-bottom: 0;
		border-bottom: none;}

.commonListSide dt {
	float:left;
	clear:left;}
.commonListSide dd {
	margin-bottom: 6px;
	float: left;}


/*　コンテナ
===============================================*/
.wrapper {
  width: 100%;
  padding: 70px 0;
  position: relative;
  z-index: 60;
  background: url(../images/contents_bg.png);
}
.wrapper section {
  margin-bottom: 68px;
}
.wrapper section:last-child {
  margin-bottom: 0;
}

.common_contentsWrapper {
  width: 1028px;
  margin: 0 auto;
  padding: 60px 0;
  background-color: #FFF;
}
.common_contentsContainer {
  width: 830px;
  margin: 0 auto;
  background-color: #FFF;
}

.common_title {
  margin-bottom: 46px;
  padding-bottom: 10px;
  font-size: 36px;
  font-weight: normal;
  text-align: center;
  letter-spacing: 4px;
  border-bottom: 3px double #362e2b;
}
.common_subTitle {
  margin-bottom: 20px;
  text-align: center;
  line-height: 38px;
  font-size: 18px;
  font-weight: normal;
  letter-spacing: 2px;
  background-color: #eeeeee;
}

.common_button {
  width: 240px;
  height: 40px;
  line-height: 40px;
  color: #FFF;
  background-color: #362e2b;
  border: 1px solid #362e2b;
  text-align: center;
  display: inline-block;
  transition: 0.5s;
}
.common_button:hover {
  color: #362e2b;
  background-color: #FFF;
  border: 1px solid #362e2b;
  transition: 0.5s;
}


.common_banner {
  width: 580px;
  margin: 0 auto 68px;
  display: block;
  transition: 0.5s;
}
.common_banner:hover {
  opacity: 0.7;
  transition: 0.5s;
}
.common_banner:last-child {
  margin-bottom: 0;
}




/*　ヘッダー
===============================================*/
.mainHeader_wrapper {
  width: 100%;
  min-width: 1040px;
  height: 60px;
  background-color: #362e2b;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 200;
}
.mainHeader {
  width: 1028px;
  margin: 0 auto;
}
.mainHeader_logo {
  width: 203px;
  padding-top: 7px;
  display: block;
  float: left;
}

.mainMenu_container {
  float: right;
}
.mainMenu_List {
  margin-top: 10px;  
}
.mainMenu_item {
  margin-left: 20px;
  font-size: 13px;
  float: left;
}
.mainMenu_item a {
  height: 40px;
  line-height: 40px;
  color: #FFF;
  display: block;
  position: relative;
}
.mainMenu_item a::after {
  width: 100%;
  height: 1px;
  content: '';
  position: absolute;
  bottom: 0px;
  left: 0;
  -webkit-transform: scaleX(0);
  -ms-transform: scaleX(0);
  transform: scaleX(0);
  background-color: #FFF;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;}
.mainMenu_item a:hover::after {
  -webkit-transform: scaleX(1);
  -ms-transform: scaleX(1);
  transform: scaleX(1);}


/*　フッター
===============================================*/
.mainFooter_wrapper {
  width: 100%;
  min-width: 1040px;
  background-color: #FFF;
  z-index: 100;
  position: relative;
}
.mainFooter {
  width: 1028px;
  margin: 0 auto;
  padding: 46px 0;
  text-align: center;
}

.mainFooter_title {
  margin-bottom: 10px;
  font-size: 32px;
}

.mainFooter_service {
  width: 320px;
  margin: 40px auto 30px;
}
.mainFooter_serviceContainer {
  width: 140px;
  line-height: 38px;
  border-top: 1px solid #362e2b;
  border-bottom: 1px solid #362e2b;
  float: right;
}
.mainFooter_serviceContainer:first-child {
  float: left;
}

.mainFooter .common_button {
  width: 320px;
  height: 56px;
  line-height: 56px;
}

.footerMap {
  height: 380px;
  background-color: #eeeeee;
  position: relative;
  z-index: 101;
}
.map {
  width: 100%;
  height: 380px;
}
#footerMap iframe {
  width: 100% !important;
  height: 100% !important;
  background-color: #eeeeee;
  position: relative;
  z-index: 101;
}

.copyright_wrapper {
  background-color: #362e2b;
  position: relative;
  z-index: 102;
}
.pagetop {
  width: 162px;
  margin: auto;
  display: block;
  position: absolute;
  top: -42px;
  right: 0;
  left: 0;
  transition: 0.5s;
}
.pagetop:hover {
  top: -50px;
  transition: 0.5s;
}
.copyright {
  line-height: 40px;
  text-align: center;
  color: #FFF;
  font-size: 12px;
  position: relative;
  z-index: 103;
}



/*　トップページ
===============================================*/
.mainImage_wrapper {
  width: 100%;
  min-width: 1040px;
  color: #FFF;
  background-color: #DBDBDB;
  position: relative;
  overflow: hidden;
  position: fixed;
  top: 60px;
  left: 0;
}
.mainImage_container {
  width: 100%;
  height: 300px;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
}
.mainImage_copy {
  margin: auto;
  text-align: center;
  font-size: 40px;
  position: absolute;
  right: 0;
  left: 0;
  z-index: 34;
}
.mainImage_logo {
  max-width: 138px;
  max-height: 136px;
  margin: auto;
  position: absolute;
  right: 0;
  left: 0;
  top: 100px;
  z-index: 33;
}
.mainImage_name {
  margin: auto;
  text-align: center;
  font-size: 30px;
  position: absolute;
  right: 0;
  left: 0;
  top: 260px;
  z-index: 32;
}
.mainImage_arrow {
  margin: auto;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 20px;
  z-index: 31;
}
.mainImage_bg {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index:29;
  background-size: cover;
  background-repeat: no-repeat;
}
.mainImage_bg::after{
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 30;
  background: url(../images/filter-dot.png);
  background-color: rgba(0,0,0,0.3);
  content: '';
}

.mainImage_bg1 {
  background-image: url(../images/mainImage1.png);  
}
.mainImage_bg2 {
  background-image: url(../images/mainImage2.png);  
}
.mainImage_bg3 {
  background-image: url(../images/mainImage3.png);  
}
.mainImage_bg4 {
  background-image: url(../images/mainImage4.png);  
}
.mainImage_bg5 {
  background-image: url(../images/mainImage5.png);  
}



.topMessage {
  padding: 90px 0;
  text-align: center;
  font-size: 18px;
  line-height: 36px;
  color: #FFF;
  position: relative;
  z-index: 50;
  background-color: rgba(0,0,0,0.7);
}

.topService {
  text-align: center;
}
.topService_box {
  width: 362px;
  display: inline-block;
  text-align: center;
}
.topService_box:first-child {
  margin-right: 30px;
}

.topService h3 {
  padding: 20px 0 10px;
  font-size: 24px;
  font-weight: normal;
  letter-spacing: 2px;
}
.topService p {
  padding-bottom: 20px;
  text-align: left;
  line-height: 28px;
}
.topPageEmployee {
  text-align: center;  
}


/*　下層ページ共通
===============================================*/
.subTitle_wrapper {
  height: 380px;
  margin-top: 60px;
  text-align: center;
  background: url(../images/subTitile_bg.png);
}
.common_subPageTitle {
  padding-top: 150px;
  font-size: 36px;
  font-weight: normal;
  letter-spacing: 5px;
}
.common_subPageTitle_text {
  padding-top: 10px;
  font-size: 18px;
}


/*　業務案内
===============================================*/
.subService {
  text-align: center;
}
.subService_mainImg {
  margin-bottom: 20px;
}
.subService_text {
  margin-bottom: 20px;
  line-height: 28px;
}
.subService_text:last-child {
  margin-bottom: 0;
}

.subService_contents1_container {
  margin-top: 40px;
}
.subService_contents1_imgBox {
  width: 262px;
  margin-left: 20px;
  float: left;
}
.subService_contents1_imgBox:first-child {
  margin-left: 0;
}
.subService_contents1_imgBox h5 {
  font-size: 15px;
  font-weight: normal;
  text-align: left;
}


.subService_contents2_container1 {
  margin-top: 40px;
}
.subService_contents2_list dt {
  width: 180px;
}


.subService_contents2_flow {
  width: 200px;
  height: 350px;
  margin-right: 10px;
  padding: 10px 0;
  float: left;
  border: 1px solid #362e2b;
  position: relative;
}
.subService_contents2_flow::after {
  width: 16px;
  height: 16px;
  background: url(../images/service_contents2_arrow.png) no-repeat;
  display: block;
  position: absolute;
  right: -14px;
  top: 90px;
  content: '';
}
.subService_contents2_flow:last-child {
  margin-right: 0;
}
.subService_contents2_flow:last-child::after {
  background-image: none;
  content: '';
}
.subService_contents2_flow h5 {
  padding-bottom: 5px;
  font-size: 16px;
  font-weight: normal;
  letter-spacing: 1px;
  color: #996c33;
}
.subService_contents2_flow p {
  padding: 5px 10px;
  text-align: left;
  font-size: 13px;
}


/*　工事実績
===============================================*/
.subWorks .common_contentsContainer {
  width: 900px;
}
.subWorks_title {
  font-size: 28px;
}
.subWorks_container {
  border-top: 1px solid #eeeeee;
}
.subWorks_container:last-child {
  border-bottom: 1px solid #eeeeee;
}
.subWorks_container div {
  width: 450px;
  float: left;
}
.subWorks_container div:last-child {
  width: 430px;
  float: right;
}
.subWorks_container h4 {
  padding-right: 6px;
  font-size: 14px;
  line-height: 46px;
  display: inline-block;
}
.subWorks_container .line2 h4 {
  font-size: 13px !important;
}
.subWorks_container span {
  line-height: 46px;
  font-size: 11px;
  display: inline-block;
}


/*　代表メッセージ
===============================================*/
.subMessage_img {
  margin-bottom: 30px;
} 
.subMessage_text {
  line-height: 28px;
}


/*　社員紹介
===============================================*/
.topEmployee {
  text-align: center;
}
.employee_link {
  width: 240px;
  display: block;
  color: #362e2b;
  transition: 0.5s;
}
.employee_link:hover {
  opacity: 0.7;
  transition: 0.5s;
}

.employee_box {
  width: 240px;
  margin: 0 0 40px 40px;
  border: 1px solid #362e2b;
  display: inline-block;
  overflow: hidden;
  text-align: center;
}
.employee_box:nth-child(3n + 1) {
  margin-left: 0;
}
.topPageEmployee .employee_box:nth-child(n + 7) {
  display: none;
}

.employee_profileContainer {
  width: 240px;
  float: left;
  text-align: center;
}
.employee_img1 {
  width: 100%;
  display: block;
  margin-bottom: 10px;
  background-color: #eeeeee;
}
.employee_history {
  font-size: 12px;
}
.employee_boxText {
  height: 58px;
  font-size: 12px;
  line-height: 18px !important;
  text-align: center !important;
}
.topPageEmployee .employee_boxText {
  display: none;
}


.employee_textContainer {
  width: 540px;
  float: right;  
}
.employee_messageTitle {
  padding-bottom: 4px;
  font-size: 24px;
  border-bottom: 3px double #362e2b;
}
.employee_textTitle {
  margin: 30px 0 10px;;
  padding-left: 15px;
  text-align: left !important;
}
.employee_text {
  line-height: 26px;
}

.employee_textContainer .common_button {
  margin-top: 40px;
}


/*　会社案内
===============================================*/
.access_container {
  position: relative;
}
.access_container iframe {
  width: 100%;
  height: 250px;
  margin-top: 15px;
  display: block;
}
.map_link {
  margin-top: 20px;
  display: inline-block;
  color: #362e2b;
}
.map_link:hover {
  text-decoration: underline;
}

.company_img {
  display: block;
  position: absolute;
  right: 0;
  top: 60px;
}

.locationList {
  padding-top: 0 !important;
}



/*　採用情報
===============================================*/
.interview_wrapper .common_button {
  margin: 0 auto;
  display: block;
}
.interview_title {
  margin-bottom: 5px;
  font-size: 24px;
  text-align: center;
  line-height: 32px;
  color: #b5854a;
}
.interview_text {
  margin-bottom: 40px;
  text-align: center;
  font-size: 14px;
}

.recruitList_innerContainer {
  margin-top: 15px;
  text-align: center;
}
.recruitList_innerContainer img {
  display: inline-block;
}


/*　お問い合わせ
===============================================*/
.errorArea {
  margin-bottom: 20px;
  font-size: 14px;
  text-align: center;
  color: #FF0004;
}
.errorArea_title {
  margin-bottom: 5px;
  font-size:16px;
  font-weight: bold;
}
input.error,
select.error,
textarea.error {
  border: 1px solid red !important;
  box-shadow: 0 0 4px #ff000042;
}
label.error {
  margin-top: 5px;
  color: red;
  font-size: 12px;
  display: block;
}

.contactList_title {
	width: 220px;
	margin-right: 20px;
	padding: 34px 20px 0;
	vertical-align: top;
	font-size: 15px;
  font-weight: bold;
	float: left;}
.cantactLabel {
  width: 135px;
  float: left;
}
.contactList_title .require {
  width: 40px;
  padding: 1px 0;
  text-align: center;
  font-size: 12px;
  color: #FFF;
  float: left;
  background-color: #362e2b;
}
.contactList_body {
	width: 590px;
	padding: 24px 0 24px 0;
	font-size: 14px;
	float: left;
}

.commonInput {
  width: 100%;
  padding: 10px 10px;
  border: 1px solid #D5D5D5;
}
.commonTextarea {
  width: 100%;
  height: 200px;
  padding: 10px 10px;  
  border: 1px solid #D5D5D5;
  resize: vertical;
}

.confirm_ck_container {
  margin-top: 30px;
  text-align: center;
}
.formButton_container {
  margin-top: 30px;
  text-align: center;
}
.mailConplete_text {
  text-align: center;
}