/******************************************************************************************/
/************************************************************/
/*全ページ共通*/
/************************************************************/

body {
	line-height: 1.5;
	font-family: 'KozG-light','ヒラギノ角ゴ Pro W3',sans-serif;
	margin:0;
	padding:0;
	background-color: #ffffff;
	color:#333333;
	font-size: 13px;
	/**background-image:url(./img/haikei.jpg);**/
	background-repeat: repeat-x;
}



img {
	border:0;
	margin:0;
	padding:0;
}

table{
	border-collapse: collapse;
}

a {
	text-decoration:none;
	color:#000;
}

ul {
	margin:0;
	padding:0;
}

li {
	list-style: none outside none;
}

.clear{
	clear: both;
	height: 0;
}

.clear_2{
	clear:both;
}

.clear_3{
	clear:both;
	padding: 10px 0 50px;
}

#footer{
	background-color: #eeeeee;
	color: #555555;
	padding: 20px 0 0;
	text-align: center;
	/**margin: 100px 0 0;**/
	margin: 0;
}

.f_link {
	font-size: 110%;
	margin: 0 auto 10px;
	font-family: Georgia, "Times New Roman", Times, serif;
	max-width: 1170px;
}

.f_link ul{
}

.f_link li {
	float: left;
	width: 16%;
}

.f_link a {
	font-size: 100%;
	color: #555;
	display: block;
}

.f_link a::after{
	color: #5b5b5b;
	content: "|";
	float: right;
	margin: 0 0.6em;
}

.f_logo{
	clear: both;
	padding: 50px 0 20px 0;
}

.f_logo img{
	width: 300px;
}

.f_address{
	line-height: 2em;
}

.copyright {
	clear: both;
	font-size: 110%;
	margin: 20px auto 0;
	padding: 15px;
	text-align: center;
	font-weight: bold;
	font-family: 'Noto Serif JP', serif;
	background: #000;
	color: #fff;
}



#container{
	background-color: #eeeeee;
	width:1028px;
	margin:auto;
}

.guide{
	max-width: 1170px;
	margin: 20px auto 0;
	letter-spacing: 1px;
	color: #555;
	padding: 0 10px;
}

.h_guide{
	padding-right: 17px;
	background: url(../img/ico_pankuzu.png) no-repeat right 0.3em;
	background-position-x: right;
	background-position-y: 0.3em;
	background-position: right 0.2em;
}

.guide ul{
	
}

.guide li{
	display: inline;
	font-size: 14px;
}

.guide li a {
	color: #007ebe;
}

/**画像表示**/
.fadein {
	opacity : 0;
	transform: translateY(20px);
	transition: all 1s;
}

h3{
	font-size: 30px;
	text-align: center;
	position: relative;
	clear: both;
	margin: 30px auto 100px;
}


h3::after {
	position: absolute;
	content: '';
	width: 100px;
	height: 4px;
	background-color: #d92c2c;
	bottom: -20px;
	left: 50%;
	-webkit-transform: translate(-50%, 0);
	transform: translate(-50%, 0);
}

/************************************************************/
/*トップ**/
/************************************************************/




/************************************************************/
/*サブページ共通*/
/************************************************************/

#main {
	/*background:rgba(0, 0, 0, 0) url("../img/main_back_01.png") repeat scroll 0 0;*/
	background-color: #f5f5f5;
	margin: 0;
	padding: 0 0 60px;
}

#main_1 {
	/*background:rgba(0, 0, 0, 0) url("../img/main_back_1.png") repeat scroll 0 0;*/
	background-color: #f5f5f5;
	margin: 0;
	padding: 0 0 60px;
}

#main_2 {
	/*background:rgba(0, 0, 0, 0) url("../img/main_back_2.png") repeat scroll 0 0;*/
	background-color: #f5f5f5;
	margin: 0;
	padding: 0 0 60px;
}

#main_3 {
	/*background:rgba(0, 0, 0, 0) url("../img/main_back_3.png") repeat scroll 0 0;*/
	background-color: #f5f5f5;
	margin: 0;
	padding: 0 0 60px;
}

#main_4 {
	/*background:rgba(0, 0, 0, 0) url("../img/main_back_4.png") repeat scroll 0 0;*/
	background-color: #f5f5f5;
	margin: 0;
	padding: 0 0 60px;
}

.hero {

}

#main_index{
	background-color: #ffffff;
	margin: auto;
	max-width: 1170px;
}

.contents{
	animation-duration: 1s;
	animation-name: fadeInLeft;
	margin: 40px auto 0;
	max-width: 1170px;
	overflow: hidden;
	padding: 30px 50px;
	clear: both;
}

.contents_2{
	animation-duration: 1s;
	animation-name: fadeInLeft;
	margin: 40px auto 0;
	max-width: 1300px;
	overflow: hidden;
	padding: 30px 9% 50px;
	clear: both;
}

.sub_page_title{
	color: #000000;
	font-family: Georgia, "Times New Roman", Times, serif;
	/*font-size: 3em;*/
	letter-spacing: 5px;
	line-height: 1em;
	margin: auto;
	text-align: center;
	height: 400px;
}

.s_page_1{
	background-image: url(../img/index_1.jpg);
	background-size: cover;
	position: relative;
	background-position: 50%;
}

.sub_page_title_box{
	/*background-image: url(../img/top_2_bg.jpg);*/
	background-size: cover;
	position: relative;
	background-position: 50%;
	margin: 1px 0 0 0;
	background-attachment: fixed;
}

.sub_page_bg_1{
	background-image: url(../img/sub_page_bg_1.jpg);
}

.sub_page_bg_2{
	background-image: url(../img/sub_page_bg_2.jpg);
}

.sub_page_bg_3{
	background-image: url(../img/sub_page_bg_3.jpg);
}

.sub_page_bg_4{
	background-image: url(../img/sub_page_bg_4.jpg);
}

.inbg_2{
	background-color: rgba(0,0,0,0.4);
}

.s_page_2{

}

.s_page_3{
	background-image: url(../img/index_3.jpg);
	background-size: cover;
	position: relative;
	background-position: 50%;
}

.s_page_4{
	background-image: url(../img/index_4.jpg);
	background-size: cover;
	position: relative;
	background-position: 50%;
}

.sub_page_text_box{
	background: rgba(255,255,255,.9);
	width: 580px;
	border-radius: 10px;
	padding: 20px;
	position: absolute;
	margin: auto;
	top: 205px;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);

}

.page_title_text_1{
	font-size: 300%;
	font-weight: bold;
	color: #555555;
}

.page_title_text_2{
	font-size: 18px;
	color: #555555;
}

.page_title_text_box{
	
}

.page_title_text_3{
	font-size: 30px;
	font-weight: bold;
	color: #ffffff;
	position: absolute;
	margin: auto;
	width: 100%;
	top: 103px;
}

.page_title_text_3::after {
	position: absolute;
	content: '';
	width: 150px;
	height: 1.5px;
	background-color: #fff;
	bottom: -45%;
	left: 50%;
	-webkit-transform: translate(-50%, 0);
	transform: translate(-50%, 0);
}

.page_title_text_4{
	font-size: 18px;
	font-weight: bold;
	color: #ffffff;
	position: absolute;
	margin: auto;
	width: 100%;
	top: 203px;
}

.btm_inquiry {
	clear: both;
	background: #eee;
	background-image: url("../img/top_4_bg.jpg");
	background-size: cover;
	color: #fff;
}

.btm_inquiry_box {
	padding: 30px 30px 60px;
	clear: both;
	text-align: center;
}

.btm_inquiry_title {
	width: 100%;
	text-align: center;
	font-size: 300%;
	color: #fff;
	line-height: 1.6;
	letter-spacing: .1em;
	z-index: 100;
	font-family: Georgia, "Times New Roman", Times, serif;
}

.btm_inquiry p{
	font-size: 15px;
	line-height: 2em;
	padding: 20px 0;
}

.btm_inquiry_tel{
	float: left;
	width: 50%;
	text-align: right;
}

.btm_inquiry_tel b{
	font-size: 300%;
}

.btm_inquiry_button{
	float: left;
	width: 45%;
	text-align: left;
	padding: 25px 0px;
	margin: 0 0 0 5%;
}

.btm_inquiry_button i{
	font-size: 21px;
}

.button-7 {
	width: 320px;
	height: 70px;
	text-align: center;
	cursor: pointer;
	position: relative;
	box-sizing: border-box;
	overflow: hidden;
	background-color: #000;
	border: 2px solid #fff;
}

.eff-7 {
	width: 320px;
	height: 70px;
	border: 0px solid #34495e;
	position: absolute;
	transition: all .5s ease;
	z-index: 1;
	box-sizing: border-box;
}

.button-7:hover .eff-7 {
	border: 70px solid #76a1d2;
}

