@charset "UTF-8";
/* CSS Document */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;	
}
body{
width: 100%;    
font-family: klee-one,sans-serif;
font-weight: 400;
font-style: normal;
}
@media all and (-ms-high-contrast: none) {
  h1,h2, h3, h4, h5,h6,p,li,dd,dt,dl,button[type="submit"] {font-family: "メイリオ", Meiryo, sans-serif; }
	.kv_sl,.kv_sl1,.kv_sl2,.kv_sl3,.kv_sl4{margin-top: -1%;
	}}

.contener{
	max-width: 1250px;
	margin: 0 auto;
	width: 100%;
}
.contener2{
	max-width: 1170px;
	margin: 0 auto;
	width: 100%;
	padding: 0 ;
}
.contener1{
	margin: 0 auto;
	width: 100%;
	padding:0 1%;
}


h1,h2,h3,h4,h5,h6{
	margin: 0;
}
a{
	text-decoration: none;		
}
li{
	list-style: none;
}
.fullscreenmenu{
	display: none;
}
/*===スライダー==============================*/
.top_slider{
    width: 100%;
    height: calc(100vh - 150px);
}
.top_slider{
	overflow: hidden;
    width: 100%;
}
.top_slider1{
	width: 100%;
    height: 450px;
    overflow: hidden;
    position: relative;
    background: url("../img/top4.jpg");
    background-size: cover;
    background-position: center;
}
.top_slider1 p{
    position: absolute;
    top: 45%;
    width: 100%;
    text-align: center;
    color: #034001;
     text-shadow    : 
       1px  1px 1px #ffffff,
      -1px  1px 1px #ffffff,
       1px -1px 1px #ffffff,
      -1px -1px 1px #ffffff,
       1px  0px 1px #ffffff,
       0px  1px 1px #ffffff,
      -1px  0px 1px #ffffff,
       0px -1px 1px #ffffff; 
    font-size: 2em;
}
.top_slider1 small{
display: block;
    color: #CB0B09;
    font-size: 0.7em;
    padding: 1% 0;
    text-align: center;
}

.top_slider .slider li{
	width: 100%;
	height: auto;
	position: relative;
    overflow: hidden;
}

.top_slider .slider li .slide_img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.07);
}
.top_slider .slick-active .slide_img{
	position: relative;
	animation: zoom 8s ease-in-out 0s forwards;
}
@keyframes zoom {
  0% {
		transform: scale(1);
	}
  100% {
		transform: scale(1.07);
	}
}
/*パンクズ */
.breadcrumb {
  margin-bottom: 5%;
margin-top: 2%;	
  padding-left: 1%;
  list-style: none;
}

.breadcrumb li {
  display: inline;/*横に並ぶように*/
  list-style: none;
  font-weight: bold;/*太字*/
}

.breadcrumb li:after {/* >を表示*/
  content: '>';
  padding: 0 0.2em;
  color: #333;
}

.breadcrumb li:last-child:after {
  content: '';
}

.breadcrumb li a {
  text-decoration: none;
  color: #333;/*色*/
}

.breadcrumb li a:hover {
  text-decoration: underline;
}

