@charset "utf-8";

/* ----------------------------------------------------------------------------------------------------
*  リノベーションの内容
* --------------------------------------------------------------------------------------------------*/

.ttl{
  line-height: 1.75;
}
.page_ttl{
  display: block;
	width: auto;
  padding: 0 40px;
	height: 60px;
	background: #231815;
	color: #fff;
	font-size: 2.5rem;
	line-height: 60px;
	text-align: center;
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
}
.detail_box + .btn_more a{
  width: 220px;
  margin-top: 0!important;
}
@media screen and (max-width : 768px){
  .page_ttl{
    width: 100%;
    height: 60px;
    font-size: 2.1rem;
    line-height: 60px;
    text-align: center;
    bottom: -60px;
  }
  .detail_box + .btn_more a{
    width: 100%;
    height: 32px;
    line-height: 32px;
    max-width: 300px;
    margin-top: 20px!important;
  }
  .detail_box + .btn_more a::after{
    top: 13px;
  }

}

/* ------------------------------
    mv
------------------------------ */
#mv .mv_wrap{
	width: 100%;
  height: 430px;
	margin: 0 auto;
  background: url(../img/service/mv_service.jpg) no-repeat;
  background-size: cover;
  background-position: center bottom;
}
/* menu */
#mv #menu{
  width: 100%;
  background: rgba(35,24,21,0.7);
  height: 78px;
  position: absolute;
  top: 0;
}
@media screen and (max-width : 768px){
  #mv .mv_wrap{ 
    width: 100%; 
    height: 140px;
    background: url(../img/service/mv_service_sp.jpg) no-repeat;
    background-size: cover;
    background-position: center ;
  }
  #mv #menu{
    width: 100%;
    background: rgba(35,24,21,1);
    height: auto;
    position: static;
  }
}
/* ------------------------------
    page_intro
------------------------------ */
#page_intro{
  padding: 88px 0 40px;
}
#page_intro .wrap{
	padding: 0 80px;
}
#page_intro .ttl{
  font-size: 4.2rem;
  margin-bottom: 25px;
}
#page_intro .ttl + p{
  font-size: 1.6rem;
  letter-spacing: 2px;
}

@media screen and (max-width : 768px){
  #page_intro{
    padding: 75px 0 18px;
  }
	#page_intro .wrap{
		padding: 0 5%;
	}

  #page_intro .ttl{
    font-size: 2.3rem;
    margin-bottom: 15px;
  }
  #page_intro .ttl + p{
    font-size: 1.4rem;
    letter-spacing: inherit;
  }

}
/* ------------------------------
    #service_list
------------------------------ */
#service_list{
	margin: 0 auto;
  padding: 40px 0 45px;
}
#service_list .wrap{
	width: 780px;
}
#service_list .box{
	display: block;
	position: relative;
	width: 100%;
	height: 335px;
}
#service_list .box + .box{
	margin-top: 60px;
}
#service_list .box.bathroom{
	background: url(../img/service/img_bathroom_pc.jpg) no-repeat;
	background-size: 100% auto;
}
#service_list .box.kitchen{
	background: url(../img/service/img_kitchen_pc.jpg) no-repeat;
	background-size: 100% auto;
}
#service_list .box.sink{
	background: url(../img/service/img_sink_pc.jpg) no-repeat;
	background-size: 100% auto;
}

#service_list .box .ttl{
	position: absolute;
	background: #fff;
	width: 200px;
	height: 56px;
	font-size: 2.8rem;
	line-height: 56px;
	text-align: center;
	top: 17px;
	left: 21px; 
}
#service_list .box a{
	position: absolute;
	background: #fff;
	height: 45px;
	font-size: 1.6rem;
	line-height: 45px;
	padding: 0 10px 0 20px;
	bottom: 16px;
	right: 19px;
}
#service_list .box a span{
	display: inline-block;
	line-height: 1.6;
	margin-right: 20px;
	background-image: linear-gradient(to right, #9e7f13, #9e7f13 2px, transparent 2px, transparent 4px);
  background-size: 4px 2px;
  background-repeat: repeat-x;
	background-position: center bottom;
	letter-spacing: 1.5px;
}

#service_list .box a img{
	display: inline-block;
	vertical-align: middle;
	margin-bottom: 4px;
}