.button-7 a {
	color: #fff;
	text-decoration: none;
	line-height: 70px;
	transition: all .5s ease;
	z-index: 2;
	position: relative;
	display: block;
	font-size: 19px;
	letter-spacing: 0.2em;
}

.button-7:hover a {
	color: #fff;
}

.inbg {
	background-color: rgba(0,0,0,0.5);
}

/************************************************************/
/*事業案内*/
/************************************************************/

.duties{
	
}

.duties h1 {
	display: flex;
	align-items: center;
	text-align: center;
	font-family: Georgia, "Times New Roman", Times, serif;
	font-size: 300%;
}
.duties h1:before,
.duties h1:after {
	border-top: 1px solid;
	content: "";
	flex-grow: 1;
}
.duties h1:before {
	margin-right: 1rem;
}
.duties h1r:after {
	margin-left: 1rem;
}

.dut_text_1{
	text-align: center;
	font-family: Georgia, "Times New Roman", Times, serif;
	font-size: 15px;
	line-height: 2em;
	letter-spacing: 2px;
	margin: 50px 40px;
}

.dut_text_2{
    font-size: 13px;
    line-height: 2em;
}

.dut_text_2 p{
color: #0065ab;
    font-size: 18px;
    font-weight: bold;
    margin: 10px 0;
}

.dut_image{
	
}

.dut_image img{
    width: 100%;	
}

.duties_title {
	color: #0065ab;
	font-size: 200%;
	font-weight: bold;
	font-family: Georgia, "Times New Roman", Times, serif;
	border-bottom: solid;
	border-left: solid 40px;
	line-height: 40px;
	text-indent: 10px;
	margin: 0 0 10px 0;
}

.duties_box {
	margin: 60px 0 0;
	width: 100%;
}

.duties_box_text{
	background-color: #eee;
	line-height: 2.5;
	padding: 2% 3%;
	width: 100%;
	font-size: 14px;
	margin: 20px auto;
	max-width: 860px;
}

.duties_box_text p{
	font-family: Georgia, "Times New Roman", Times, serif;
}

.duties span {
	background-color: #222a85;
    border-radius: 4px;
    color: #fff;
    font-size: 13px;
    margin: 0 0 0 5px;
    padding: 3px 5px;
}

.thumb1 img,.thumb2 img,.thumb3 img,.thumb4 img,.thumb5 img,.thumb6 img {
	max-width: 123px;
}

.item1_2,.item1_3,.item1_4,.item1_5{
	display:none;
}

.item2_2,.item2_3,.item2_4,.item2_5{
	display:none;
}

.item3_2,.item3_3,.item3_4,.item3_5{
	display:none;
}

.item4_2,.item4_3,.item4_4,.item4_5{
	display:none;
}

.item5_2,.item5_3,.item5_4,.item5_5{
	display:none;
}

.item6_2,.item6_3,.item6_4,.item6_5{
	display:none;
}

#duties_1, #duties_2, #duties_3, #duties_4, #duties_5, #duties_6 {
	height: 10px;
}

/************************************************************/
/*会社概要*/
/************************************************************/

.about{
	width:100%;
}

.about_box_1{
	position: relative;
	/*font-family: Georgia, "Times New Roman", Times, serif;*/
	max-width: 1000px;
	margin: auto;
}

.about_box_1 h2{
	overflow: hidden;
	padding-right: 5vw;
	min-height: 140px;
}

.about_box_1 h2 span{
	display: inline-block;
	font-size: 2rem;
	line-height: 2;
	background: #0b76b7;
	padding: 0 1rem 0 3.5rem;
	margin-bottom: 1.5rem;
	transform: translate3d(0, 0, 0);
	color: #fff;
	width: 80%;
}

.about_box_1_text{
	width: 100%;
	position: relative;
	padding-top: 4rem;
	display: inline-block;
}

.about_box_1_text_box{
	background-image: url("../img/top_02_bg.jpg");
	background-size: cover;
}

.about_box_1_text_1 {
	background-color: rgba(255, 255, 255, 0.8);
	padding: 130px 45px 20px 45px;
	font-size: 16px;
	margin: -130px 0 0;
	line-height: 2.5em;

}

.about_box_1_text_2 {
	background-color: rgba(255, 255, 255, 0.8);
	padding: 0px 45px 60px 45px;
	font-size: 16px;
	margin: 0;
	line-height: 2em;
	
	text-align: right;
}