/*キャッチ*/
.top_slider li .catch{
position: absolute;
  top: calc(100vh / 2.5);
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 35%;
  text-align: center;  
}
.top_slider li .catch img{
	display: block;
	width: 100%;
}
@keyframes apper {
	0% {
		opacity: 0;
	}
	50%{
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@media (max-width: 750px){

}



#wrap{
	width: 100%;
    height: auto;
    display: flex;
    flex-wrap:wrap;
justify-content:space-between;
align-items:center
}

.wrap{
width: 100%;
height: auto;
display:block;  
padding: 1% 0;     
}
.h5{
height: 5px;    
}
.h10{
height: 10px;    
}
.h15{
height: 15px;    
}
.h20{
height: 20px;    
}
.h30{
height: 30px;    
}
.h40{
height: 40px;    
}
.h50{
height: 50px;    
}
.h100{
height: 100px;    
}


.m1 h2{
	color: #fff;
	margin:0;
	padding: 0.5% 0;
	margin-top: 3%;
}
.sp{
display: none;
}

.midashi{
width: 100%;
height: auto;    
display: block;
margin: 2% 0;    
}
.midashi p{
font-size: 2.5em; 
font-weight: bold;
font-family: klee-one,sans-serif;
font-weight: 600;
line-height: 1.5;    
text-align: center;    
}
.midashi .small{
   font-size: 0.7em;  
    display: block;
    color: #157307;
}
.midashi .border_bottom{
 border-bottom: solid 3px #fff600;;
}
.text1{
font-size: 1.3em;  
line-height: 220%; 
text-align: center;
}
.text1 strong{
font-size: 1.3em;  
}
.text2{
font-size: 2em; 
letter-spacing: 3px;  
border-bottom: 2px solid #157307;
padding-bottom: 1%;    
}
.text2 strong{
font-size: 1.5em;  
color: #4ABF2A;
}
.text3{
font-size: 1em; 
letter-spacing: 3px;  
}
.text3 strong{
font-size: 2em;  
color: #157307;
text-align: center!important;
display: block;    
}
.text4{
font-size: 1.2em; 
letter-spacing: 3px;  
padding-bottom: 1%;       
}
.text4 strong{
font-size: 1.5em;  
}

.heading{
width: 98%;    
  position: relative;
  padding: 1.5rem 1rem;
font-size: 1.8em;
color: #157307;   
padding: 2% 1%;  
display: block;
margin: 0 auto ;
}

.heading:after {
  position: absolute;
  bottom: 1%;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #157307, #157307 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #157307, #157307 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
    
}
.text-shadow_w{
 text-shadow    : 
       1px  1px 1px #ffffff,
      -1px  1px 1px #ffffff,
       1px -1px 1px #ffffff,
      -1px -1px 1px #ffffff,
       1px  0px 1px #ffffff,
       0px  1px 1px #ffffff,
      -1px  0px 1px #ffffff,
       0px -1px 1px #ffffff;  
    }
.text-shadow_b{
 text-shadow    : 
       1px  1px 1px #000,
      -1px  1px 1px #000,
       1px -1px 1px #000,
      -1px -1px 1px #000,
       1px  0px 1px #000,
       0px  1px 1px #000,
      -1px  0px 1px #000,
       0px -1px 1px #000;  
    }
.line_h200{
line-height: 200%;    
}
.line_h15{
line-height: 1.5;    
}
.red{
color: #F0001D;      
}
.blue{
font-weight: bold;
color: #050060!important;    
}
.white{
color: #fff;    
}
.center{
text-align: center;
}
.red_border{
border-bottom: #2c3eb5 10px solid;  
display: inline-block;
padding-top: 20px;    
}
.blue_border{
border-bottom: #F0001D 10px solid;  
display: inline-block;
padding-top: 20px;     
}
.border-left{
 margin-right: 0.5%; 
}
.border-left:before{
	content: '';
	display: inline-block;
	width: 5px;
	height:0.5em;
	background: linear-gradient(to bottom, #CB0B09 0%,#CB0B09 50%, #050060 50%,#050060 100%);
     margin-bottom: 3px;  
}
.border-left:after{
	content: '';
	display: inline-block;
	width: 5px;
	height: 0.5em;
	background: linear-gradient(to bottom, #050060 0%,#050060 50%, #CB0B09  50%,#CB0B09  100%);
     margin-bottom: 3px;   
}
.back1{
background: rgba(170,242,119,0.1);    
}
.back2{
width: 100%;    
background:url("../img/background2.png");  
background-size: cover;
background-position: center;
background-repeat: no-repeat;    
padding: 5% 7%;    
}
/*===========ボタン============-*/
.btn,
a.btn,
button.btn {
  font-size: 1em;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1% 0;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
        display: block;
    margin: 0 auto;
    width: 30%;
    box-shadow: 2px 2px 5px #eee;
}

.btn-box a.btn-flat {
  overflow: hidden;
  padding: 1.5rem 6rem;
  color: #fff;
  border-radius: 0;
  background: #4ABF2A;
}

.btn-box a.btn-flat span {
  position: relative;
}

.btn-box a.btn-flat:before {
  position: absolute;
  top: 0;
  left: 30px;
  width: 150%;
  height: 500%;
  content: '';
  -webkit-transition: all .5s ease-in-out;
  transition: all .5s ease-in-out;
  -webkit-transform: translateX(-90%) translateY(-70%) rotate(135deg);
  transform: translateX(-90%) translateY(-70%) rotate(135deg);
  background: #ffde00;
}

.btn-box a.btn-flat:hover:before {
  -webkit-transform: translateX(-9%) translateY(-25%) rotate(135deg);
  transform: translateX(-9%) translateY(-25%) rotate(135deg);
}
.btn-box a:hover{
 color: #000;  
 letter-spacing: 0.3em;    
}

.btn-box1{
width: calc(95% / 3);  
display: block;
margin: 0 auto;
}

.btn-box1 a.btn-flat {
  overflow: hidden;
  padding: 1rem 1rem;
  color: #fff;
  border-radius: 0;
  background: #4ABF2A;
width: 100%;    
}

.btn-box1 a.btn-flat span {
  position: relative;
}

.btn-box1 a.btn-flat:before {
  position: absolute;
  top: 0;
  left: 30px;
  width: 150%;
  height: 500%;
  content: '';
  -webkit-transition: all .5s ease-in-out;
  transition: all .5s ease-in-out;
  -webkit-transform: translateX(-90%) translateY(-70%) rotate(135deg);
  transform: translateX(-90%) translateY(-70%) rotate(135deg);
  background: #ffde00;
}

.btn-box1 a.btn-flat:hover:before {
  -webkit-transform: translateX(-9%) translateY(-25%) rotate(135deg);
  transform: translateX(-9%) translateY(-25%) rotate(135deg);
}
.btn-box1 a:hover{
 color: #000;  
 letter-spacing: 0.3em;    
}

/*===========ヘッダー============-*/
#logo{
	width: 500px;
}
#logo img{
	width: 90%;
}
.top_contact{
   widows: 65%;
    display: flex;
    flex-wrap:wrap;
justify-content:flex-end;
align-items:center;
}
.t-tel{
	width:300px ;
    padding: 2%; 
    border-radius: 30px;
    top:40px;
    z-index: 999;
}
.t-tel a{
width: 100%;    
color: #4ABF2A;
font-size: 1.8em;    
transition: all 0.5s;	
display: block;   
text-align: center;   
font-family: klee-one,sans-serif;
font-weight: 600;
font-style: normal;    
}
 .t-tel a:hover{
text-decoration: transparent;  
color: #AAF277;
}
 .t-tel .small{
display: block;
color:#333;
font-size: 0.5em;
}
.t-mail{
	width:180px ;
}
.t-mail a{
    width: 100%;
    border-radius: 50px;
    z-index: 999;
    background: #ffde00;
    color: #fff;
    text-align: center;
    font-size: 1em;
    display: block;
    padding:10% 1%; 
    color: #fff;
    transition: all 0.5s;	
    border: 2px solid #ffde00;
    font-family: klee-one,sans-serif;
font-weight: 600;
font-style: normal;
}
.t-mail a:hover{
    background: #fff;
    text-decoration: transparent;
    color: #ffde00;
}
/*===========グローバルナビ===========*/

.glovalnavi{
	width: 100%;
   height: auto;
	display: inline-block;
    background: rgba(255,255,255,0.5);
}

.glovalnavi ul{
width: 100%;		
display: flex;
align-items:center;	
padding: 0;	
text-align: center;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
border-left: 1px solid #ccc;
margin: 10px 0;    
}


.glovalnavi ul li{
font-size: 0.9em;	
    position: relative;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
    text-align: center;
    position: relative;
    border-right: 1px solid #ccc;
    padding:3px 12px;
	font-weight: bold;
    font-family: klee-one,sans-serif;
font-weight: 600;
font-style: normal;
	
}


.glovalnavi ul li a {
    display: block;
    position: relative;
    line-height: 1.6;
    font-size: 1.3em;
    font-weight: 500;
    color:#034001;
    text-align: center;
	transition: all 0.9s;
}
.glovalnavi ul li a:after {
    content: "";
    position: absolute;
    bottom: -5px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    width: 0;
    height: 2px;
    background:#fff600;
    -webkit-transition: 0.2s width ease-in;
    transition: 0.2s width ease-in;
    z-index:-2;
	margin: 2% 0;
}


.glovalnavi ul li a img {
    display: block;
    width: 80px;
    text-align: center;
    margin:0 auto 3px
}
.glovalnavi ul li a:hover {
    -webkit-transform: translateY(-10px);
    transform:translateY(-10px);
	transition: all 0.9s;	
}

.glovalnavi ul li a:hover, #header_nav ul li a.active {
    -webkit-transition: 0.2s all ease-in;
    transition:0.2s all ease-in;
	transition: all 0.9s;
}

