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

@media screen and (max-width: 999.999px) {
/* 768pxまでの幅の場合に適応される */
		
	.header_inner{
		width: 100%;
		max-width: 960px;
		height: 150px;
		margin: 0 auto;
		display: flex;
		box-sizing: border-box;
	}
	
	a.logo{
		width: 250px;
		height: 60px;
		margin: 10px 0 0 10px;
	}
		
	a.logo img{
		width: 250px;
		display: block;
		object-fit: cover;
		object-position: center;
	}
	
	a.tel{
		width: 96px;
		margin: 0 0 0 0;
	}
	
	a.tel{
		width: 100px;
		height: 60px;
		position: absolute;
		top: 10px;
		right: 120px;
		color: rgba(255,255,255,0.0);
	}
	
	a.tel::before{
		content: "";
		background-image: url("../images/bshome_tel_mb.png") ;
		width: 100px;
		height: 60px;
		display: block;
		background-size: cover;
		vertical-align: middle;
		border-radius: 5px;
	}
			
	a.contact{
		width: 100px;
		height: 60px;
		margin: 10px;
		background: #48775A;
		display: block;
		line-height: 60px;
		color: #fff;
		font-size: 0.70rem;
		text-align: center;
		border-radius: 5px;
		position: absolute;
		right: 0px;
		padding: 0 0 10px 0;
		
	}
	
	a.contact::after{
		content:"（メーラーが起動します）";
		font-size: 0.5rem;
		display: block;
		margin: -50px 0 0 0;
	}
	
	a.contact img{
		width: 25px;
		margin: 12px auto -18px auto;
		display: block;
	}
	
	.header_inner_top .contact img{
		width: 30px;
		display: block;
		margin: 10px auto -20px auto;
	}
	
	header nav{
		width: calc(100% - 20px);
		position: absolute;
		top: 90px;
		left: 10px;
		z-index: 200;
	}
	
	header nav ul{
		width: 100%;
		display: flex;
	}
	
	header nav ul li {
		width: 25%;
		height: 40px;
		line-height: 40px;
		text-align: center;
		box-sizing: border-box;
		border-right: 1px solid #B3B3B3;	
	}
	
	header nav ul li:last-child{	
		border-right:none;
	}
	
	header nav ul li a{
		width: 100%;
		height: 40px;
		display: block;
		transition-duration: 0.25s;
	}
	
	.mv_img{
		width: 100%;
	}
	
	.mv_catch{
		width: 100%;
		max-width: 748px;
		margin: 0 auto;
		position: relative;
	}
	
	.mv_catch::before{
		width: 100%;
		max-width: 748px;
		height: 300px;
		content: "";
		margin: 0 auto;
		background-image: url("../images/bshome_img_mvtx01_pc.svg");
		background-position: top;
		background-size:contain;
		background-repeat: no-repeat;
		display: block;
		position: absolute;
		top: 30px;
	}
	
	.mv{
		width: 100%;
		height: 630px;
		background-image: url("../images/bshome_img_mv_pc.png");
		background-position: bottom;
		background-size:cover;
		background-repeat: no-repeat;
		
	}
		
	.mv_text{
		width: calc(100% - 20px);
		max-width: 760px;
		position: relative;
		top: -160px;
		margin: 0 auto -130px auto;
		text-align: center;
		padding: 30px;
		background: rgba(255,255,255,0.90);
		box-shadow: 5px 5px 5px rgba(0,0,0,0.05);
	}
	
	.mv_text h2{
		font-size: clamp(1.8rem, 2.00vw, 2.4rem);
		line-height: 2.5rem;
		margin: 0 0 10px 0;
		letter-spacing: -2px;
		color:#48775A;
		font-weight: 800;
	}
	
	.mv_text p{
		font-size: 1.25rem;
	}
	
	.mv_text p span{
		display: block;
	}
	
	.content_title_01,.content_title_02,.content_title_03{
		width: 100%;
		overflow: hidden;
		margin-bottom: 30px;
	}
	
	.content_title_01 .content_title_inner{
		width: 100%;
		height: 150px;
		margin: 0px auto 0px auto;
		z-index: 1;
		background-image: url("../images/bshome_img_chapter_title_01.jpg");
		background-repeat:no-repeat; /*背景画像の繰り返しを解除*/
		background-size:cover;
		background-position:center;		
	}
	
	.content_title_02 .content_title_inner{
		width: 100%;
		height: 150px;
		margin: 0px auto 0px auto;
		z-index: 1;
		background-image: url("../images/bshome_img_chapter_title_02.jpg");
		background-repeat:no-repeat; /*背景画像の繰り返しを解除*/
		background-size:cover;
		background-position:center;		
	}
	
	.content_title_03 .content_title_inner{
		width: 100%;
		height: 150px;
		margin: 0px auto 0px auto;
		z-index: 1;
		background-image: url("../images/bshome_img_chapter_title_03.jpg");
		background-repeat:no-repeat; /*背景画像の繰り返しを解除*/
		background-size:cover;
		background-position:center;		
	}
		
	.content_title_01 .content_title_inner h3,.content_title_02 .content_title_inner h3,.content_title_03 .content_title_inner h3{
		width: 90%;
		margin: 0px auto;
		display: block;
		text-align: center;
		font-size: 2.0rem;
		position: relative;
		top: 0;
		color: #fff;
	}
	
	.content_title_01 .content_title_inner h3 img.chapter_title{
		width: 100%;
		max-width: 440px;
		margin: 0 auto -105px auto;
		display: block;
		position: relative;
		top: 10px;
	}
	
	.content_title_02 .content_title_inner h3 img.chapter_title{
		width: 90%;
		max-width: 620px;
		height: auto;
		display: block;
		margin: 0 auto -55px auto;
		padding-top: 30px;
	}
	
	.content_title_03 .content_title_inner h3 img.chapter_title{
		width: 90%;
		max-width: 500px;
		height: auto;
		display: block;
		margin: 0 auto -45px auto;
		padding-top: 20px;
	}	
	
	.service_01,.service_02,.service_03{
		width: 100%;
		max-width: 1200px;
		margin: 0 auto 20px auto;
	}
	
	.service_01 img,.service_03 img{
		width: calc(100% - 30px);
		margin: 0 0 20px 0;
	}
	
	.service_02 img{
		width: calc(100% - 30px);
		margin: 0 0 20px 30px;
	}
		
	.service_01 .service_tx_01,.service_03 .service_tx_03{
		width: calc(100% - 60px);
		display: block;
		margin: 0 auto;
		z-index: 25;
		box-sizing: border-box;
	}
	
	.service_02 .service_tx_02{
		width: calc(100% - 60px);
		display: block;
		margin: 0 auto;
		z-index: 25;
		box-sizing: border-box;
	}
	
	.service_01 h4,.service_02 h4,.service_03 h4{
		font-size:2.4rem;
		color: #48775A;
		margin: 0 0 10px 0;
	}
	
	.service_01 p,.service_02 p,.service_03 p{
		font-size: 1.4rem;
	}
	
	.service_03 p.bg_yellow{
		background: rgba(244,220,135,0.5);
		font-size: 1.8rem;
		border-radius: 500px;
		text-align: center;
		padding: 30px 40px;
		margin: 0px 0 20px 0;
		line-height: 2.4rem;
	}
	
	.company_inner{
		width: calc(100% - 60px);
		max-width: 960px;
		margin: 30px auto 10px auto;
		box-sizing: border-box;
		padding: 30px;
		background: #EBEFF4;
	}
	
	.company_left{
		width: 100%;
	}
	
	.company_left h5{
		color: #214582;
		font-size: 2.1rem;
		font-weight: 700;
		text-align: center;
		border-bottom: 3px solid #214582;
		margin: 20px 0 20px 0;	
	}
	
	.company_left p{
		font-size: 1.5rem;
		text-align: justify;
	}
	
	.company_right{
		width: 100%;
		margin: 20px 0 0 0;
	}
	
	.company_right img{
		width: 100%;
	}
	
	.content_04{
		width: 100%;
	}
	
	table,tbody,tr,td,th {
    width: 100%;    /* 幅を100%にする */
    display: block; /* ブロック要素にする */
  }
	
	.content_04 table{
		width: calc(100% - 60px);
		margin: 0 auto 50px auto;
	}
	
	.content_04 table tbody tr th,.content_04 table tbody tr td{
		text-align: center;
		padding: 20px 0;
		font-size: 1.4rem;
		box-sizing: border-box;
		border-top: solid 1px #E6E6E6;
	}
	
	.content_04 table tbody tr th{
		width: 100%;
	}
	
	.content_04 table tbody tr td{
		width: 100%;
	}
	
	.content_04 table tbody tr td.end_border{
		width: 100%;
		border-bottom:solid 1px #E6E6E6;
	}
	
	.content_04 table tbody tr th.col_01{
		background-color: #EEF3F0;
	}
	
	.content_04 table tbody tr th.col_02{
		background-color: #F7F9F8;
	}
	
	
.contact_h{
	width: calc(100% - 40px);
	margin: 0 auto;
	padding:40px 0 10px 0;
	font-size:1.6rem;
	text-align:center;
	font-weight:500;
	color:#508363;
	border-bottom:3px solid #508363;
}

.mailform{
	width: calc(100% - 40px);
	max-width: 900px;
	margin: 20px auto 20px auto;
	display: block;
	background: #F3F5F3;
	border-radius: 25px;
}

.mailform form{
	width: 100%;
	padding: 20px;
	margin: 0 auto;
}

.mailform form label{
	width: 100%;
	display: block;
	font-size: 1.2rem;
	margin: 0 0 5px 0;
}

.hissu{
	width: 60px;
	margin: 0 0 0 10px;
	font-size: 1.0rem;
	color: #fff;
	background-color: #F90401;
	padding: 3px 5px;
	border-radius: 5px;
	line-height: 1.0rem;
}

.setsumei{
	margin: 0 0 0 10px;
	font-size: 0.75rem;
	line-height: 0.5rem;
	color: #999;
}

.mailform form input,.mailform form textarea{
	display: block;
	border: 1px solid #ccc;
	padding: 0 0 20px 0;
}

.mailform form input{
	width: 80%;
	height: 35px;
	margin-bottom: 20px;
	display: block;
	font-size:1.0rem;
	padding: 5px;
	color: #bbb;
	border: 1px solid #ccc;
	background-color: #FFF;
}

.mailform form textarea{
	width: 100%;
	height: 400px;
	margin-bottom: 20px;
	background-color: #FFF;
	font-size:1.0rem;
	padding: 5px;
	color: #bbb;
}

.mailform form input:last-child{
	width: 100%;
	height: 80px;
	font-size: 1.6rem;
	font-weight: 600;
	color: #fff;
	background-color: #508363;
	text-align: center;
	line-height: 80px;
	border: none;
	border-radius: 15px;
}

.thankyou_tx{
	width: calc(100% - 80px);
	padding: 30px 0 70px 0;
	margin: 0 auto;
	font-size: 1.2rem;
	line-height: 2.1rem;
	text-align: center;
}
	

}