/* ------- #service_list.col2 ------- */
#service_list.col2{
	padding: 40px 0 0;
}
#service_list.col2 h3.ttl{
	font-size: 3.2rem;
  margin-bottom: 50px;
	padding: 40px 0 15px;
  background: url(../img/service/bg_ttlline.png) no-repeat;
  background-position: center bottom;
}
#service_list.col2 .wrap{
	width: 940px;
	flex-wrap: wrap;
}
#service_list.col2 .box{
	width: 458px;
	height: 286px;
	background-size: cover;
	margin-bottom: 28px;
}
#service_list.col2 .box:last-child{
	margin-bottom: 0;
}
#service_list.col2 .box + .box{
	margin-top: 0;
}
#service_list .box.bathroom{
	background: url(../img/service/img02_bathroom_pc.jpg) no-repeat;
	background-size: 100% auto;
}
#service_list.col2 .box.kitchen{
	background: url(../img/service/img02_kitchen_pc.jpg) no-repeat;
	background-size: 100% auto;
}
#service_list.col2 .box.sink{
	background: url(../img/service/img02_sink_pc.jpg) no-repeat;
	background-size: 100% auto;
}
#service_list.col2 .box .ttl{
	width: 142px;
	height: 40px;
	font-size: 2.0rem;
	line-height: 40px;
	top: 14px;
	left: 0; 
	right: 0;
	margin: auto;
}
#service_list.col2 .box a{
	width: 432px;
	padding: 0;
	text-align: center;
	left: 0;
	right: 0;
	margin: auto;
}
#service_list.col2 .box a span{
	margin-right: 15px;
}


@media screen and (max-width : 768px){
  #service_list{
    padding: 12px 0 0;
  }
	#service_list .wrap{
		width: inherit;
		padding: 0;
	}
	#service_list .box{
		width: 100%;
		height: 0;
		padding-top: 62.5%;
	}
	#service_list .box + .box{
		margin-top: 20px;
	}
	#service_list .box.bathroom{
		background: url(../img/service/img_bathroom_sp.jpg) no-repeat;
		background-size: 100% auto;
	}
	#service_list .box.kitchen{
		background: url(../img/service/img_kitchen_sp.jpg) no-repeat;
		background-size: 100% auto;
	}
	#service_list .box.sink{
		background: url(../img/service/img_sink_sp.jpg) no-repeat;
		background-size: 100% auto;
	}

	#service_list .box .ttl{
		width: 100px;
		height: 28px;
		font-size: 1.4rem;
		line-height: 28px;
		top: 10px;
		left: 0; 
		right: 0;
		margin: auto;
	}
	#service_list .box a{
		width: 301px;
		height: 31px;
		font-size: 1.1rem;
		line-height: 31px;
		padding: 0 ;
		bottom: 9px;
		left: 0; 
		right: 0;
		margin: auto;
		text-align: center;
	}
	#service_list .box a span{
		margin-right: 10px;
		background-image: linear-gradient(to right, #9e7f13, #9e7f13 1px, transparent 1px, transparent 2px);
		background-size: 3px 1px;
	}

	#service_list .box a img{
		width: 12px;
		height: auto;
		margin-bottom: 2px;
	}
	

	/* ------- #service_list.col2 ------- */
	#service_list.col2 h3.ttl{
		font-size: 1.7rem;
		margin-bottom: 40px;
		padding-top: 0;
		background-size: 100% 3px;
	}
	#service_list.col2 .wrap{
		width: inherit;
	}
	#service_list.col2 .box{
		width: 100%;
		height: 200px;
		margin-bottom: 20px;
	}
	#service_list .box.bathroom{
		background: url(../img/service/img_bathroom_sp.jpg) no-repeat;
		background-size: 100% auto;
	}
	#service_list .box.kitchen{
		background: url(../img/service/img_kitchen_sp.jpg) no-repeat;
		background-size: 100% auto;
	}
	#service_list .box.sink{
		background: url(../img/service/img_sink_sp.jpg) no-repeat;
		background-size: 100% auto;
	}
	#service_list .box .ttl{
		width: 100px;
		height: 28px;
		font-size: 1.4rem;
		line-height: 28px;
		top: 10px;
	}
	#service_list .box a{
		width: 90%;
		max-width: 300px;
	}
	#service_list .box a span{
		margin-right: 10px;
	}

}


/* ------------------------------
    recommend
------------------------------ */
#recommend {
  padding-top: 90px;
}
@media screen and (max-width : 768px){
  #recommend {
    padding-top: 45px;
  }
}







/* ----------------------------------------------------------------------------------------------------
*   リノベーションの内容 詳細ページ
* --------------------------------------------------------------------------------------------------*/