.glovalnavi ul li a:hover:after, .glovalnavi ul li a.active:after {
    width:30px;
	text-decoration: transparent;	
}

/*===========あいさつ===========*/
.greetings-box{
width: 95%;
margin: 0 auto;    
height: auto;   
padding: 5%;
border-radius: 20px;  
position: relative;

}
.greetings{
width: 100%;
height: auto;
display: block;
position: relative;
}
.flex-box{
width: 100%;
display: flex;   
flex-wrap:wrap;
justify-content:space-between;
align-items:center;    
}
.flex-box2{
width: 100%;
display: flex;   
flex-wrap:wrap;
justify-content:space-between;
align-items:flex-start;    
}
.flex-box3{
width: 100%;
display: flex;   
flex-wrap:wrap;
justify-content:flex-start;
align-items:flex-start;    
}
.greeting_photo{
width:calc(90% / 3);
}
.greeting_photo img{
width: 100%;
border-radius: 50%;    
}

/*===========コンテンツ===========*/
.contents-box{
width: 95%;
margin: 0 auto; 
height: auto;
display:block;

}
.contents{
width: 100%;
display: flex;
flex-wrap:wrap;
justify-content:space-around;
align-items:center;    
}

.contents-photo{
width:calc(95% / 3);  
position: relative;  
background: #000;   
overflow: hidden;
}
.contents-photo img{
width: 100%;       
transition: 0.5s; 
 background: inherit;  
}
.contents-photo a{
width: 100%;        
transition: all 0.4s;	      
text-decoration: transparent;    
display: block;   
opacity: 1;     
margin-bottom: -2%;    
background: rgba(0,0,0,0.7);    
}
.contents-photo a:hover{  
opacity: 0.7;         
transform: scale(1.1, 1.1);    
text-decoration: transparent;    
}
.contents_text{   
position: absolute;
font-size: 1.3em;
color: #fff;  
padding: 5%;
top:25%;  
width: 100%;
text-align: left; 
display: block;    
z-index: 10;   
text-shadow:2px 2px 5px #000;        
}
.contents_text strong{
font-size: 1.5em;    
display: block;
text-align: center;     
}
.lnk{
width: 90%;
color: #fff; 
display: block;
margin: 0 auto;
text-align: center;    
  text-shadow:2px 2px 5px #000;    
}
/*===========選ばれる理由===========*/
.choice-box{
width: 100%;
height: auto;
display: block;
background: #54c541; 
margin-top: -50px;     
}
.choice{
width:calc(90% / 2);  
position: relative;
margin: 5% 0 0;    
}
.choice img{
width:100%;
border-radius: 20px;    
box-shadow: 2px 2px 5px #333;   
border: solid 5px #157307;
}
.choice-text1{
position: absolute;
top:-45px;
left: 0;    
font-size: 3em;
color: rgba(255,255,255,0.9); 
text-shadow: 2px 2px 10px #000;    
font-weight: bold;    
}
.choice-text1 strong{ 
font-size: 1.5em;
vertical-align:inherit;     
}
.choice-text2{
position: absolute;    
font-size: 2em;
bottom:-10px;
right: 0;  
color: #034001;
 text-shadow    : 
       1px  1px 1px #ffffff,
      -1px  1px 1px #ffffff,
       1px -1px 1px #ffffff,
      -1px -1px 1px #ffffff,
       1px  0px 1px #ffffff,
       0px  1px 1px #ffffff,
      -1px  0px 1px #ffffff,
       0px -1px 1px #ffffff;   
background: #034001;  
padding: 1%;    
}
/*===========TOP求人情報===========*/
.top-recruit{
width: 100%;
height: auto;
display: block;    
position: relative;
}
.top-recruit img{
width: 100%;
}
.top-recruit a{
width: 100%;
display: block;    
}
.recruit-text1{
font-size: 1.5em;  
color: #fff; 
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 100%;
  text-align: center;  
 text-shadow: 2px 2px 5px #000;   
line-height: 1.75;  
background: rgba(21,115,7,0.8);  
padding: 5%;    
    
}
.recruit-text1 strong{
font-size: 2em;  
color: #fff; 
display: block;    
}
/*===========スライダー===========*/
.multiple{
width: 90% ;
display: block;
margin: 3% auto;
background: #fff; 

}
.multiple div{
width:100%;
position: relative;    
}
.multiple div p{
font-size: 1em; 
    
}
.multiple img{
width: 90% ;  
display: block;
margin: 5% auto; 
padding: 1%;
}
.multiple .karu-seru::after{
  content: '';
  position: absolute;
  left:0;
  top: 0;
 
  /*四角形を傾けます*/
  transform: skewY(-5deg);
  transform-origin: top right;
  display: block;
  z-index: -1;
  width:90%;
  height:85%;
  background:url("../img/backcolor.png");
background-repeat: no-repeat;
margin-left: 5%;
}
/*===========ニュース===========*/
.news-box{
width: 95%;
margin: 0 auto; 
height: auto;	
display: block;
}
.news{
width: 100%;	  
}