.about_box_1_text::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.about_box_1::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.about_box_1_text::before {
	content: "";
	background-image: repeating-linear-gradient(-45deg,#52CAEA, #0481A2 4px,transparent 0, transparent 8px);
	width: 200px;
	height: 200px;
	position: absolute;
	z-index: 0;
	left: -5rem;
	top: 0;
}


.about_box_1_right{
	width: 45vw;
	margin-left: -4vw;
	display: inline-block;
}


.about_box_1_right_image{
	position: relative;
	z-index: 0;
}


.about_box_1_right::after{
	content: '';
	display: block;
	padding-top: 61.8%;
	background-image:url('../img/about_1.jpg');
	background-size: cover;
	transform: translate3d(0, 0, 0);
	height: 100px;
}

/**/
.about_box_2{
	display: flex;
	position: relative;
	margin: 80px 0 0 0;
	font-family: Georgia, "Times New Roman", Times, serif;
	padding-top: 100px;
	padding-bottom: 50px;
	background:#fff;
}

.about_box_2 h2{
	overflow: hidden;
	min-height: 140px;
	text-align: right;
}

.about_box_2 h2 span{
	display: inline-block;
	font-size: 2rem;
	line-height: 2;
	background: #0b76b7;
	padding: 0 0 0 3.5rem;
	margin-bottom: 1.5rem;
	transform: translate3d(0, 0, 0);
	color: #fff;
	min-width: 350px;
}

.about_box_2_left{
	width: 44vw;
	position: relative;
	display: inline-block;
}

.about_box_2_right p{
	background: #eee;
	padding: 130px 10px 60px 45px;
	font-size: 16px;
	margin: -130px 0 0;
	line-height: 2em;
	border: solid #fff;
	border-radius: 10px;
}

.about_box_2::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.about_box_2_right::before {
	content: "";
	background-image: repeating-linear-gradient(-45deg,#52CAEA, #0481A2 4px,transparent 0, transparent 8px);
	width: 200px;
	height: 200px;
	position: absolute;
	z-index: 0;
	right: -4rem;
	top: 0;
}


.about_box_2_right{
	width: 50vw;
	margin-left: -2vw;
	display: inline-block;
	transform: translate3d(0, 0, 0);
	padding-top: 4rem;
}


.about_box_2_left_image{
	position: relative;
	z-index: 0;
}


.about_box_2_left::after{
	content: '';
	display: block;
	padding-top: 61.8%;
	background-image:url('../img/about_02.jpg');
	background-size: cover;
	transform: translate3d(0, 0, 0);
	height: 100px;
	
}


.about_box_5{
	background: #fff;
	padding: 50px 0;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	margin: 80px 0 0 0;
}

.about_box_5_index{
	width: 96%;
	max-width: 900px;
	margin: 0 auto;
}



.about table{
	width: 100%;
	margin: 80px 0 30px 0;
	justify-content: space-between;
}

.about tr{
	
}

.about th{
	width: 30%;
	background-color: #fff;
	border-bottom: 1px solid #ccc;
	font-weight: normal;
	font-size: 1.3em;
	padding: 20px 0;
	vertical-align: top;
	padding: 30px;
	text-align:left;
}

.about td{
	width: 70%;
	border-bottom: 1px solid #d3d3d3;
	font-size: 1.3em;
	padding: 20px 0;
	line-height: 2em;
	background-color: #fff;
}

.service p{
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 40px;
}

.service_flow{
	margin: 70px 0 40px;
	width: 100%;
}

.service_flow_step{
	clear: both;
	max-width: 940px;
	margin: auto;
}

.flow_step_number{
	float: left;
	max-width: 150px;
	width: 20%;
	text-align: center;
	background-color: #222a85;
	color: #fff;
	height: 150px;
	display: table-cell;
	vertical-align: middle;
	border: solid 1px #222a85;
	border-radius: 5px 0px 0px 5px;
}

.flow_step_number p{
	display: table-cell;
	vertical-align: middle;
	height: 150px;
	text-align: center;
	width: 1%;
}

.flow_step_number p span{
	font-size: 250%;
	font-weight: bold;
}

/*.flow_step_number::before{
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	margin-left: -15px;
	border: 15px solid transparent;
	border-top-color: transparent;
	border-top-style: solid;
	border-top-width: 15px;
	border-top: 15px solid #fff;
}*/

.flow_step_text{
	float: left;
	width: 80%;
	border: solid 1px #222a85;
	background-color: #efefef;
	border-radius: 0px 5px 5px 0px;
}

.flow_step_text p{
	display: table-cell;
	vertical-align: middle;
	height: 150px;
	width: 1%;
	font-size: 14px;
	line-height: 2em;
	padding: 0 30px;
}

.flow_step_arrow{
	border-top: 50px solid #222a85;
	border-right: 50px solid transparent;
	border-bottom: 20px solid transparent;
	border-left: 50px solid transparent;
	clear: both;
	width: 0px;
	margin: 20px auto 0;
}


/************************************************************/
/*業務案内*/
/************************************************************/

.duties{
	width:100%;
}

.duties_box_1{
	padding-left: 15vw;
	display: flex;
	position: relative;
	margin: 80px 0 0 0;
	/*font-family: Georgia, "Times New Roman", Times, serif;*/
}

.duties_box_1 h2{
	overflow: hidden;
	padding-right: 5vw;
	min-height: 140px;
}

.duties_box_1 h2 span{
	display: inline-block;
	font-size: 2rem;
	line-height: 2;
	background: #0b76b7;
	padding: 0 1rem 0 3.5rem;
	margin-bottom: 1.5rem;
	transform: translate3d(0, 0, 0);
	color: #fff;
	width: 70%;
	font-family: Georgia, "Times New Roman", Times, serif;
}

.duties_box_1_left{
	width: 44vw;
	position: relative;
	padding-top: 4rem;
	display: inline-block;
}

.duties_box_1_left p{
	background: #fff;
	padding: 130px 15% 60px 45px;
	font-size: 16px;
	margin: -130px 0 0;
	line-height: 2em;
}

.duties_box_1_left::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.duties_box_1::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.duties_box_1_left::before {
	content: "";
	background-image: repeating-linear-gradient(-45deg,#52CAEA, #0481A2 4px,transparent 0, transparent 8px);
	width: 200px;
	height: 200px;
	position: absolute;
	z-index: 0;
	left: -5rem;
	top: 0;
}


.duties_box_1_right{
	width: 45vw;
	margin-left: -4vw;
	display: inline-block;
}


.duties_box_1_right_image{
	position: relative;
	z-index: 0;
}


.duties_box_1_right::after{
	content: '';
	display: block;
	padding-top: 61.8%;
	background-image:url('../img/about_1.jpg');
	background-size: cover;
	transform: translate3d(0, 0, 0);
	height: 100px;
}

/**/
.duties_box_2{
	display: flex;
	position: relative;
	margin: 80px 0 0 0;
	font-family: Georgia, "Times New Roman", Times, serif;
	padding-top: 100px;
	padding-bottom: 50px;
	background:#fff;
}

.duties_box_2 h2{
	overflow: hidden;
	min-height: 140px;
	text-align: right;
}

.duties_box_2 h2 span{
	display: inline-block;
	font-size: 2rem;
	line-height: 2;
	background: #0b76b7;
	padding: 0 3.5rem 0 0;
	margin-bottom: 1.5rem;
	transform: translate3d(0, 0, 0);
	color: #fff;
	width: 70%;
}

.duties_box_2_left{
	width: 44vw;
	position: relative;
	display: inline-block;
}

.duties_box_2_right p{
	background: #eee;
	padding: 130px 10px 60px 45px;
	font-size: 16px;
	margin: -130px 0 0;
	line-height: 2em;
	border: solid #fff;
	border-radius: 10px;
}

.duties_box_2::after {
	content: "";
	background: #ffffff;
	width: 100%;
	height: 200px;
	position: absolute;
	z-index: -1;
	top: 87px;
	left: 0;
	transform: translate3d(0, 0, 0);
}

.duties_box_2_right::before {
	content: "";
	background-image: repeating-linear-gradient(-45deg,#52CAEA, #0481A2 4px,transparent 0, transparent 8px);
	width: 200px;
	height: 200px;
	position: absolute;
	z-index: 0;
	right: -4rem;
	top: 0;
}


.duties_box_2_right{
	width: 50vw;
	margin-left: -2vw;
	display: inline-block;
	transform: translate3d(0, 0, 0);
	padding-top: 4rem;
}


.duties_box_2_left_image{
	position: relative;
	z-index: 0;
}


.duties_box_2_left::after{
	content: '';
	display: block;
	padding-top: 61.8%;
	background-image:url('../img/about_02.jpg');
	background-size: cover;
	transform: translate3d(0, 0, 0);
	height: 100px;
	
}




.duties_box_4{
	background: #fff;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	margin: 80px 0 0 0;
	
	background-image: url("../img/top_03_bg.jpg");
	background-size: cover;
}

.duties_inbg {
	background-color: rgba(255, 255, 255, 0.7);
	padding: 50px 0;
}

.duties_box_4_index{
	width: 96%;
	max-width: 900px;
	margin: 0 auto;
}


.duties_box_5{
	background-color: #ffffff;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cg fill-rule='evenodd'%3E%3Cg id='hexagons' fill='%23d3d3d3' fill-opacity='0.4' fill-rule='nonzero'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
		
		
		padding: 50px 0;
		font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
		margin: 0px 0 0 0;
	}
	
	
	.duties_box_5_index{
		width: 96%;
		max-width: 900px;
		margin: 0 auto;
	}
	
	.flow_step_text b{
		color: #222a85;
		font-size: 18px;
		line-height: 2;
	}

/************************************************************/
/*施工事例*/
/************************************************************/

.construction h4{
	margin: 0 0 30px 0;
	position: relative;
	background: #0481A2;
	color: #fff;
	padding: 10px 20px;
	font-size: 23px;
}

.construction h4::after {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	bottom: -10px;
	left: 1.5em;
	border-width: 10px 10px 0 10px;
	border-style: solid;
	border-color: #0481A2 transparent transparent transparent;
}

.construction_box_1{
	max-width:1200px;
	margin: auto;
	padding:0 10px 100px;
}

.construction_box_1_list{
	
}

.construction_list{
	max-width:30%;
	float: left;
	background: black;
	border: solid 1px;
	margin: 0 1.5% 1.5%;
}


.construction_list p{
	margin: 0;
	padding: 10px;
	font-size: 20px;
	font-weight: bold;
	color: #fff;
	z-index: 100;
	position: sticky;
	background: black;
}

.construction_list img{
	width:100%;
	margin: 0;
	padding: 0;
	z-index: 0;
}

.construction_list{
	overflow:hidden; 
}

.construction_list img:hover{
	transform:scale(1.3);
	transition:0.3s;
}

.construction_list img{
	transition:0.3s;
}



.construction_box_2{
	
}

.construction_box_2_index{
	max-width: 1280px;
	padding: 0 50px;
	margin: auto;
}

.construction_box_2_text_1 {
	line-height: 2.5em;
	font-size: 16px;
	/*font-family: Georgia, "Times New Roman", Times, serif;*/
	text-align: center;
	margin: 70px 0 0px;
	clear: both;
}

.construction_box_2_text_2 {
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	clear: both;
}

.construction_price_box_1{
	width: 100%;
	margin: 30px 0px 60px 0;
}

.construction_price_box_1 table{
	width: 100%;
	justify-content: space-between;
}

.construction_price_box_1 tr{
	
}

.construction_price_box_1 th{
	background-color: #eeeeee;
	border: 1px solid #ccc;
	font-weight: normal;
	font-size: 1.3em;
	padding: 20px 0;
	color: #777;
	text-align: center;
}

.construction_price_box_1 td{
	width: 23%;
	border: 1px solid #ccc;
	font-size: 1.3em;
	padding: 20px 0;
	line-height: 2em;
	color: #777;
	text-align: center;
}




.construction_price_box_1_image{
	
}

.construction_price_box_1_image_1{
	max-width: 30%;
	float: left;
}

.construction_price_box_1_image_2{
	max-width: 30%;
	float: left;
	margin: 0 5% 3% 5%;
}

.construction_price_box_1_image_3{
	max-width: 30%;
	float: left;
}

.construction_price_box_1_image_1 img,.construction_price_box_1_image_2 img,.construction_price_box_1_image_3 img{
	width: 100%;
}


.construction_price_box_2_image{
	
}

.construction_price_box_2_image_1{
	max-width: 30%;
	float: left;
}

.construction_price_box_2_image_2{
	max-width: 30%;
	float: left;
	margin: 0 5% 3% 5%;
}

.construction_price_box_2_image_3{
	max-width: 30%;
	float: left;
}

.construction_price_box_2_image_1 img,.construction_price_box_2_image_2 img,.construction_price_box_2_image_3 img{
	width: 100%;
}



.construction_price_box_2{
	width: 100%;
	margin: 30px 0 0 0;
}

.construction_price_box_2 table{
	width: 100%;
	justify-content: space-between;
}

.construction_price_box_2 tr{
	
}

.construction_price_box_2 th{
	background-color: #eeeeee;
	border: 1px solid #ccc;
	font-weight: normal;
	font-size: 1.3em;
	padding: 20px 0;
	color: #777;
	text-align: center;
}

.construction_price_box_2 td{
	width: 23%;
	border: 1px solid #ccc;
	font-size: 1.3em;
	padding: 20px 0;
	line-height: 2em;
	color: #777;
	text-align: center;
}

.construction_plan_box_1{
	box-shadow: 0px 5px 10px 0 #dcdcdc;
	margin: 70px 0;
	border-radius: 10px;
	
}

.plan_title_1{
	font-size: 22px;
	margin: 0;
	line-height: 2;
	color: #fff;
	background: #0481A2;
	padding: 8px 25px;
	border-radius: 10px 10px 0 0;
	position: relative;
}

.plan_title_1::after {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	bottom: -10px;
	left: 1.5em;
	border-width: 10px 10px 0 10px;
	border-style: solid;
	border-color: #0481A2 transparent transparent transparent;
}

.plan_title_head{
	background: #FFFCE3;
	border-radius: 10px 10px 0 0;
}

.plan_title_1{
	
}

.plan_content_flex{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	align-items: center;
	background-color: #fff;
	padding: 60px 50px;
	border-radius: 0 0 10px 10px;
}

.plan_left{
	background-color: #fff;
	margin: 0;
	width: 50%;
}

.plan_left_price{
	
}

.plan_left_price h5{
	font-size: 22px;
	font-weight: bold;
	margin: 0;
	font-family: 'Noto Sans JP', sans-serif;
}

.plan_left_price h5 span{
	font-size: 50px;
	color: #FE8402;
	padding: 0 10px;
}

.plan_content_text{
	
}

.plan_content_text p{
	margin: 0;
	font-size: 16px;
	line-height: 3;
}

.plan_right{
	width: 45%;
	margin-left: 5%;
}

.plan_right img{
	border-radius: 10px;
	width: 100%;
	object-fit: cover;
	max-height: 250px;
}

.construction_plan_box_2 {
	width: 48%;
	float: left;
	margin: 2% 2% 2px 0%;
}

.construction_plan_box_3 {
	width: 48%;
	float: left;
	margin: 2% 0 2px 2%;
}

.plan_left_2{
	
}

.plan_content_flex_2{
	background-color: #fff;
	padding: 60px 50px;
	border-radius: 0 0 10px 10px;
}

.plan_content_text_2 p {
	margin: 0;
	font-size: 16px;
	line-height: 2;
}


/************************************************************/
/*施工ケース*/
/************************************************************/

.construction_case{
	background-color: #fff;
	padding: 0 0 50px 0;
}

.construction_case h3{
	padding: 50px 0 0 0;
}


.case_box_1{
	max-width: 1170px;
	margin: auto;
	background-color: #e6e6e6;
	padding: 40px;
}


.case_box_1_index{
	padding: 20px;
	background-color: #ffffff;
}

.case_box_1 h4{
	margin: 20px 0 40px;
	position: relative;
	background: #0481A2;
	color: #fff;
	padding: 10px 20px;
	font-size: 23px;
}

.case_box_1 h4::after {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	bottom: -10px;
	left: 1.5em;
	border-width: 10px 10px 0 10px;
	border-style: solid;
	border-color: #0481A2 transparent transparent transparent;
}

.case_arrow {
	float: left;
	width: 5%;
	font-size: 40px;
	margin: 10% 2% 0;
}

.case_box_1_list_1{
	max-width: 27%;
	float: left;
}


.case_box_1_list_2{
	max-width: 27%;
	float: left;
}

.case_box_1_list_3{
	max-width: 27%;
	float: left;
}

.case_box_1_list_1 p{
	text-align: center;
	font-size: 18px;
	background-color: #c65e03;
	padding: 10px;
	font-weight: bold;
	letter-spacing: 5px;
	color: #fff;
}

.case_box_1_list_2 p{
	text-align: center;
	font-size: 18px;
	background-color: #25884c;
	padding: 10px;
	font-weight: bold;
	letter-spacing: 5px;
	color: #fff;
}

.case_box_1_list_3 p{
	text-align: center;
	font-size: 18px;
	background-color: #1a00cc;
	padding: 10px;
	font-weight: bold;
	letter-spacing: 5px;
	color: #fff;
}

.case_box_1_list_1 img,.case_box_1_list_2 img,.case_box_1_list_3 img{
	width: 100%;
}

.case_box_1_list_text{
	
}

.case_box_1_list_text p{
	line-height: 2.5;
	font-size: 15px;
}

.construction{
	
}
/************************************************************/
/*メニュー*/
/************************************************************/

.menu_page{
	
}

.menu_page p{
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 40px;
}

.menu_list{
	
}

.menu_list_box{
	margin: 0;
	padding: 0;
	width: 100%;
}

.menu_list_item{
	padding: 0;
	float: left;
	width: 25%;
	margin: 0 0 3% 0;
	text-align: center;
	color: #555;
	line-height: 1.2;
}

.menu_list_item a{
	
}

.menu_list_item img{
	width: 100%;
	border: solid #fff 6px;
	
}



/************************************************************/
/*料金案内*/
/************************************************************/

.achievement_text {
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 40px;
}

.achievement_list{
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	padding: 0 0 100px 0;
}

.achievement_list ul{
	width: 100%;
	margin: auto;
}

.achievement_list li{
	float: left;
	width: 47%;
	font-size: 18px;
	text-align: center;
	border: 1px solid #ccc;
	margin: 10px 1%;
	background-color: #f5f5f5;
	padding: 10px 0;
}


.achievement_scenery{
	width: 46%;
	float: left;
	margin: 0% 2% 4% 2%;
}

.achievement_scenery img{
	width: 100%;
}

.achievement_scenery p{
	line-height: 2.5em;
	font-size: 15px;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	text-align: center;
	margin: 0;
}

/************************************************************/
/*料金案内*/
/************************************************************/

.price{
	
}

.price_box_1{
	width: 100%;
	margin: 0 0 100px 0;
}

.price_box_1_image{
	float: left;
	width: 48%;
	margin: 0 2% 0 0;
}

.price_box_1_image img{
	width: 100%;
}

.price_box_1_text{
	float: left;
	width: 50%;
}

.price_box_1_text h2{
	margin: 0 0 30px 0;
	position: relative;
	background: #0481A2;
	color: #fff;
	padding: 10px 20px;
	font-size: 23px;
}

.price_box_1_text h2::after {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	bottom: -10px;
	left: 1.5em;
	border-width: 10px 10px 0 10px;
	border-style: solid;
	border-color: #0481A2 transparent transparent transparent;
}

.price_box_1_text p{
	line-height: 2.3em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
}


.price_s_text {
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 0px;
	clear:both;
}

.cancel_box{
	margin: 50px 0 100px 0;
}

.kyori_box {
	margin: 50px 0 150px 0;
}


.kyori_text_1{
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 0px;
	clear: both;
}

.kyori_text_2{
	font-size: 16px;
	text-align: center;
	color:#ff0000;
	line-height: 2em;
}



.price table {
	width: 100%;
	justify-content: space-between;
}

.price tr {
}

.price th {
	background-color: #eeeeee;
	border: 1px solid #ccc;
	font-weight: normal;
	font-size: 1.3em;
	padding: 20px 0;
	color: #777;
	text-align: center;
}

.price td {
	width: 20%;
	border: 1px solid #ccc;
	font-size: 1.3em;
	padding: 20px 0;
	line-height: 2em;
	color: #777;
	text-align: center;
}

.cancel_month_1{
	/*background: #8cd9bc;*/
	background: #f9f9f9;
}

.cancel_month_2{
	/*background: #bee7ff;*/
	background: #f9f9f9;
}

.cancel_par_1{
	/*background: #c3e4d8;*/
}

.cancel_par_2{
	/*background: #d7e1f4;*/
}

.price_type_1{
	float: left;
	width: 49%;
	margin: 0 2% 0 0;
	border-bottom: solid 5px #5ebfb8;
}

.price_type_1_title{
	background: #5ebfb8;
	color: #fff;
	padding: 10px;
	font-size: 17px;
	font-weight: bold;
	letter-spacing: 1px;
}

.price_type_1_text_frame{
	background: #5ebfb8;
}

.price_type_1_text_box{
	margin: 0 5px 0px 5px;
	background: #fbfbfb;
	padding: 10px;
}

.price_type_stitle{
	font-size: 16px;
	margin: 10px 0 30px 0;
	background: linear-gradient(transparent 60%, #92cae6 60%);
}

.price_type_figure{
	width: 90%;
	margin: auto;
}

.price_type_figure_1{
	float: left;
	width: 43%;
	text-align: center;
	background-color: #eee;
	border-radius: 30px;
	padding: 10px 0;
}

.price_type_figure_2{
	float: left;
	width: 14%;
	text-align: center;
	margin: 80px 0 0 0;

}

.price_type_figure_3{
	float: left;
	width: 43%;
	text-align: center;
	background-color: #eee;
	border-radius: 30px;
	padding: 10px 0;
}

.price_type_figure_1 i{
	font-size: 60px;
	color: #2187c4;
}

.price_type_figure_2 i{
	font-size: 40px;
}

.price_type_figure_3 i{
	font-size: 60px;
	color: #c43021;
}

.figure_stitle{
	font-size: 17px;
	margin: 10px 0;
}

.figure_price{
	font-size: 22px;
	letter-spacing: 1px;
	font-weight: bold;
	margin: 10px 0;
	color: #f00;
}

.price_type_figure_arrow{
	text-align: center;
	font-size: 40px;
	color: #555;
	margin: 10px;
}

.price_type_figure_money{
	text-align: center;
	font-size: 25px;
	color: #555;
	padding: 10px;
}

.price_type_figure_money b{
	color: #ff0000;
}




.price_type_image {
	text-align: center;
}

.price_type_image img{
	width: 100%;
	max-width: 300px;
}

.price_type_2{
	float:left;
	width:49%;
	margin:0 0 100px 0;
	border-bottom: solid 5px #ef8949;
}

.price_type_2_title{
	background: #ef8949;
	color: #fff;
	padding: 10px;
	font-size: 17px;
	font-weight: bold;
	letter-spacing: 1px;
}

.price_type_2_text_frame{
	background: #ef8949;
}

.price_type_2_text_box{
	margin: 0 5px 0px 5px;
	background: #fff;
	padding: 10px;
	background: #fbfbfb;
}





/************************************************************/
/*採用情報*/
/************************************************************/

.recruit{
	animation-duration: 1s;
	animation-name: fadeInLeft;
	margin: 40px auto 0;
	max-width: 1028px;
	overflow: hidden;
	padding: 30px 50px;
	clear: both;
	background-color: #fff;
}

.rec_box{
	width: 90%;
	margin: auto;
	display: table;
}

.rec_left{
	width: 30%;
	background-color: #f2f2f2;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	padding: 20px 30px;
	clear: both;
	display: table-cell;
	vertical-align: top;
}

.rec_right{
	width: 60%;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	padding: 20px;
	line-height: 2em;
	display: table-cell;
}

.recruit h1{
	margin: 30px auto;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	text-align: center;
	font-size: 2.5em;
	letter-spacing: 5px;
}

.recruit p{
	width: 90%;
	margin: 30px auto;
	font-size: 1.1em;
}

.recruit_info{
	border: 3px solid #333333;
    margin: 30px auto;
    width: 90%;
}

.recruit_message{
    background-color: #333333;
    color: #ffffff;
    font-size: 18px;
    padding: 8px 0;
    text-align: center;
}

.recruit_tel{
    color: #555555;
    font-size: 40px;
    font-weight: bold;
    text-align: center;
	margin: 20px 0 0;
}

.recruit_tel:before{
content:"";
	display:inline-block;
	width:1em;
	height:1em;
	background:url(../img/tel.png) no-repeat;
	background-size:contain;
	margin: 0 5px 0 0;
}

.recruit_time{
    color: #555555;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
	clear: both;
}

.recruit_mail{
    margin: 40px 0;
    text-align: center;
}

.recruit_mail a{
	background: #0481a2 none repeat scroll 0 0;

    color: #ffffff;
    cursor: pointer;
    font-size: 18px;
    font-weight: bold;
    line-height: 1;
	padding: 15px 25px;
    text-align: center;
    vertical-align: middle;
	white-space: nowrap;
	transition: all .7s;
}

.recruit_mail a:hover{
	background: #000000 none repeat scroll 0 0;
	transition: all .7s;
}

/************************************************************/
/*よくある質問*/
/************************************************************/


.question_text {
	line-height: 2.5em;
	font-size: 16px;
	font-family: Georgia, "Times New Roman", Times, serif;
	text-align: center;
	margin: 70px 0 40px;
}

.answer{
	line-height: 2em;
	font-size: 15px;
	letter-spacing: 2px;
}


/************************************************************/
/*問合せ*/
/************************************************************/

.inquiry{
	
}

.inq_box{
	width: 90%;
	margin: auto;
	display: table;
}

.inq_left{
	width: 30%;
	background-color: #f2f2f2;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	padding: 20px 30px;
	clear: both;
	display: table-cell;
	vertical-align: top;
}

.inq_right{
	width: 60%;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	padding: 20px;
	line-height: 2em;
	display: table-cell;
}

.inquiry h1{
	width: 90%;
	margin: auto;
	border-left: 8px solid #16a085;
	padding: 5px 0 5px 0;
	text-indent: 15px;
}

.inquiry p{
	width: 90%;
	margin: 30px auto;
	font-size: 1.1em;
}

textarea {
	background-color: #fff;
	border: 1px solid #ccc;
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
	transition: border 0.2s linear 0s, box-shadow 0.2s linear 0s;
	border-radius: 4px;
	color: #555;
	display: inline-block;
	font-size: 14px;
	line-height: 20px;
	margin-bottom: 10px;
	padding: 4px 6px;
	vertical-align: middle;
	margin: 0;
	width: 90%;
}

input[type="text"] {
	background-color: #fff;
	border: 1px solid #ccc;
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
	transition: border 0.2s linear 0s, box-shadow 0.2s linear 0s;
	border-radius: 4px;
	color: #555;
	display: inline-block;
	font-size: 14px;
	height: 20px;
	line-height: 20px;
	margin-bottom: 10px;
	padding: 4px 6px;
	vertical-align: middle;
	margin: 0 5px 0 0;
	width: 90%;
}

select{
	font-size: 1em;
}

.inquiry span{
	background-color: #ed3b3b;
	color: #fff;
	padding: 3px 5px;
	margin: 0 0 0 5px;
	border-radius: 4px;
	font-size: 13px;
	float: right;
}

button {
	padding: 10px 13px 11px;
	font-size: 18px;
	cursor: pointer;
	font-weight: bold;
	font-weight: bold;
	border-radius: 4px;
	line-height: 1;
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;
	border: 1px solid #0093c9;
	color: #ffffff;
	background: #009ecf;
	box-shadow: 0px 1px 1px rgba(0,0,0,0.28),inset 0px 2px 0px -1px #10a4d2;
}

input[type="button"]{
	padding: 10px 13px 11px;
	font-size: 18px;
	cursor: pointer;
	font-weight: bold;
	font-weight: bold;
	border-radius: 4px;
	line-height: 1;
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;
	border: 1px solid #ccc;
	color: #ffffff;
	background: #565656;
}

.inq_btn{
	text-align: center;
	margin: 50px 0;
}

.inquiry .error{
	color: #f00;
}

/******************************************************************************************/
/*【PC】*/
/******************************************************************************************/
/*@media screen and (min-width:1128px) {*/
@media screen and (min-width:768px) {
	
	/*pc用のcssを記述*/
	
	
	.menu_sp_box{
		display:none;
	}
	
	.menu_pc_box{
		border-bottom: solid #ffffff 1px;
	}
	
	.pc_logo{
		display:block;
	}
	
	.sp_logo{
		display:none;
	}
	
	#header_frame{
		height: 163px;
	}
	
	/**ヘッダーデフォルト**/
	#header {
		/*background-color:#fff;*/
		font-family: "Raleway",sans-serif;
		/*height: 80px;*/
		padding: 0;
		/*position: fixed;*/
		width: 100%;
		z-index: 9999;
		top: 0;
		/*border-bottom: solid 1px #ccc;*/
		transition: all .5s ease;
	}
	
	#header #logo{
		float: left;
	}
	
	
	
	#header #logo img {
		height: 94px;
		margin: 5px 0 0 10px;
		transition: all .5s ease;
	}
	
	
	#header .h_contents{
		max-width: 1170px;
		margin: auto;
	}
	
	
	#header #logo a {
		color: #c00;
		font-family: "Tinos",serif;
		font-size: 24px;
		height: 0;
		overflow: hidden;
		padding-top: 60px;
		width: 260px;
	}
	
	
	#header #menu_back{
		font-family: "Raleway",sans-serif;
		font-weight: 800;
		line-height: 55px;
		letter-spacing: 2px;
		text-transform: uppercase;
		width: 100%;
		z-index: 9999;
	}
	
	
	#header #menu dl,
	#header_2 #menu dl	{
		display: table;
		table-layout: fixed;
		font-size: 13px;
		margin: 0;
		width: 100%;
	}
	
	#header #menu dd,
	#header_2 #menu dd	{
		display: table-cell;
		text-align: center;
		vertical-align: middle;
	}
	
	
	#header .m_btn a,#header .now_m_btn a,
	#header_2 .m_btn a,#header_2 .now_m_btn a{
		/*背景色の基点とするためrelativeを指定*/
		position: relative;
		/*アニメーションの指定*/
		transition: all .7s;
		color: #555;
		display: block;
		font-weight: normal;
		font-size: 1.1em;
		/*padding: 0 15px 0;*/
		/*border-bottom: solid #fff 3px;*/
		/*font-family: Georgia, "Times New Roman", Times, serif;*/
		/*font-family: Georgia, "メイリオ",Meiryo,"ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN,sans-serif;*/
	}
	
	/****現ページのボタンデザイン****/
	#header .now_m_btn a::after,
	#header_2 .now_m_btn a::after	{
		content: '';
		/*絶対配置で線の位置を決める*/
		position: absolute;
		z-index: -1;
		bottom: 0;
		left: 0;
		/*背景の形状*/
		width: 100%;
		height: 1px;
		opacity: 1;
		/*アニメーションの指定*/
		animation:bgappear_2 0.5s forwards;
	}
	
	
	/****ボタンデザイン****/
	#header .m_btn a::after,
	#header_2 .m_btn a::after{
		content: '';
		/*絶対配置で線の位置を決める*/
		position: absolute;
		z-index: -1;
		bottom: 0;
		left: 0;
		/*背景の形状*/
		width: 0;
		height: 1px;
		background:#0481A2;
		opacity: 0;/*はじめは透過を0に*/
	}
	
	
	/****ロールオーバー時のボタンデザイン****/
	#header .now_m_btn a:hover::after,#header .m_btn a:hover::after,
	#header_2 .now_m_btn a:hover::after,#header_2 .m_btn a:hover::after	{
		/*背景の形状*/
		width: 100%;
		opacity: 1;
		/*アニメーションの指定*/
		animation:bgappear 0.5s forwards;
	}
	
	
	
	/*アニメーションで線を伸ばして背景をつける*/
	@keyframes bgappear{
		0% {
			width: 0%;
			height: 1px;
		}
		
		50% {
			width: 100%;
			height: 1px;
		}
		
		100% {
			width: 100%;
			height: 100%;
			background: #0481A2;
		}
	}
	
	/*アニメーションで線を伸ばして背景をつける（現在のページ）*/
	@keyframes bgappear_2{
		0% {
			width: 0%;
			height: 1px;
		}
		
		50% {
			width: 100%;
			height: 1px;
		}
		
		100% {
			width: 100%;
			height: 5px;
			background: #0481A2;
		}
	}
	
	
	/*ロールオーバー時のボタンテキスト*/
	#header .m_btn a:hover,#header .now_m_btn a:hover,
	#header_2 .m_btn a:hover,#header_2 .now_m_btn a:hover{
		color: #fff;
		/*テキストを最前面へ*/
		z-index: 1;
	}
	
	
	
	
	#header .pc_logo_2{
		display:none;
	}
	
	/**ヘッダースクロール**/
	#header_2 {
		background-color:rgba(255, 255, 255, 0.9);
		font-family: Georgia, "Times New Roman", Times, serif;
		/*font-family: Georgia, "メイリオ",Meiryo,"ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN,sans-serif;*/
		height: 60px;
		padding: 0;
		position: fixed;
		width: 100%;
		z-index: 9999;
		top: 0;
		border-bottom: solid 1px #ccc;
		transition: all .5s ease;
	}
	
	#header_2 #logo{
		position: absolute;
		left: 0;
	}
	
	#header_2 #logo img {
		height: 35px;
		margin: 13px 0 0 40px;
		transition: all .5s ease;
		display: none;
	}
	
	#header_2 .h_contents{
		max-width: 1170px;
		margin: auto;
	}
	
	
	#header_2 #logo a {
		color: #c00;
		font-family: "Tinos",serif;
		font-size: 24px;
		height: 0;
		overflow: hidden;
		padding-top: 60px;
		width: 260px;
	}
	
	
	#header_2 #menu_back{
		font-family: "Raleway",sans-serif;
		font-weight: 800;
		line-height: 57px;
		letter-spacing: 2px;
		text-transform: uppercase;
		width: 100%;
		z-index: 9999;
	}
	
	#header_2 .pc_logo{
		display:none;
	}
	
	
	
	
	
	.head_right_box{
		float: right;
	}
	
	.head_tell_box{
		float: left;
	}
	
	.head_tell_box b {
		font-size: 25px;
	}
	
	.fa-solid.fa-square-phone{
		margin: 0 10px 0 0;
	}
	
	#header .far.fa-envelope {
		margin: 0 5px;
		font-size: 15px;
	}
	
	
	.head_inquiry_box{
		float: right;
		background-color: #333;
		margin:30px 10px 0px 20px;;
	}
	
	
	
	.head_inquiry_box a{
		color: #fff;
		font-size: 14px;
		padding: .8em 1.5em;
		display:block;
		transition: .3s;
		border: solid 1px;
	}
	
	.head_inquiry_box a:hover {
		color: #fff !important;
		text-decoration: none;
		transition: .3s;
		border: solid 1px;
		background-color: #76a1d2;
	}
	
	.head_right_box{
		
	}
	
	#header_2 .head_right_box,#header_2 .head_tell_box{
		display:none;
	}
	

	
}

