@charset "UTF-8";
/* CSS Document */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;	
}
body{
width: 100%;    
font-family: 'Noto Sans JP', sans-serif;
font-style: normal;
font-weight: 400;
background:url("../img/background2.jpg");
background-size: 50%;
background-repeat: repeat;    
}
@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: 350px;
    overflow: hidden;
    position: relative;
    background: url("../img/top4.jpg");
    background-size: cover;
    background-position: center;
}
.top_slider1 p{
   position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 100%;
  text-align: center;
    font-size: 2em;
    color: #fff;
     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; 
font-family: 'Noto Serif JP', serif;
font-weight: 600;     
}
.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: 'Noto Serif JP', serif;
font-weight: 600;  
line-height: 1.5;    
text-align: center;     
}
.midashi .small{
   font-size: 0.5em;  
    display: block;
    color: #0f7ada;
}

.text1{
font-size: 1em;  
line-height: 200%; 
text-align: center;
}
.text1 strong{
font-size: 1.5em; 
font-family: 'Noto Serif JP', serif;
font-weight: 600;     
}
.text2{
font-size: 1em;  
line-height: 1.5;    
}
.text2 strong{
font-size: 1.3em;    
}

header{
width: 100%;
height: auto;
background: url("../img/background1.jpg");
background-position: center;
background-size: cover;    
}
.heading{
width: 98%;    
  position: relative;
  padding: 1.5rem 1rem;
font-size: 1.8em;
color: #fff;   
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, #fff, #fff 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #fff, #fff 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
    
}
.heading2{
width: 98%;    
  position: relative;
  padding: 1.5rem 1rem;
font-size: 1.8em;
color: #0f7ada;   
padding: 2% 1%;  
display: block;
margin: 0 auto ;
}

.heading2:after {
  position: absolute;
  bottom: 1%;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #0f7ada, #0f7ada 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg,#0f7ada,#0f7ada 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;   
}

.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:200px ;
    padding: 2%; 
    border-radius: 30px;
    top:40px;
    z-index: 999;
}
.t-tel a{
    width: 100%;
    border-radius: 50px;
    z-index: 999;
    background: #333;
    text-align: center;
    font-size: 1.2em;
    display: block;
    padding: 1%; 
    color: #fff;
    transition: all 0.5s;	
    border: 2px solid #333;   
}
 .t-tel a:hover{
    background: #555;
    text-decoration: transparent;
}

.t-mail{
	width:200px ;
}
.t-mail a{
    width: 100%;
    border-radius: 50px;
    z-index: 999;
    background: #333;
    text-align: center;
    font-size: 1.2em;
    display: block;
    padding: 1%; 
    color: #fff;
    transition: all 0.5s;	
    border: 2px solid #333;
}
.t-mail a:hover{
    background: #555;
    text-decoration: transparent;
}
/*===========グローバルナビ===========*/

.glovalnavi{
	width: 100%;
   height: auto;
	display: inline-block;
    border-top: solid 2px #0070D0;
}

.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 #aeafaf;
margin: 10px 0;    
}


.glovalnavi ul li{
    position: relative;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
    text-align: center;
    position: relative;
    border-right: 1px solid #aeafaf;
    padding:2% 12px;
font-style: normal;  
	
}