/* clearfix */
.clearfix:after { content:"."; display:block; clear:both; height:0; visibility:hidden; }
.clearfix { display:inline-block; }

/* for macIE \*/
.clearfix { height:1%; }
.clearfix { display:block; }
#newsWrap ul#newsList{/*211029〜*/
	width: 100%;
    height: 200px;
	margin: 0 auto;
	overflow-y: scroll;
	padding: 0 5px;
}

.news ul#newsList{
	padding:5%!important;
	background: rgba(170,242,119,0.05);	
    box-shadow: 2px 2px 5px #eee;
   
}
.news ul#newsList li{
	color:#666;
	font-size:1em;
	margin:0;
	padding:1% 0 3%;
	margin-bottom:3px;
	line-height:200%;
	list-style-type:none;
    text-align:left;
      padding:3% 0 ;
}
.news ul#newsList a{color:#034001;text-decoration:underline;}
.news ul#newsList a:hover{color:#4ABF2A;text-decoration:none;}

.catName{
	display:inline-block;
	padding:3px 8px;
	border:1px solid #f46a42;
	border-radius:6px;
	font-size:1.1em;
	line-height:100%;
	margin:0 2px;
	background:#f46a42;
	color: #fff;
}
	
.newMark{
	display:inline-block;
	border:1px solid #fff600;
	padding:1px 4px;
	font-size:1.1em;
	line-height:100%;
	background:#fff600;
	color:#034001;
	border-radius:8px;
	font-style:italic;
}
.comment{
	display:block;
	padding:3px 0;
	float:left;
	overflow:hidden;
	width:100%;/* 本文部分の幅。ここは特に設置ページ合わせて変更下さい */
}
.thumbNailWrap{
	display:block;
	width:100%;
	float:left;
	height:auto;
	overflow:hidden;
}
/* Pager style（外部化可） */
.pager{
	text-align:right;
	padding:10px;
	clear:both;
}
/*ページャーボタン*/
.pager a{
    border: 1px solid #999;
    border-radius: 5px 5px 5px 5px;
    color: #333;
    font-size: 12px;
    padding: 3px 7px 2px;
    text-decoration: none;
	margin:0 1px;
}

