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

/*デバイス共通====================================*/

/*下層ページ共通要素=====================*/
.base-warp{
	width: 90%;
	max-width: 1000px;
	margin: 0               auto;
}

.color_green{
color:#0F2B00 !important;
}

.font_large{
	font-size:   calc((100vw - 320px) / 200 + 25px);
}

.font_middle{
	font-size:   calc((100vw - 320px) / 200 + 18px);
}

.font_small{
	font-size:   calc((100vw - 320px) / 1000 + 16px);
}

p{
	line-height: 1.5;
}

.br_sp_400{
	display: block;
}
@media screen and (min-width:400px)  {
	.br_sp_400{
		display: none;
	}
}

.br_sp_700{
	display: block;
}
@media screen and (min-width:700px)  {
	.br_sp_700{
		display: none;
	}
}


.flex-base{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
@media screen and (min-width:769px)  {
	.flex-base-SB{
		justify-content: space-between;
	}
}

/*横並びのボタン調整*/
.commonBT_flex{
	margin: 20px 0;
}
@media screen and (min-width:769px)  {
	.commonBT_flex{
	width:45%;
}
}

/*下層header--------------------*/
.underlayer_header{
	position: relative;
	top: 75px;
}

.underlayer_header img{
	width: 100%;
	height: calc((100vw - 320px) / 10 + 150px);
	max-height: 370px;
	object-fit: cover;
}

.header__Ttl{
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	color: #9ECDBD;
	font-size: calc((100vw - 320px) / 100 + 50px);
}

.header__Ttl em{
	color: #FFF;
	margin-top: -10px;
}

/*下層footer--------------------*/
.footer__img img{
	width: calc(100%/3);
	height:calc((100vw - 320px) / 10 + 200px);
	max-height:400px;
	object-fit: cover;
}

/*main--------------------*/
.underlayer_main{
	padding: calc((100vw - 320px) / 10 + 100px) 0;
	position: relative;
}

.padding_TB{
	padding: calc((100vw - 320px) / 30 + 80px) 0;
	position: relative;
}

/*各ページ共通要素ここまで=====================*/
/*ご依頼から施工までの流れ--------------------*/
.business__Ttl img{
	width: 50%;
	height: auto;
	max-width: 100vh;
	padding: 0 0 40px 0;
}

.business__Ttl{
	text-align: center;
	padding-bottom: 50px;
}

.business__Ttl h1{
	text-align: center;
	font-weight: bold;
}

.business__Ttl::after{
	content: "";
	display: block;
	border-bottom: solid 2px #AED900;
	width:50px;
	margin: 0 auto;
	position: relative;
	top: 40px;
}

/*---------  フロー  ---------*/
.flow_chart{
padding-bottom: calc((100vw - 320px) / 20 + 50px);
}

.business__list__no{
	font-size: calc((100vw - 320px) / 30 + 70px);	
	position: absolute;
	left: calc((100vw - 320px) / 30 + 10px);
	top: 10px;
	color: rgba(146,209,163,0.5);
	font-weight: bold;
}
.flow_chart_warp,.flow_chart_warp_ferst{
	background: #EBF8E0;
	font-family: 'Noto Sans JP', sans-serif;
	padding:  calc((100vw - 320px) / 50 + 20px);
	max-width: 1000px;
	position: relative;
	margin: 80px auto;
}
.flow_chart_warp::before{
	content: "";
	position:absolute;
	top:-80px;
	left:calc((100vw - 320px) / 50 + 50px);
	border: solid 1px #4BA201;
	height: 80px;
}
.flow_chart_text{
	width: 85%;
	margin: 20px 0 0 auto;
}
.flow_chart_text h2{
	font-weight: bold;
	margin: 0 0 10px 0;
}
.flow_chart_add,.flow_chart_tel{
	border: solid 1px #054C3A;
	padding: 15px;
	width: 100%;
	line-height: 1.5;
	text-align: center;
	font-weight: bold;
	color: #054C3A;
	margin: 10px auto;
}

.flow_chart_add::before{
	content: "aaaa";
	background-image: url("../images/flow/Icon material-mail-outline.png");
background-repeat: no-repeat;
	background-size: 25px;
	color: rgba(255,255,255,0.00);
	position: relative;
	top: 5px;
}

.flow_chart_add:hover{
	background: #D7ECD4;
	transition: 0.5s;
}
.flow_chart_tel:hover{
	background: #D7ECD4;
	transition: 0.5s;
}

.flow_chart_tel{
	padding: 2px;
	position: relative;
}
.flow_chart_tel strong::before{
	content: "aa";
	background-image: url( "../images/flow/Icon_tel.png");
background-repeat: no-repeat;
	background-size: 20px;
	height: 40px;
	color: rgba(255,255,255,0.00);
}
/*フリーダイヤル*/
.flow_chart_tel p{
	font-size: calc((100vw - 320px) / 1000 + 13px);
	display: block;
	position: relative;
	top: 5px;
}
.flow_chart_tel strong::after{
	content: "8:00～18:00";
	font-size: calc((100vw - 320px) / 1000 + 13px);
	display: block;
	position: relative;
	top: -5px;
}
.flow_chart_tel strong{
	font-size: calc((100vw - 320px) / 500 + 20px);
}

/*---------3DCAD------------*/
.CAD_content{
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.5;
	text-align: center;
}

.CAD_content_Ttl h2{
	font-weight: bold;
	padding: 50px 0 30px;
}

.CAD_img_pc{
	display: none;
}

.CAD_img_sp{
	display: inline-block;
	width: 100%;
	height: auto;
	max-width: 350px;
	padding: 50px 0 20px;
}

/*---------3DCAD エクスプラット------------*/
.Xplat_warp{
	padding: calc((100vw - 320px) / 30 + 80px) 0 0 0;
}

.Xplat_Ttl{
	background: rgba(233, 252, 218,0.5);
	position: relative;
	height: 100px;
	font-weight: bold;
	max-width: 1200px;
}

.Xplat_Ttl h1{
	line-height:0.8;
	position: relative;
	top: 15px;
}

.Xplat_Ttl::before{
	content: "";
	border-left:8px solid #097B00;
	width: 20px;
	height: 100px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
}

.Xplat_Ttl span{
	font-size: 16px;
	margin: 0 5px;
	position: relative;
	top:5px;
}

.Xplat_Ttl strong{
	position: relative;
	top: 15px;
}

.Xplat_warp h2{
	color: #4A741F;
	font-weight: bold;
	padding: 80px 0 30px;
}

.Xplat_img_sp{
	width: 100%;
	height: auto;
	max-width: 400px;
	margin: 0 auto 30px;
}

.Xplat_img_pc{
	display: none;
}

.Xplat_plan_Ttl{
  position: relative;
  text-align: center;
  font-weight: bold;
	max-width:800px;
	margin: 0 auto;
	padding: calc((100vw - 320px) / 30 + 80px) 0 20px;
}

.Xplat_plan_Ttl h3{
	margin: 0 50px;
}
 
.Xplat_plan_Ttl::before,
.Xplat_plan_Ttl::after {
  position: absolute;
  display: inline-block;
  content: "";
  background: #062B03;
  width: 2px;
  height: 5em;
  margin: 0 1em;
  margin-top: -.2em;
  vertical-align: middle;
}
 
.Xplat_plan_Ttl::before {
  transform: rotate(-35deg);
	left: 0;
}
 
.Xplat_plan_Ttl::after {
  transform: rotate(35deg);
	right: 0;
	top: calc((100vw - 320px) / 30 + 80px);
}

.Xplat_design_img img{
	width: 100%;
	height: auto;
	margin: 10px;
	object-fit: cover;
	max-width: 320px;
}

.Xplat_link span{
	display: block;
	position: relative;
	font-family: 'Noto Serif JP', sans-serif !important;
	font-weight: bold;
	max-width: 500px;
}

.Xplat_link span::before{
content:"";
	position: absolute;
	left: auto;
	margin-left:-30px;
background-image: url( "../images/flow/Icon map-search.png");
background-repeat: no-repeat;
	background-size: 30%;
	padding: 40px;
}
.Xplat_link span:hover::before{
background-image: url( "../images/flow/Icon map-search_W.png");
}

.Xplat_link span::after{
content:"";
	position: absolute;
	top: 28px;
	right:auto;
background-image: url( "../images/flow/Icon_link.png");
background-repeat: no-repeat;
	background-size: 40%;
	padding: 20px;
}
.Xplat_link span:hover::after{
background-image: url( "../images/flow/Icon_link_W.png");
}
@media screen and (min-width:400px)  {
.Xplat_link  span::after{
	top: 5px;
}
}

.Xplat_link_warp:hover{
	background: #054C3A;
	transition: 0.5s;
}

.Xplat_link_warp a span:hover{
	color: #FFF !important;
	transition: 0.5s;
}

.Xplat_link_warp{
	border: solid 1px #054C3A;
	padding: 15px;
	max-width: 500px;
	margin:80px auto;
}

/*--------------- よくある質問 -----------*/
.cp_qa *, .cp_qa *:after, .cp_qa *:before {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
		font-family: 'Noto Sans JP', sans-serif;
}
.cp_qa {
	
}

.cp_qa .cp_actab {
	position: relative;
	overflow: hidden;
	width: 100%;
	margin-bottom: 15px;
}
.cp_qa .cp_actab input {
	position: absolute;
	opacity: 0;
}
/* 質問 */
.cp_qa .cp_actab label {
	font-weight: bold;
	line-height: 1.6;
	position: relative;
	display: block;
	margin: 0 0 0 0;
	padding: 1em 2em 1em 1em;
	cursor: pointer;
}
.cp_actab-content::before{
	content:"";
		position: absolute;
	background: #F5F8EA;
	height: 100%;
	width: 10px;
}

@media screen and (min-width:400px)  {
.QA_Q p{
	width: 70%;
	position: absolute;
	left: 65px;
	top:15px;
}
}
@media screen and (min-width:700px)  {
.QA_Q p{
	width: 100%;
	top:30px;
}
}

.QA_Q strong {
	width: 60px;
	font-size: calc((100vw - 320px) / 200 + 25px);
	margin: 0 10px;
	color: #0F2B00;
	font-family: 'Noto Serif JP', sans-serif;
}
.QA_A::before {
	content: "A.";
	font-size: calc((100vw - 320px) / 200 + 25px);
	margin: 0 10px;
	color: #0F2B00;
	font-family: 'Noto Serif JP', sans-serif;
	font-weight: bold;
}

.cp_qa .cp_actab label:hover {
	color: #00838F;
}

.cp_actab{
	background: #EBF8E0;
}

.QA_line{
	position: absolute;
	left: 0;
	top: 0;
	background:#097B00;
	height:100vh;
	width: 7px;
}

/* 答え */
.cp_qa .cp_actab .cp_actab-content {
	overflow: hidden;
	max-height: 0;
	-webkit-transition: max-height 0.5s ease;
	        transition: max-height 0.5s ease;
	background: #F5F8EA;
}
.cp_qa .cp_actab .cp_actab-content p {
	margin: 5px 15px 50px 15px;
}

/* 質問を開いた時の仕様 */
/* --アイコン */
.cp_qa .cp_actab input:checked ~ label {
	color: #00838F;
}
/* --答えの高さ */
.cp_qa .cp_actab input:checked ~ .cp_actab-content {
	max-height: 40em;
}
/* 質問をクリックした時のアイコンの動き */
.cp_qa .cp_actab label::after {
	line-height: 1.6;
	position: absolute;
	top: 50%;
	right: 0;
	display: block;
	width: 3em;
	margin-top: -12.5px;
	-webkit-transition: all 0.5s ease;
	        transition: all 0.5s ease;
	text-align: center;
}
.cp_qa .cp_actab input[type=checkbox] + label::after {
	content: '〉';
	transform: rotate(90deg);
}
.cp_qa .cp_actab span input[type=checkbox]:checked + label::after {
	-webkit-transform: rotateX(180deg);
	transform: rotateX(180deg);
}

.cp_actab-content a{
	display: block;
	border: solid 1px #0F2B00;
	color: #0F2B00;
	font-family: 'Noto Serif JP', sans-serif;
	padding: 5px 10px;
	text-align: center;
	width:250px;
	margin:10px 0 0 auto;
}

.cp_actab-content a:hover{
	color: #FFF;
	background: #0F2B00;
	transition: 0.5s;
}

/*---------- contact --------------*/
.flow_contact{
	background: #D7ECD4;
}

.flow_contact_warp{
	background: #FFF;
	padding: 20px 20px 30px 20px;
}

.flow_contact_Ttl,
.flow_contact_Ttl p{
	color: #1E3911;
	text-align: center;
	padding: 10px 0;
	line-height: 1.5;
}

.flow_contact_Ttl p{
	border-bottom: solid 1px #1E3911;
}

.flow_contact_Ttl span{
	background: #054C3A;
	color: #FFF;
	padding: 2px 10px;
	margin: 0 5px;
}

.flow_contact_mailtel{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: bold;
	color: #054C3A;
}

.flow_contact_mailtel a{
	display: block;
	width: 100%;
	font-size: calc((100vw - 320px) / 500 + 17px);
}

.flow_contact_mail::before{
	content: "aaa";
	background-image: url("../images/flow/Icon material-mail-outline.png");
background-repeat: no-repeat;
	background-size: 25px;
	color: rgba(255,255,255,0.00);
	position: relative;
	top: 5px;
}

.flow_contact_mail{
	margin: 5px 0 20px 0;
	padding-bottom: 10px;
	border-bottom: solid 1px #1E3911;
	text-align: center;
}

.flow_contact_tel{
	position: relative;
	text-align: center;
}

.flow_contact_tel p{
	font-size: 16px;
	line-height: 1.3;
}

.flow_contact_tel strong{
	display: block;
}

.flow_contact_tel::before{
	content: "aaa";
	background-image: url( "../images/flow/Icon_tel.png");
background-repeat: no-repeat;
	background-size:25px;
	height: 50px;
	color: rgba(255,255,255,0.00);
	position: absolute;
	left: -30px;
	top: 10px;
}

.flow_contact_tel strong::after{
	white-space: nowrap;
	content: "8:00～18:00";
	margin: 0 5px;
	width: 300px;
	height: 100px;
	font-size: 15px;
}





/*tablet================================================*/
@media screen and (min-width:700px)  {
/**/
	.flow_chart_addtel{
		justify-content: flex-start;
	}	
	
.flow_chart_add,.flow_chart_tel{
	width: calc(95%/2);
	margin-top:20px;
}
	
/*--------- 3DCAD ---------*/
.CAD_img_sp{
	display: none;
}
	
.CAD_img_pc{
	display: block;
	width: 100%;
	height: auto;
	max-width: 1000px;
	padding: 50px 0 20px;
	margin: 0 auto;
}
	
/*--------- エクスプラット ---------*/
	.Xplat_img_sp{
		display: none;
	}
	
	.Xplat_img_pc{
		display: block;
		width: 100%;
		height: auto;
		margin: 0 0 30px 0;
	}
	
.Xplat_design_img img{
	width: calc(90%/4);
}

.Xplat_Ttl span{
	position: relative;
	top:15px;
	left: -10px;
}

.Xplat_Ttl strong{
	position: relative;
	top: 20px;
}

/*--------- contact ---------*/
.flow_contact_mail{
	margin: 5px 50px 0px 0px;
	padding: 10px 30px 30px 10px;
	border-right: solid 1px #1E3911;
	border-bottom: none;
}
	
.flow_contact_mailtel>a,.flow_contact_tel{
	width:50%;
	margin-top: 10px;
}

.flow_contact_tel{
	width:40%;
	position:relative;
	left:5%;
	text-align:left;
	top: 5px;
}

.flow_contact_tel::before{
	left:-30px;
	top: 10px;
}
	
}


/*PC============================================================*/
@media screen and (min-width: 1280px) {
	


}