/************************************************************/
/*業務案内*/
/************************************************************/

.duties_box {
	margin: 60px 0 0;
	width: 100%;
}

.duties_box_image {
	background: #fff none repeat scroll 0 0;
	border: 1px solid #cecece;
	padding: 1%;
	width: 100%;
	margin: auto;
	max-width: 900px;
}

.duties_box_image_1, .duties_box_image_2, .duties_box_image_3, .duties_box_image_4, .duties_box_image_5, .duties_box_image_6 {
	float: left;
	width: 85%;
}

.duties_box_image img {
	width: 100%;
	border: solid 1px #eee;
}

.s_image {
	float: left;
	width: 15%;
	margin: 0;
	padding: 0;
}

.s_image li {
	margin: 0 0 10px 10px;
	padding: 0;
	font-size: 0;
}

.thumb1 img, .thumb2 img, .thumb3 img, .thumb4 img, .thumb5 img, .thumb6 img {
	margin: 0;
	padding: 0;
	width: 100%;
}

/******************************************************************************************/
/*【スマホ】*/
/******************************************************************************************/

@media screen and (max-width:768px) { 
	
	
	
	/************************************************************/
	/*全ページ共通*/
	/************************************************************/
	
	body {
		line-height: 1.5;
		font-family: 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',Helvetica,Osaka,Verdana,Arial,sans-serif;
		margin:0;
		padding:0;
		color:#333333;
		font-size: 13px;
		background-color:#efefef;
		/**background-image:url(../img/haikei.jpg);**/
		background-repeat: repeat-x;
		max-width: 768px;
	}
	
	.menu_pc_box{
		display:none;
	}
	
	.menu_sp_box{
		display:block;
	}
	
	.rest_sp_box{
		display:block;
	}
	
	.rest_pc_box{
		display:none;
	}
	
	.sp_top_logo{
		text-align: center;
		position: absolute;
		height: 100%;
	}
	
	.pc_logo{
		display:none;
	}
	
	.pc_logo_2{
		display:none;
	}
	
	.sp_logo{
		display:block;
	}
	
	.head_right_box{
		display:none;
	}
	
	.sp_top_logo img {
		width: 45%;
		margin: 50% 0 0 0;
	}
	
	.hero {
			background-color: rgba(9,24,55,0.5);
	}
	
	
	img {
		border:0;
		margin:0;
		padding:0;
	}
	
	p {
		line-height: 2;
	}
	
	table{
		border-collapse: collapse;
	}
	
	a {
		text-decoration:none;
		color:#000;
	}
	
	ul {
		margin:0;
		padding:0;
	}
	
	li {
		list-style: none outside none;
	}
	
	#footer{
		background-color: #111111;
		color: #ffffff;
		padding: 40px 0;
		text-align: center;
	}
	
	
	#header {
		background: rgba(255, 255, 255, 0.8) none repeat scroll 0 0;
		/*background: rgba(35, 24, 2, 0.8) none repeat scroll 0 0;*/
		box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
		font-family: "Raleway",sans-serif;
		font-weight: 800;
		left: 0;
		letter-spacing: 2px;
		line-height: 50px;
		padding: 15px 0;
		position: fixed;
		text-transform: uppercase;
		top: 0;
		transition: all 0.4s ease 0s;
		width: 100%;
		z-index: 9999;
	}
	
	.h_contents{
		animation-duration: 1s;
		animation-name: fadeInLeft;
		margin: 0 auto;
		max-width: 700px;
		overflow: hidden;
	}
	
	#header #logo a {
		color: #c00;
		float: left;
		font-family: "Tinos",serif;
		font-size: 24px;
		/*height: 45px;*/
		overflow: hidden;
		width: 260px;
		margin: 0 0 0 10px;
	}
	
	#logo img{
		width: 260px;
	}
	
	
	#header dl {
		font-size: 14px;
		margin: 0;
	}
	
	#header dd {
		margin: 0;
	}
	
	#header dd a {
		border-bottom: 1px dotted #bbbbbb;
		text-align: center;
		line-height: 60px;
	}
	
	#header a, #header dt {
		display: block;
	}
	
	
	#nav-drawer {
		position: relative;
		float: left;
		margin: 1.4% 3% 0 2%;
	}
	
	/*チェックボックス等は非表示に*/
	.nav-unshown {
		display:none;
	}
	
	/*アイコンのスペース*/
	#nav-open {
		display: inline-block;
		width: 32px;
		height: 32px;
		vertical-align: middle;
	}
	
	
	#nav-open span:before {
		bottom: -8px;
	}
	#nav-open span:after {
		bottom: -16px;
	}
	
	/*閉じる用の薄黒カバー*/
	#nav-close {
		display: none;/*はじめは隠しておく*/
		position: fixed;
		z-index: 99;
		top: 0;/*全体に広がるように*/
		left: 0;
		width: 100%;
		height: 100%;
		background: rgba(4, 129, 162, 0.5) none repeat scroll 0 0;
		opacity: 0;
		transition: .3s ease-in-out;
	}
	
	/*中身*/
	#nav-content {
		overflow: auto;
		position: fixed;
		top: 77px;
		left: 0;
		z-index: 9999;/*最前面に*/
		width: 80%;/*右側に隙間を作る*/
		height: 100%;
		/*background: #fff;背景色*/
		background: rgba(4, 129, 162, 0.5) none repeat scroll 0 0;
		transition: .3s ease-in-out;/*滑らかに表示*/
		-webkit-transform: translateX(-105%);
		transform: translateX(-105%);/*左に隠しておく*/
	}
	
	/*チェックが入ったらもろもろ表示*/
	#nav-input:checked ~ #nav-close {
		display: block;/*カバーを表示*/
		opacity: .5;
	}
	
	#nav-input:checked ~ #nav-content {
		-webkit-transform: translateX(0%);
		transform: translateX(0%);/*中身を表示*/
		box-shadow: 6px 0 25px rgba(0,0,0,.15);
	}
	
	
	.m_btn a {
		background: rgba(4, 129, 162, 0.9) none repeat scroll 0 0;
		color: #fff;
	}
	
	.jump a {
		background: rgba(34,89,60, 0.9) none repeat scroll 0 0;
		color: #fff;
		font-size: 12px;
	}
	
	
	/*ヘッダー下*/
		
	#header_2 {
		background: rgba(255, 255, 255, 0.8) none repeat scroll 0 0;
		/*background: rgba(35, 24, 2, 0.8) none repeat scroll 0 0;*/
		box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
		font-family: "Raleway",sans-serif;
		font-weight: 800;
		left: 0;
		letter-spacing: 2px;
		line-height: 50px;
		padding: 15px 0;
		position: fixed;
		text-transform: uppercase;
		top: 0;
		transition: all 0.4s ease 0s;
		width: 100%;
		z-index: 9999;
	}

	#header_2 #logo a {
		color: #c00;
		float: left;
		font-family: "Tinos",serif;
		font-size: 24px;
		/*height: 45px;*/
		overflow: hidden;
		width: 260px;
		margin: 0 0 0 10px;
	}
	
	
	#header_2 dl {
		font-size: 14px;
		margin: 0;
	}
	
	#header_2 dd {
		margin: 0;
	}
	
	#header_2 dd a {
		border-bottom: 1px dotted #bbbbbb;
		text-align: center;
		line-height: 60px;
	}
	
	#header_2 a, #header dt {
		display: block;
	}
	
	.f_logo img {
    width: 200px;
	}
	
	.guide{
		max-width: 1128px;
		margin: 20px 0 0 20px;
	}
	
	.f_link li {
		float: none;
		width: 100%;
		line-height: 3em;
	}
	
	.f_link a::after{
		content: none;
	}
	
	
	
	
	/*ここから*/
	
	h3 {
		font-size: 1.5rem;
		margin: 30px auto 50px;
	}
	
	h3 span {
		font-size: 1.3rem;
	}
	
	.fa-solid, .fas {
		margin: 0 10px 0 0;
	}
	
	.sub_page_title_box {
		background-attachment: scroll;
		}
	
	/*フッダー*/
	
	#footer {
		background-color: #fff;
		color: #ffffff;
		padding: 40px 0 0 0;
		text-align: center;
	}
	
	.btm_inquiry_title {
		font-size: 200%;
	}
	
	.btm_inquiry_tel {
		float: none;
		width: 100%;
		text-align: center;
	}
	
	.btm_inquiry_button {
		float: none;
		width: 300px;
		text-align: center;
		padding: 25px 0px;
		margin: auto;
	}
	
	.btm_inquiry_tel b {
		font-size: 9vw;
	}
	
	
	
	
	/************************************************************/
	/*トップ**/
	/************************************************************/
	
	
	
	
	/************************************************************/
	/*サブページ共通*/
	/************************************************************/
	
	
	
	
	#main{
		background: #ffffff url("../img/main_back.png");
		margin: 0;
		padding: 80px 0 50px;
	}
	
	#main_index {
		max-width: 95%;
		margin: auto;
	}
	
	.main_text{
		font-size: 16px;
		font-weight: bold;
		line-height: 2;
		padding: 0 0 40px;
		text-align: center;
	}
	
	.sub_page_text_box {
		top: 255px;
		width: 80%;
	}
	
	.sub_page_title{
		color: #000000;
		font-family: "Cinzel",serif;
		/*font-size: 3em;*/
		letter-spacing: 5px;
		/*line-height: 5em;*/
		margin: auto;
		text-align: center;
		height: 420px;
	}
	
	
	.page_title_text_1{
		font-size: 2rem;
		font-weight: bold;
		color: #555555;
		margin: 0;
		letter-spacing: 2px;
	}
	
	.page_title_text_2{
		font-size: 18px;
		color: #555555;
		margin: 0;
	}
	
	.page_title_text_box{
		
	}
	
	.contents{
		animation-duration: 1s;
		animation-name: fadeInLeft;
		background-color: #ffffff;
		margin: 20px auto 0;
		max-width: 100%;
		overflow: hidden;
		padding: 0 5px 10px 5px;
	}
	
	.clear_2 {
		clear: both;
	}
	
	.clear_3 {
		display: none;
	}
	
	
	/************************************************************/
	/*ほっこりフードとは*/
	/************************************************************/
	
	.about_box_1 {
		padding-left: 0;
		display: block;
		position: relative;
		margin: 50px 20px 0 20px;
		width: auto;
	}
	
	.about_box_1 h2 {
		position: relative;
		left: 40px;
		max-width: 330px;
	}
	
	.about_box_1 h2 span {
		font-size: 1.3rem;
		padding: 0 10px 0 20px;
	}
	
	.about_box_1_left{
		width: 100%;
	}
	
	.about_box_1_left p{
		padding: 80px 20px 60px 20px;
		font-size: 3.8vw;
	}
	
	.about_box_1_left::before {
		left: 10px;
		top: 50px;
		width: 150px;
		height: 100px;
	}
	
	.about_box_1_right {
		width: 100%;
		margin-left: 0;
	}
	
	
	.about_box_2 {
		padding-left: 0;
		display: block;
		position: relative;
		margin: 50px 20px 0 20px;
		width: auto;
		padding-top:0;
		padding-bottom:0;
		background: #f5f5f5;
	}
	
	.about_box_2 h2 {
		position: relative;
		right: 10px;
		max-width: 90%;
	}
	
	.about_box_2 h2 span {
		font-size: 1.3rem;
		padding: 0 30px 0 0px;
		min-width: 280px;
	}
	
	.about_box_2_left{
		width: 100%;
		display: none;
	}
	
	.about_box_2_right p{
		padding: 80px 20px 60px 20px;
		font-size: 3.8vw;
		border-radius: 0;
		border: none;
		background: #fff;
	}
	
	.about_box_2_right::before {
		top: 50px;
		width: 150px;
		height: 100px;
	}
	
	.about_box_2_right::before {
		right: 0;
	}
	
	.about_box_2_right {
	width: 100%;
	margin-left: 0;
}

	/************************************************************/
	/*会社概要*/
	/************************************************************/
	
	.duties_box_1 {
		padding-left: 0;
		display: block;
		position: relative;
		margin: 50px 20px 0 20px;
		width: auto;
	}
	
	.duties_box_1 h2 {
		position: relative;
		left: 40px;
		max-width: 330px;
	}
	
	.duties_box_1 h2 span {
		font-size: 1.3rem;
		padding: 0 10px 0 20px;
	}
	
	.duties_box_1_left{
		width: 100%;
	}
	
	.duties_box_1_left p{
		padding: 80px 20px 60px 20px;
		font-size: 3.8vw;
	}
	
	.duties_box_1_left::before {
		left: 10px;
		top: 50px;
		width: 150px;
		height: 100px;
	}
	
	.duties_box_1_right {
		width: 100%;
		margin-left: 0;
	}
	
	
	.duties_box_2 {
		padding-left: 0;
		display: block;
		position: relative;
		margin: 50px 20px 0 20px;
		width: auto;
		padding-top:0;
		padding-bottom:0;
		background: #f5f5f5;
	}
	
	.duties_box_2 h2 {
		position: relative;
		right: 10px;
		max-width: 90%;
	}
	
	.duties_box_2 h2 span {
		font-size: 1.3rem;
		padding: 0 30px 0 0px;
		min-width: 280px;
	}
	
	.duties_box_2_left{
		width: 100%;
		display: none;
	}
	
	.duties_box_2_right p{
		padding: 80px 20px 60px 20px;
		font-size: 3.8vw;
		border-radius: 0;
		border: none;
		background: #fff;
	}
	
	.duties_box_2_right::before {
		top: 50px;
		width: 150px;
		height: 100px;
	}
	
	.duties_box_2_right::before {
		right: 0;
	}
	
	.duties_box_2_right {
		width: 100%;
		margin-left: 0;
	}
	
	/************************************************************/
	/*施工事例*/
	/************************************************************/
	
	.construction_list {
		max-width: 43%;
		float: left;
		background: black;
		border: solid 1px;
		margin: 0 3% 5%;
	}
	
	
	.case_box_1_list_1{
		max-width: 100%;
		float: none;
		margin: auto;
	}
	
	
	.case_box_1_list_2{
		max-width: 100%;
		float: none;
		margin: auto;
	}
	
	.case_box_1_list_3{
		max-width: 100%;
		float: none;
		margin: auto;
	}
	
	.case_arrow {
		float: none;
		width: 100%;
		font-size: 40px;
		margin: 3% 0;
		text-align: center;
		transform: rotate(90deg);
	}
	
	.case_box_1_list_1 p{
		text-align: center;
		font-size: 18px;
		background-color: #c65e03;
		padding: 10px;
		font-weight: bold;
		letter-spacing: 5px;
		color: #fff;
	}
	
	.case_box_1_list_2 p{
		text-align: center;
		font-size: 18px;
		background-color: #25884c;
		padding: 10px;
		font-weight: bold;
		letter-spacing: 5px;
		color: #fff;
	}
	
	.case_box_1_list_3 p{
		text-align: center;
		font-size: 18px;
		background-color: #1a00cc;
		padding: 10px;
		font-weight: bold;
		letter-spacing: 5px;
		color: #fff;
	}
	
	.case_box_1_list_1 img,.case_box_1_list_2 img,.case_box_1_list_3 img{
		width: 100%;
	}
	
	.case_box_1_list_text{
		
	}
	
	.case_box_1,.case_box_2,.case_box_3 {
		padding: 40px 20px;
	}
	
	.construction_plan_box_1 {
		margin: 50px 0 30px;
	}
	
	.construction_box_2_index {
		padding: 0 20px;
	}
	
	.plan_content_flex{
		display: block;
		padding: 30px;
	}
	
	.plan_left {
		background-color: #fff;
		margin: 0;
		width: 100%;
	}
	
	.plan_right {
		background-color: #fff;
		margin: 0;
		width: 100%;
	}
	
	.plan_right img {
		max-height: 300px;
	}
	
	.plan_content_text p {
		margin: 0 0 20px 0;
	}
	
	.construction_plan_box_2,.construction_plan_box_3 {
		width: 100%;
		float: none;
		margin: 50px 0 30px;
	}
	
	.plan_content_flex_2{
		padding: 30px;
	}
	
	/************************************************************/
	/*メニュー*/
	/************************************************************/
	
	.menu_list_item {
		width: 49%;
	}
	
	/************************************************************/
	/*実績*/
	/************************************************************/
	
	.achievement_list li {
		float: none;
		width: 98%;
	}
	
	.achievement_scenery {
		width: 100%;
		float: none;
		margin: 0% auto 5% auto;
	}
	
	/************************************************************/
	/*よくある質問*/
	/************************************************************/
	
	.question_list .title{
		padding: 3% 40px 3% 10px;
	}
	
	/************************************************************/
	/*料金案内*/
	/************************************************************/
	
	.price_box_1_image {
		float: none;
		width: 100%;
		margin: 0 0% 30px 0;
	}
	
	.price_box_1_text {
		float: none;
		width: 100%;
	}
	
	
	.price_type_1 {
		float: none;
		width: 100%;
		margin: 0 0 50px 0;
	}
	
	.price_type_2 {
		float: none;
		width: 100%;
		margin: 0 0 100px 0;
	}
	
	.price_type_stitle {
		font-size: 16px;
		margin: 10px 0 30px 0;
		background: #329fd5;
		padding: 10px;
		text-align: center;
		color: #fff;
	}
	
	.service_flow_step {
		width: 100%;
	}
	
	.flow_step_number {
		height: auto;
		width: 100%;
		border-radius: 0px;
		float: none;
		max-width: 960px;
		display: block;
	}
	
	.flow_step_number p {
		height: 70px;
		font-size: 14px;
	}
	
	.flow_step_text p {
		height: auto;
		padding: 20px 30px;
	}
	
	.flow_step_text {
		width: 100%;
		border-radius: 0px;
		float: none;
	}
	
	.service_flow_br{
		display: none;
	}
	
	/************************************************************/
	/*業務案内*/
	/************************************************************/

	
	.duties_title {
		font-size: 150%;
		border-left: solid 30px;
		line-height: 30px;

	}
	