/* ------------------------------
    service_point
------------------------------ */
#main_content{
  padding: 88px 0 40px;
}
#main_content .ttl{
  font-size: 4.2rem;
  margin-bottom: 25px;
}
#main_content .point{
	margin-bottom: 50px;
}
#main_content .point .img{
	position: relative;
	width: 300px;
}
#main_content .point .img span{
	position: absolute;
	background: #fff;
	left: 10px;
	bottom: 10px;
	text-align: center;
	font-size: 1.6rem;
	width: 105px;
	height: 27px;
	line-height: 27px;
}
#main_content .point .txt{
	width: calc(100% - 300px);
	padding: 10px 0 0 20px;
}
#main_content .point .txt p{
	font-size: 1.6rem;
}
/*
#main_content .point .txt p.center{
	font-size: 1.8rem;
	position: relative;
	width: 100%;
	height: 38px;
	line-height: 38px;
	background: url(../img/service/bg_point_txt.png) no-repeat;
	background-size: 340px auto;
	background-position: center;
	margin-bottom: 20px;
}
*/
#main_content .point .txt p.center{
	font-size: 1.8rem;
	position: relative;
	width: 338px;
	height: 36px;
	line-height: 36px;
	border: 1px dashed #000;
	margin-bottom: 20px;
}
#main_content .point .txt p.center::before{
	content: "";
	display: block;
	width: 36px;
	height: 47px;
	background: url(../img/service/icon_service_point.png) no-repeat;
	position: absolute;
/*	left: 88px;*/
	left: -53px;
	margin-top: -5px;
}
#main_content .after_area{
	background: #e1e0d2;
	padding: 30px 0;
}
#main_content .after_area p.center{
	font-size: 2.0rem;
	background: #fff;
	width: 225px;
	height: 41px;
	line-height: 41px;
	margin-bottom: 26px;
}
#main_content .after_area img + img{
	margin-left: 20px;
}
#main_content .after_area img{
	vertical-align: top;
}
#main_content .btn a{
	display: block;
	width: 620px;
	height: 66px;
	background: #c90012;
	color: #fff;
	font-size: 2.4rem;
	line-height: 66px;
	text-align: center;
  position: relative;
  margin: 46px auto 0;
}
#main_content .btn a img{
	vertical-align: baseline;
	margin-left: 8px;
}





@media screen and (max-width : 768px){
	#main_content{
		padding: 75px 0 40px;
	}
	#main_content .ttl{
		font-size: 2.3rem;
		margin-bottom: 25px;
	}
	#main_content .point{
		flex-direction: column-reverse;
		margin-bottom: 20px;
	}
	#main_content .point .img{
		width: 67%;
		max-width: 300px;
		margin: auto;
	}
	#main_content .point .img span{
		left: 6px;
		bottom: 6px;
		font-size: 1rem;
		width: 66px;
		height: 17px;
		line-height: 17px;
	}
	#main_content .point .txt{
		width: 100%;
		padding: 0;
		margin-bottom: 30px;
	}
	#main_content .point .txt p{
		font-size: 1.4rem;
		line-height: 1.57;
	}
/*
	#main_content .point .txt p.center{
		font-size: 1.3rem;
		max-width: 287px;
		height: 26px;
		line-height: 26px;
		background-size: 247px auto;
		background-position: 40px center;
		margin-bottom: 20px;
		padding-left: 40px;
	}
*/
	#main_content .point .txt p.center{
		font-size: 1.3rem;
		max-width: 247px;
		height: 26px;
		line-height: 26px;
		margin-bottom: 20px;
		left: 20px;
	}
	#main_content .point .txt p.center::before{
		width: 26px;
		height: 34px;
		background: url(../img/service/icon_service_point.png) no-repeat;
		background-size: 100%;
		position: absolute;
		left: -40px;
		margin-top: -5px;
	}
	#main_content .after_area{
		padding: 20px 0 36px;
	}
	#main_content .after_area p.center{
		font-size: 1.5rem;
		width: 152px;
		height: 30px;
		line-height: 30px;
		margin-bottom: 20px;
	}
	#main_content .after_area img{
		width: 100%;
		max-width: 400px;
		display: block;
		margin: auto;
	}
	#main_content .after_area img + img{
		margin-left: auto;
		margin-top: 22px;
	}
	#main_content .after_area img{
		vertical-align: bottom;
	}
	#main_content .btn a{
		width: 294px;
		height: auto;
		font-size: 1.8rem;
		line-height: 1.36;
		padding: 11px 0;
		margin: 23px auto 0;
	}
	#main_content .btn a img{
		width: 14px;
		height: auto;
		margin-left: 5px;
	} 
}