/*現在のページのボタン*/
.pager a.current{
    background: #999;
    border: 1px solid #999;
    border-radius: 5px 5px 5px 5px;
    color: #fff;
    font-size: 12px;
    padding: 3px 7px 2px;
	margin:0 1px;
    text-decoration: none;
}

.pager a:hover{
    background:#999;
    color: #fff;
}

.overPagerPattern{
	padding:0 2px ;	
}
/*===========業務内容===========*/
.business-wrapper{
width: 100%;
height: auto;
display: inline-block;
padding: 3% 0 10%;	
}
.business-wrapper h4{
font-size: 1.3em;
text-align: center;	
color: #F00C23;
padding: 2% 0;	
}

.business-wrapper .renovation{
font-size: 1em;
text-align: left;	
line-height: 1.75;	
}

.business-wrapper .border_red{
font-size: 1.3em;
text-align: center;	
color: #F00C23;
padding: 3% 0;
border-bottom: solid 2px #F00C23;	
}
.business-wrapper .timing{
font-size: 1em;
text-align: center;
line-height: 1.75;		
}

.business-wrapper .business{
width: 100%;
display: flex;
flex-wrap:wrap;
justify-content:center;
align-items:flex-end;	
padding: 2%;
}
.business-wrapper .business .p-contact{
width: 100%;
display: flex;
flex-wrap:wrap;
justify-content:space-around;
align-items:center;	
}
.business-wrapper .business .p-contact .botann {
width: 30%;	
background: #F00C23;
margin: 2% 0;
text-align: center;
border-radius: 50px;
transition: color .3s, text-decoration .3s;	
box-shadow: 2px 2px 5px #333;	
}
.business-wrapper .business .p-contact .botann :hover{	
background: #A31826;
text-decoration: transparent;	
border-radius: 50px;	
}
.business-wrapper .business .p-contact .botann a{
color: #fff;
font-size: 1em;
line-height: 1.75;	
display: block;	
padding: 1%;	
}
.business-wrapper .business .p-text{
line-height: 1.75;
color:#F00C23;	
font-weight: bold;
padding: 2%;	
margin-top: 2%;	
border: 2px solid #F00C23;
background-color: rgba(255,255,255,0.5);		
}
.business-wrapper .business .b-box{
width: 50%;	
}
.business-wrapper .business .b-box h4{
font-size:1.3em;
border-bottom: solid 2px #F00C23;	
padding-bottom: 1%;
margin-bottom: 1%;	
}
.business-wrapper .business .b-box p{
font-size:1em;	
line-height: 1.75;
padding: 3%;
background-color: rgba(255,255,255,0.5);		
}
.business-wrapper .business .b-box span{
display: block;	
font-size: 1.2em;	
background-color: #F0E924;	
}
.business-wrapper .business .b-box img{
width: 100%;
box-shadow: 1px 1px 5px #333;	
}
.business-wrapper .business2{
width: 100%;
display: flex;
flex-wrap:wrap;
justify-content:space-around;
align-items:flex-start;	
padding: 2%;	
}
.business-wrapper .business2 .b-box2{
width: 30%;
height: 380px;	
margin-top: 1%;	
box-shadow: 1px 1px 5px #333;
background-color: #eee;		
}
.business-wrapper .business2 .re{
height: auto!important;	
padding: 0.5% 0.5% 0;
background-color: #fff;	
}	
.business-wrapper .business2 .b-box2 .t-text{
font-size: 1em;
text-align: center;
line-height: 1;
background:#F0E924;	
font-weight: bold;
}
.business-wrapper .business2 .b-box2 p{
font-size:0.9em;	
line-height: 1.75;
padding: 3%;

}
.business-wrapper .business2 .b-box2 img{
width: 100%;	
}
.business-wrapper .b-back{
width: 100%;
height: auto;
display: inline-block;
background-image: url("../img/background7.jpg");
background-size: cover;
background-position: center;
box-shadow: inset 0 0 15px 10px #fff;	
padding: 3% 0;	
}

.business-wrapper .business3{
width: 100%;
display: flex;
flex-wrap:wrap;
justify-content:space-between;
align-items:center;	
padding: 3%;
	
}
.business-wrapper .business3 .b-box3{
width: 30%;
margin-top: 1%;		
}
.business-wrapper .business3 .b-box4{
width: 67%;
margin-top: 1%;		
}