@media screen and (max-width: 767.999px) {
/* 768pxまでの幅の場合に適応される */
	
	.mv_catch{
		width: 100%;
		max-width: 440px;
		margin: 0 auto;
		position: relative;
	}
	
	.mv_catch::before{
		width: 100%;
		max-width: 480px;
		height: 250px;
		content: "";
		margin: 0 auto;
		background-image: url("../images/bshome_img_mv_mb.svg");
		background-position: top;
		background-size:contain;
		background-repeat: no-repeat;
		display: block;
		position: absolute;
		top: 30px;
	}
	
	.mv_text p{
		font-size: 1.15rem;
	}
	
	.content_title_01,.content_title_02,.content_title_03{
		width: 100%;
		overflow: hidden;
		margin-bottom: 20px;
	}
	
	.content_title_01 .content_title_inner h3,.content_title_02 .content_title_inner h3,.content_title_03 .content_title_inner h3{
		width: 90%;
		margin: 0px auto;
		display: block;
		text-align: center;
		font-size: 2.0rem;
		position: relative;
		top: 0;
		color: #fff;
	}
	
	.content_title_01 .content_title_inner h3 img.chapter_title{
		width: 100%;
		max-width: 320px;
		margin: 0 auto -70px auto;
		display: block;
		position: relative;
		top: 25px;
	}
	
	.content_title_02 .content_title_inner h3 img.chapter_title{
		width: 90%;
		max-width: 480px;
		height: auto;
		display: block;
		margin: 0 auto -35px auto;
		position: relative;
		top: 10px;
	}
	
	.content_title_03 .content_title_inner h3 img.chapter_title{
		width: 90%;
		max-width: 400px;
		height: auto;
		display: block;
		margin: 0 auto -33px auto;
		position: relative;
		top: 10px;
	}	
	
	.service_03 p.bg_yellow{
		background: rgba(244,220,135,0.5);
		font-size: 1.4rem;
		border-radius: 500px;
		text-align: center;
		padding: 20px 40px;
		margin: 0px 0 20px 0;
		line-height: 1.6rem;
	}
	
	.service_03 p.bg_yellow span{
		display: block;
		margin-bottom: -25px;
		line-height: 2.4rem;
	}
	
	.content_04 table tbody tr th,.content_04 table tbody tr td{
		text-align: center;
		padding: 20px 0;
		font-size: 1.25rem;
		box-sizing: border-box;
		border-top: solid 1px #E6E6E6;
	}
	
}