.glovalnavi ul li a {
    display: block;
    position: relative;
    line-height: 1.6;
    font-size: 1em;
    font-weight: 500;
    text-align: center;
	transition: all 0.9s;
    color: #333;  
    font-weight: bold;
}
.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:#60a0d0;
    -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(-5px);
    transform:translateY(-5px);
	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;	
}
.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: 98%;
display: flex;   
flex-wrap:wrap;
justify-content:space-around;
align-items:center;
margin: 0 auto;
}
.flex-box4{
width: 98%;
display: flex;   
flex-wrap:wrap;
justify-content:flex-start;
align-items:center;
}
/*===========あいさつ===========*/
.greetings-box{
width: 95%;
height: 800px!important;    
margin: 0 auto;    
height: auto;   
padding:0 5% 5%;
position: relative;   
}
.greetings-box1{
width: 95%;
height: auto;     
display: block;
margin: 0 auto;
}
.g-text1{
width: 90%;  
height: auto;     
display: block;
margin: 0 auto;   
background: rgba(255,255,255,0.5);   
padding: 5%;    
}
.g-img1{
width:30%;         
position: absolute;
bottom: 10%;
right: 5%;  
box-shadow: 2px 2px 5px #eee;      
}
.g-text{
width: 75%;   
background: #fff;    
box-shadow: 2px 2px 5px #eee;   
padding: 5% 10% 5% 5%;   
font-family: 'Noto Serif JP', serif;
font-weight: 600;      
}
.greetings-box2{
width: 100%;
height: auto;    
margin: 0 auto;    
height: auto;     
}
.g-img2{
width:30%;           
}
.g-img2 img{
width: 100%;    
}
.g-text2{
width: 100%;   
padding: 2%;    
}
.greetings{
width: 100%;
height: auto;
display: block;
position: relative;
}

.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;    
font-family: 'Noto Serif JP', serif;
font-weight: 600;      
}

/*===========選ばれる理由===========*/
.strength-box{
width: 100%;
height: auto;
display: block;
background:#60A0D0 ;   

}
.strength{
width:calc(90% / 2); 
position: relative;  
background: #fff;    
box-shadow: 2px 2px 5px #333;      
}
.strength img{
width:100%;
border-radius: 20px;    
  
}
.strength-text2{ 
font-size:1.2em;
color: rgba(255,255,255,0.9);   
font-weight: bold;   
color: #333;  
position: absolute;
bottom: 5px;
width: 100%;
text-align: center;    
}
.strength-text1{ 
font-size:1.2em;
color: rgba(255,255,255,0.9);   
font-weight: bold;   
color: #333;  
position: absolute;
top: -8%;
width: 100%;
text-align: center;    
}
.strength-text1 strong{ 
font-size: 3.5em;
vertical-align:inherit;     
font-family: yu-mincho-pr6n, sans-serif;
font-style: normal;
font-weight: 400;  
color: #005090;    
}

/*===========対応可能エリア===========*/
.t-map{
width: 90%;
height: auto;
display: block;
margin: 0 auto;
}
.t-map img{
width: 60%; 
display: block; 
 margin: 0% auto;   
}
/*===========スライダー===========*/
.multiple{
width: 90% ;
display: block;
margin: 3% auto;
background: rgba(255,255,255,0.8); 
padding: 2%;  
     
}
.karu-seru{
  
}
.multiple .photo2{
 height: 250px;
overflow: hidden;  
position: relative;    
}
.multiple div p{
font-size: 1em; 
padding-left: 5%;   
}
.multiple img{
width: 90% !important;  
display: block;
margin: 5% auto; 
padding: 1%;
}
/*====コンテンツ===*/
.btn3{
width:80%;
display: block;
margin: 0 auto;
  text-align: center;/*一応BOX内の文字も中央寄せ*/    
}
.button3{
    display:block;
    background:rgba(255,255,255,0.5);
    width: 100%;
    padding:1%;
    text-align:center;
    color:#000;
    margin:5px;
    cursor:pointer;
    position: relative;
    text-decoration: none;
     font-size: 1.5em;
}
.text-con{
font-size: 1.2em; 
width: 100%;
text-align: left;    
color: #fff;     
}
.contents-box{
width: 100%;
height: auto;
display: flex;    
flex-wrap:wrap;
justify-content:space-between;
align-items:center; 
}
.contents{
width:calc(100% / 3);   
position: relative;
overflow: hidden;
cursor: pointer;
background:#0f3354;  
}
.contents img{
width:100%; 
opacity: 0.5; 
transition-duration: 0.5s; 
 object-fit: cover; 
margin-bottom: -3px; 
 display:table;   
}
.c-box{
width:90%;    
position: absolute;
line-height: 200%; 
display: block;
top: 50%;
left: 50%;
margin-right: -50%;
transform: translate(-50%, -50%) ;
display:table-cell;
 overflow:hidden;
}
.c-box p{
width: 100%;  
display: block;
    margin-left: auto;
    margin-right: auto ; 
}
.c-box a{
width: 100%;  
display: block;
    margin-left: auto;
    margin-right: auto;
        font-family: 'Noto Serif JP', serif; 
    color: #000;
}
.contents:hover img{
  transform: scale(1.2);
  transition-duration: 0.5s;
    opacity: 0.9; 
}
/*===========業務内容===========*/
.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: 40%;  
display: block;
margin: 0 auto;
}
.con-box{
width: 50%;
margin: 0 auto;    
}
.f-con{
width: calc(90% / 2);  
}