.business-wrapper .business3 .b-box4 p{
font-size:0.9em;	
line-height: 1.75;
padding: 3%;
background-color: rgba(255,255,255,0.5);		
}
.business-wrapper .business3 .b-box3 img{
width: 100%;
box-shadow: 1px 1px 5px #333;	
}
.under {
  font-size: 1.3em;	
  background: linear-gradient(transparent 70%, rgba(240,233,36,0.8) 70%);
text-shadow: 1px 1px 3px #fff;	
}




/*===========フッターお問い合わせ===========*/

.footer_contact{
width: 100%;
height: auto;
display: inline-block;
 background-image: url("../img/background1.jpg");
background-size: cover;
background-position: center;  
background-attachment: fixed;    
}
.f-logo{
width: 100%;
height: auto;
display: block;    
}
.f-logo img{
width: 35%;  
display: block;
margin: 0 auto;
}

.f-con_box{
width: 100%;    
}
.f-tel{
width: 100%;    
font-size: 2.3em;   
color: #CB0B09;
text-align: center;  
display: block;  
}

.f-tel small{
display: block;
font-size: 0.7em;
color: #050060; 
margin-bottom: 1%;    
}

.footer_contact iframe{
height: 500px;    
} 
/*===========フッター===========*/

footer{
	width: 100%;
	background: #157307;
	height: auto;
    padding: 1% 0 0;
}


.footernavi ul{
	display: flex;
	flex-wrap:wrap;
justify-content:space-around;
align-items:center;
	list-style: none;
    border-top: 1px solid white;
	border-bottom: 1px solid white;
	text-align: center;
}

.footernavi ul li {
	padding: 1% 0;
}

.footernavi ul li a{
	text-decoration: none;
	color: #fff;
	font-size: 0.9em;
	font-weight: bold;
	transition: color .3s, text-decoration .3s;
}

.footernavi ul li a:hover{
opacity: 0.7;	
text-decoration-color: transparent;		
}


.my_icon{
	padding-right: 5px;
}

#copy{
    width: 100%;
	text-align: center;
	padding: 1% 0;
	font-size: 13px;
	color:#fff;
}
/*===========事業案内===========*/
.business-box{
width: 100%;
height: auto;
display: block;    
}
.bus-text1{
font-size: 1.5em;
color:#157307;  
border-bottom: 2px solid #AAF277;
padding-bottom: 2%; 
padding-left: 1%;    
}
.bus-text2{
font-size: 1.3em;
line-height: 1.75;  
padding-left: 1%;  
padding-bottom: 3%;    
}
.bus-text1 span{
color:#157307;
background: #fff600;
padding: 1% 2%;  
vertical-align: middle;
}
/*===========施工実積===========*/
.works_box{
width: 100%;
height: auto;
display: block;    
}
.works_photo{
width: calc(93% / 3);  
display: block;
margin: 1%;
}
.works_photo img{
width: 100%;    
}
.works_photo p{
font-size: 1em;
line-height: 1.75;  
letter-spacing: 1px;  
border-bottom: 1px dotted #034001;  
padding-left: 2%;  
min-height: 200px;    
}
.works_photo a{
font-size: 1em;
color: #333;
display: block;
 
}
.works_photo strong{
font-size: 1.1em;
border-bottom: 1px dotted #034001;
display: block;  
padding-left: 2%;      
}
.works_photo span{
font-size: 1.5em;
color: #157307;    
}



.w_slider li a{
	display: block;
	width: 100%;
	position: relative;
    overflow: hidden;
	min-height: 0%;
	aspect-ratio:3 / 2;
}
.w_slider li a::before{
	content: '';
    display: block;
    padding-top: 80%;
}
.w_slider li a img{
	display: block;
	aspect-ratio:3 / 2;
    position: absolute;
    top: 0;
    left: 0;
	transition: all 0.3s ease;
  object-fit: cover;
}
.w_slider li a:hover img{
	transform: scale(1.15);
}

/*before/afterの記述*/
.w_slider li a.before::after,
.w_slider li a.after::after{
	position: absolute;
	height: 100%;
	right:5px;
	bottom: -200px;
	text-align: right;
	text-shadow: #fff 0px 0px 1px, #fff 0px 0px 2px, #fff 0px 0px 3px, #fff 0px 0px 4px, #fff 0px 0px 5px, #fff 0px 0px 6px;
	color: #26973a;
	text-transform: capitalize;
	font-family: 'Readex Pro', sans-serif;
    font-weight: 400;
	padding-right: 5px;
	letter-spacing: 0.05em;
}
.w_slider li a.before::after{
	content: 'before';
}
.w_slider li a.after::after{
	content: 'after';
}

@media (max-width: 450px){
	.w_slider li a.before::after,
	.w_slider li a.after::after{
		font-size: 2rem;
	}
}