.duties_box_text {
		background-color: #eee;
		float: none;
		line-height: 2;
		padding: 10px;
		width: 95%;
}

.duties h1 {
    font-size: 22px;
}
	
	.duties_box {
		margin: 60px 0 0;
		width: 100%;
	}
	
	.duties_box_image {
		background: rgba(0, 0, 0, 0) none repeat scroll 0 0;
		border: medium none;
		float: none;
		padding: 0;
		width: 100%;
	}
	
	.duties_box_image img {
		width: 100%;
		border: solid 1px #eee;
	}
	
	.s_image {
		display: table;
		width: auto;
	}
	
	.s_image li {
		margin: 1% 0px 0 0;
		display: table-cell;
		padding: 1%;
	}
	
	.thumb1 img, .thumb2 img, .thumb3 img, .thumb4 img, .thumb5 img, .thumb6 img {
		max-width: 123px;
	}
	
	.duties_box_image_1, .duties_box_image_2, .duties_box_image_3, .duties_box_image_4, .duties_box_image_5, .duties_box_image_6 {
		float: none;
		width: 100%;
	}
	
	
	

	
	
	/************************************************************/
	/*採用情報*/
	/************************************************************/
	
.rec_box {
    display: block;
    margin: auto;
    width: 100%;
}

.rec_left{
    background-color: #f2f2f2;
    border: 1px solid #d3d3d3;
    clear: both;
    display: block;
    font-size: 1.1em;
    margin: auto;
    padding: 10px 5%;
    vertical-align: top;
    width: 90%;
}

.rec_right{
	width: 90%;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	line-height: 2em;
	display: block;
	padding: 20px 5%;
}

.recruit h1 {
font-size: 170%;
    text-indent: 5px;
    width: 100%;
}

.recruit p {
    width: 100%;
}

.recruit_info{
    width: 100%;
}

.recruit_tel {
    font-size: 30px;
}	
	
	
	
	
	/************************************************************/
	/*お問い合わせ*/
	/************************************************************/
	
.inq_box {
    display: block;
    margin: auto;
    width: 100%;
}

.inq_left{
    background-color: #f2f2f2;
    border: 1px solid #d3d3d3;
    clear: both;
    display: block;
    font-size: 1.1em;
    margin: auto;
    padding: 10px 5%;
    vertical-align: top;
    width: 90%;
}

.inq_right{
	width: 90%;
	border: 1px solid #d3d3d3;
	font-size: 1.1em;
	line-height: 2em;
	display: block;
	padding: 20px 5%;
}

.inquiry h1 {
font-size: 140%;
    text-indent: 5px;
    width: 100%;
}

.inquiry p {
    width: 100%;
}
	
	
}