.f-con a{
    width: 100%;
    border-radius: 50px;
    z-index: 999;
    background: #333;
    text-align: center;
    font-size: 1.2em;
    display: block;
    padding: 1%; 
    color: #fff;
    transition: all 0.5s;	
    border: 2px solid #333;
}
.f-con a:hover{
    background: #555;
    text-decoration: transparent;
}


footer{
	width: 100%;
	height: auto;
}


#copy{
    width: 100%;
	text-align: center;
	padding: 1% 0;
	font-size: 13px;
	color:#fff;
    background: #0f7ada;
}
/*===========事業案内===========*/
.business-box{
width: 100%;
height: auto;
display: block;    
}
.bus-text1{
width: 70%; 
padding: 2%;    
}
.bus-photo1{
width: 30%;   
}
.bus-photo1 img{
width: 100%;   
}
.flow-box{
width: 100%;
height: auto;
display: block;  
background: #60a0d0;    
}
.flow-box ul {
  padding: 0;
}
.flow-box li {
  list-style-type: none;
}
.flow-box dd {
  margin-left: 0;
}

.flow-box .flow > li {
  position: relative;
}
.flow-box .flow > li:not(:last-child) {
  margin-bottom: 40px;
}
.flow-box .flow > li:not(:first-child)::before {
  content: "";
  height: 60px;
  display: block;
  border-left: 4px dotted #e5e5e5;
  position: absolute;
  top: -40px;
  left: -webkit-calc(10% + 30px - 2px);
  left: calc(10% + 30px - 2px);
  z-index: 10;
}
.flow-box .flow > li dl {
  width: 100%;
  padding: 20px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border: 2px solid rgb(107,144,219);
  border-radius: 10px;
  position: relative;
background: #fff;    
}
.flow-box .flow > li:not(:last-child) dl::before,
.flow-box .flow > li:not(:last-child) dl::after {
  content: "";
  border: solid transparent;
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.flow-box .flow > li:not(:last-child) dl::before {
  border-width: 22px;
  border-top-color: rgb(107,144,219);
}
.flow-box .flow > li:not(:last-child) dl::after {
  border-width: 20px;
  border-top-color: #fff;
}
.flow-box .flow > li dl dt {
  font-size: 20px;
  font-weight: 600;
  color: rgb(107,144,219);
  -ms-flex-preferred-size: 20%;
  flex-basis: 20%;
  margin-right: 2vw;
  text-align: center;
}
.flow-box .flow > li dl dt .icon {
  font-size: 12px;
  color: #fff;
  background: rgb(107,144,219);
  background: -moz-linear-gradient(left, rgba(107,144,219,1) 0%, rgba(102,213,233,1) 100%);
  background: -webkit-linear-gradient(left, rgba(107,144,219,1) 0%,rgba(102,213,233,1) 100%);
  background: linear-gradient(to right, rgba(107,144,219,1) 0%,rgba(102,213,233,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6b90db', endColorstr='#66d5e9',GradientType=1 );
  padding: 5px 10px;
  margin-bottom: 10px;
  display: block;
  border-radius: 20px;
  position: relative;
  z-index: 100;
}
/*===========施工実積=============*/
.works_photo{
width: calc(93% / 3);  
display: block;
margin: 1%;    
}
.works_photo .photo1{
height: 300px;
overflow: hidden;      
}
.works_photo img{
width:100%;
border:2px solid #fff;  
}

.works-wrapper{
width: 100%;
height: auto;
display:block;
padding: 1% 0;  
background: rgba(255,255,255,0.5);    
}

.works_photo p{
font-size: 1em;
line-height: 1.75;  
letter-spacing: 1px;  
border-bottom: 1px dotted #022a72;  
width: 100%;      
}
.works_photo a{
font-size: 1em;
color: #333;
display: block;
}
.works_photo strong{
font-size: 1.1em;
border-bottom: 1px dotted #022a72;
display: block;  
 width: 100%;   
}
.works_photo span{
font-size: 1.5em;
color: #0f7ada;    
}
.photo-s{
width: auto!important;
height: 200px;
overflow: hidden;
}
/*===========スタッフ紹介===========*/
.staff{
 width: calc(90% / 3); 
margin-top: 2%;  
padding: 3%; 
background: rgba(255,255,255,0.5);    
height: 700px;   
margin-left: 1em;    
}
.staff img{
 width: 100%; 
background: #fff;
border-radius: 50%;
padding: 2%;    
}
/*===========会社概要===========*/
.text_box{
width: 100%;
background: #fff;
padding: 3%;    
}

.company-box{
width: 100%;
height: auto;
display: block;  
background:#60A0D0 ;       
}
.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;	    
border-bottom:solid 1px #fff; 
}

.company-box table td{
  text-align: left;
border-bottom:solid 1px #fff;
  padding:1% 2%;	
  font-weight: normal;	
  line-height: 200%;
  font-size: 1em;	
  width: 70%;	
position: relative;
overflow: hidden;
color: #fff;       
}
.company-box table img{
  width: 50%;
position: absolute;
bottom: 0;
right: 0;    
}
.map{
width: calc(95% / 2);
height: auto;
display: block;    
margin: 0 auto;
}
.map iframe{
height: 300px;
}
.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: #022a72; 
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:#D80424; 
	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:#D80424; 
	color:#fff;
	font-size:0.8em;
	padding:2px 5px;
	margin-right: 5px;
    
}
.table1 table .yellow{
	background-color:#D8B804;
	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: #0f7ada;
	transition: all 0.5s;	
	font-weight:300;
    border-radius: 50px;
    border: #0f7ada 3px solid;
}
.form-button button:hover{
    color: #0f7ada;
     background:#fff;
	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;	   
}

.button_c {
width: 100%;    
  display: inline-block;
  padding: .9em 3.5em;
  background-color:#022972;
  border: 2px solid #022972;
  color: #fff;
  text-align: center;
  text-decoration: none;
}
.button_c span {
  position: relative;
  padding-right: 1em;
  transition: all .3s;
}
.button_c span::after {
  position: absolute;
  top: 50%;
  right: -0px;
  content: '';
  margin-top: -2px;
  border: 7px solid transparent;
  border-btottom-width: 5px;
  border-left-width: 5px;
  border-top-color: #fff;
  transition: all .3s;
}
.button_c:hover span {
  padding: 0 .5em;
}
.button_c:hover span::after {
  right: 0;
  opacity: 0;
}
.kojin h4{
font-size: 1.1em;
text-align: left;
color: #0f7ada;
padding-bottom: 3px;	
font-weight:bold;
letter-spacing: 2px;
border-bottom: 1px solid #0f7ada;
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: #fefefe;    
padding: 3%;    
}