/*===========お客様の声・FAQ==========*/
.voice_faq-box{
width: 100%;
height: auto;
display: block;
}
.v-photo{
width: 40%    
}
.v-photo img{
width: 90%;
display:block;
margin: 0 auto;
}
.v-text{
width: 60%;
padding: 2%;    
}
.question{
font-size: 1.5em;
color:#157307;  
border-bottom: 2px dotted #157307;
padding-bottom: 1%; 
padding-left: 1%;    
}
.answer{
font-size: 1.3em;
line-height: 1.75;  
padding-left: 1%;     
}
.fa-quora{
color: #fff;
background: #4ABF2A;
padding: 5px;    
}
/*===========求人情報===========*/
.recruit{
width: 100%; 
background: rgba(255,255,255,0.3); 
    
}

.recruit .img1{
width: 90%; 
display: block;
margin: 2% auto;     
}
.recruit .img2{
width: 100%; 
display: block;
}
.r-text{
width: 48%;
height: 300px;    
padding:3%;  
display: block;
margin: 0 auto;
background: url("../img/background12.png");
background-size: cover;
background-repeat: no-repeat;
}
.r-text2{
width: 60%;
position: absolute;
bottom: 15%;
left: 3%; 
background:rgba(255,255,255,0.7);
padding: 2%;    
}
.r-text2 span{
font-size: 1.2em;
color:#bf512a; 
display: block;    
}
.recruit table{
 width: 100%;
}
.recruit table tr{
  border-bottom:solid 3px #fff;
 font-size: 1em;	
}

.recruit table th{
  position: relative;
  width: 30%;
 text-align:center;
 font-size: 1.3em;	    
border-bottom:1px solid #157307;
background: rgba(255,255,255,0.5); 
color: #195708; 
  line-height: 1.75;    
}

.recruit table td{
  text-align: left;
  border-bottom:1px solid #eee;
  padding:1% 2%;	
  font-weight: normal;	
  line-height: 200%;
  font-size: 1.3em;	
  width: 70%;	
position: relative;
overflow: hidden;
background: rgba(255,255,255,0.5);      
}
.r-title1{
width: 100%;    
}
.r-title2{
width: 50%; 
margin: 0!important;   
display: block;
}
.r-box{
width: 100%;
background: url("../img/background3.jpg");
background-size: cover;   
box-shadow: 2px 2px 5px #eee;  
position: relative;    
}
/*===========会社概要===========*/
.company-box{
width: 100%;
height: auto;
display: block;      
}
.company-box img{
width: 100%;   
border-radius: 20px;
z-index: 97;   
position: relative;
}
.com-photo{
width: 100%;    
}
.com-photo img{
width: 70%;
display: block;
margin: 0 auto;
}
.company-box table{
 width: 100%;
}
.company-box table tr{
  border-bottom:solid 3px #fff;
 font-size: 1em;	
}

.company-box table th{
  position: relative;
  width: 30%;
  color:#fff;
 text-align:center;
 font-size: 1em;	    
background: #4ABF2A; 
border-radius: 10px;    
}

.company-box table td{
  text-align: left;
  border-bottom:1px solid #195708;
  padding:1% 2%;	
  font-weight: normal;	
  line-height: 200%;
  font-size: 1em;	
  width: 70%;	
position: relative;
overflow: hidden;
background: #fff;       
}
.company-box table img{
  width: 50%;
position: absolute;
bottom: 0;
right: 0;    
}
.map{
width: 100%;
height: auto;
display: block;    
}
.map iframe{
height: 350px;
}
.info_p{
width: 30%; 
margin-top: 3%;    
}
.info_p img{
width: 98%;
display: block;
margin: 0 auto;
}
.info_t{
width: 70%;
padding: 2%;    
}
/*===========お問い合わせ===========*/
.contact-box{
width: 100%;
height: auto;
display: block;    
}
.contact-t{
    width: 50%;
    position:relative;
    height: 150px;  
}
.contact-t strong{
 font-size: 2em;   
}
.contact-t p{
font-size:1em;
color: #4ABF2A; 
line-height: 1.75;   
padding: 2%;   
position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 100%;
  text-align: center;/*一応BOX内の文字も中央寄せ*/    
}
.contact-t a{
font-size: 1em; 
transition: all 0.5s;
padding: 2%;  
color: #FFF;    
line-height: 1.75;   
position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 100%;
  text-align: center;/*一応BOX内の文字も中央寄せ*/    
}
.contact-t a:hover{     
ext-decoration: transparent;    
 color: #eee;
}