@media screen and (max-width: 640px) {
/* 768pxまでの幅の場合に適応される */
		
	.mv_text h2{
		font-size: 1.50rem;
		line-height: 2.5rem;
		margin: 0 0 30px 0;
		letter-spacing: -2px;
		color:#48775A;
		font-weight: 800;
	}
	
}

@media screen and (max-width: 500px) {
/* 768pxまでの幅の場合に適応される */
	
	a.logo{
		width: 60px;
		height: 80px;
		margin: 5px 0 0 10px;
	}
	
	a.logo img{
		height: 80px;
		margin: 0px 0 0 10px;
		opacity: 1.0;
		object-fit: cover;
		object-position: left;
	}
	
	header nav ul li {
		font-size: 0.90rem;
		
	}
		
	.mv_catch::before{
		width: calc(100% - 40px);
		height: *;
		max-height: 250px;
		content: "";
		margin: 0 auto;
		background-image: url("../images/bshome_img_mv_mb.svg");
		background-position: top;
		background-size:contain;
		background-repeat: no-repeat;
		display: block;
		position: absolute;
		top: 30px;
		left: 20px;
	}
	
	.mv_text{
		padding: 20px;
	}
	
	.mv_text h2 span{
		display: block;
		margin: 0 0 -30px 0;
	}
	
	.mv_text h2{
		font-size: clamp(1.6rem, 2.00vw, 2.0rem);
		line-height: 2.5rem;
		margin: 0 0 60px 0;
		letter-spacing: -2px;
		color:#48775A;
		font-weight: 800;
	}
	
	.mv_text p{
		text-align: left;
	}
	
	.mv_text p span{
		display: inline;
	}
	
	.service_01 h4,.service_02 h4,.service_03 h4{
		font-size:2.1rem;
		color: #48775A;
		margin: 0 0 10px 0;
	}
	
	.company_left h5{
		color: #214582;
		font-size: 6vw;
		font-weight: 700;
		text-align: center;
		border-bottom: 3px solid #214582;
		padding: 0 0 10px 0;
		margin: 20px 0 20px 0;	
	}
	
	.service_01 img,.service_03 img{
		width: calc(100% - 10px);
		margin: 0 0 10px 0;
	}
	
	.service_02 img{
		width: calc(100% - 10px);
		margin: 0 0 10px 10px;
	}
	
	.service_01 .service_tx_01,.service_03 .service_tx_03{
		width: calc(100% - 20px);
		display: block;
		margin: 0 auto;
		z-index: 25;
		box-sizing: border-box;
	}
	
	.service_02 .service_tx_02{
		width: calc(100% - 20px);
		display: block;
		margin: 0 auto;
		z-index: 25;
		box-sizing: border-box;
	}
		
	
	.service_01 p,.service_02 p,.service_03 p{
		font-size: 1.20rem;
		line-height: 1.8rem;
	}
	
	.service_03 p.bg_yellow{
		font-size: 1.3rem;
		line-height: 1.4rem;
	}
	
	.service_03 p.bg_yellow span{
		display: block;
		margin-bottom: -25px;
		line-height: 2.4rem;
	}
	
	.company_inner{
		width: calc(100% - 20px);
		max-width: 960px;
		margin: 30px auto 10px auto;
		box-sizing: border-box;
		padding: 20px;
		background: #EBEFF4;
	}
	
	.company_left p{
		font-size: 1.20rem;
		line-height: 1.8rem;
		text-align: justify;
	}
	
	.content_04 table{
		width: calc(100% - 20px);
		margin: 0 auto 50px auto;
	}
	
}