form{
	width: 100%;
	text-align: center;
}
.cotact-box{
width: 100%;
margin-bottom: 10%;    
}
.checkbox_text{
line-height: 1.75;
color: #333;	
}
.table1{
width: 100%;
background:rgba(255,255,255,0.7);
display: block;
margin: 0 auto;  
padding: 3%;     
}
.table1 table{
width: 100%;	
}
.contact-text1 {
	font-size:1em;
}
.contact-text1 .red1{
	background-color:#ff5b5b; 
	color:#fff;
	font-size:0.8em;
	padding:2px 5px;
	margin-left: 5px;
              text-shadow    : 
       0px  0px 0px #ffffff,
      -0px  0px 0px #ffffff,
       0px -0px 0px #ffffff,
      -0px -0px 0px #ffffff,
       0px  0px 0px #ffffff,
       0px  0px 0px #ffffff,
      -0px  0px 0px #ffffff,
       0px -0px 0px #ffffff;  
    
}
.table1 .w30{
width: 30%;
margin-bottom: 2%;	
}
.table1 table .red1{
	background-color:#ff5b5b; 
	color:#fff;
	font-size:0.8em;
	padding:2px 5px;
	margin-right: 5px;
    
}
.table1 table .yellow{
	background-color:#F2CB05;
	color:#fff;
	font-size:0.8em;
	padding:2px 5px;
	margin-right: 5px;
}
.table1 table th{
	font-size: 1em;
	text-align: left;
	color:#333;
	font-weight:300;
	border-bottom: 1px dotted #222;
	padding-left: 2%;
}

.table1 table td p{
	font-size: 1em;
	color:#000;
	font-weight:300;
	padding-top: 1%;
	line-height: 1.7;
}
.table1 table td img{
width:100%;	
margin-top: 1%;	
border-radius: 50px;	
}
.table1 table td{
font-size: 1em;
text-align: left;	
color:#333;
border-bottom: 1px dotted #222;
padding: 2% 2%;
font-weight:300;
width: 60%;    
}


.textareatablearea{
width:100%;
}

textarea{
width:100%;
height: 400px
}
.table1 dd p{
	margin-top: 1%;
	font-size:1.1em;
	color:#333;
	letter-spacing: 4px;
	font-weight:300;
	line-height: 1.75;
}

.single p{
	text-align: center;
	color:#333;
	font-weight:300;
}


.fm-text p{
	font-size: 1.1em;
	text-align: left;
	color:#333;
	line-height: 200%;
	font-weight:300;
    padding: 2%;
}
.form-button
{
margin: 5% 0;
text-align: center;
}

.form-button button {
    cursor: pointer;
    display: block;
    margin: 0 auto 5px;
    padding: 10px 0 10px;
    color: #fff;
    text-align: center;
    width: 250px;
    font-weight: bold;
    background: #247D0B;
	transition: all 0.5s;	
	font-weight:300;
    border-radius: 50px;
    border: #eee 3px solid;
}
.form-button button:hover{
    color: #fff;
     background:#195708;
	text-decoration: transparent;
}
.textarea, textarea, .dropdown {
    border-radius: 2px;
}


button[type="submit"]{
	font-size:1.2em;
	padding: 10px;
}

input[type="checkbox"]{
	font-size:0.9em!important;
	margin-bottom: 7%;
	border:1px solid #bababa;	

}
input[type="text"]{
	width: 95%;
	height: 40px;
	font-size: 1em;
	padding: 10px;
	background:#fff;
	border:1px solid #bababa;
     margin-right: 1%;
    font-weight: normal;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; 
}
input[type="tel"]{
	width: 95%;
	height: 40px;
	font-size: 1em;
	padding: 10px;
	background:#fff;
	border:1px solid #bababa;
    font-weight: normal;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; 
}
input[type="email"]{
	width: 95%;
	height: 40px;
	font-size: 1em;
	padding: 10px;
	background:#fff;
	border:1px solid #bababa;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; 
}
textarea[type="text"]{
padding: 10px;	
font-size: 1em;	
background:#fff;	
border:1px solid #bababa;
width: 95%;  
font-weight: normal;  
font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";    
}

.kojin{
width: 100%;
height: auto;
display:block;	
margin: 0 auto;
}
.kojin h3{
font-size: 1.2em;
margin-bottom: 1%;	
font-weight:300;
transition: all 0.5s;
padding: 1%;
text-align: left;	
background:#195708;  
color:#fff;	    
}
.kojin h3:hover{
border:1px #195708 solid;
color:#195708;
background: rgba(255,255,255,0.9);   
text-decoration: transparent;	

}
.kojin h4{
font-size: 1.1em;
text-align: left;
color: #195708;
padding-bottom: 3px;	
font-weight:bold;
letter-spacing: 2px;
border-bottom: 1px solid #195708;
padding: 1%;	
}
.kojin p{
font-size:0.9em;
line-height:200%;	
text-align: left;
font-weight: normal;
color:#333;	
font-weight:300;
letter-spacing: 2px;
padding: 1% 0;	
padding-left: 1%;	
}
#open1{
background: #e3f5df;    
padding: 3%;    
}



#mailform .in_box, #mailform textarea{
	border: 1px solid #ddd;
  	padding: 5px;
  	width: 100% !important;
  	border-radius: 0;
	-webkit-appearance: none;
	margin-bottom: 5px;
	background: #fff;
}




/* 251129 TOP 新着情報 リストの表示崩れ修正 ===============================*/
.news_correction251129 .news ul#newsList li {
  line-height: 1.9;
  margin-bottom: 0;
  padding: 10px 0 !important;
}
@media (max-width: 670px) {
  .news_correction251129 .news ul#newsList li {
    padding: 5px 0 !important;
  }
}