
@charset "utf-8";

.container{
    width: 100%;
    text-align: center;
}
.content{
    width: 1200px;
    display: inline-block;
}

/* スクロールCSS */
.fade-in {
  opacity: 0;
  transition-duration: 2400ms;
  transition-property: opacity, transform;
}

.fade-in-up {
  transform: translate(0, 100px);
}

.fade-in-down {
  transform: translate(0, -200px);
}

.fade-in-left {
  transform: translate(-100px, 0);
}

.fade-in-right {
  transform: translate(100px, 0);
}

.scroll-in {
  opacity: 1;
  transform: translate(0, 0);
}


.newline{
    display: none;
}
.statics600{
    display: none;
}

.blank150{
    padding-top: 150px;
}
.blank100{
    padding-top: 100px;
}
.blank50{
    padding-top: 50px;
}
.blank40{
    padding-top: 40px;
}
.blank30{
    padding-top: 30px;
}
.blank20{
    padding-top: 20px;
}
.blank10{
    padding-top: 10px;
}

.main-color{
    color: #6FAC44;
}
.white{
    color: #fff;
}

@media screen and (max-width: 600px) {

.blank150{
    padding-top: 80px;
}
.blank100{
    padding-top: 50px;
}
.blank50{
    padding-top: 30px;
}
.blank40{
    padding-top: 20px;
}
.blank30{
    padding-top: 20px;
}
.blank20{
    padding-top: 10px;
}
.blank10{
    padding-top: 10px;
}
}


/* ----- section01 ----- */


.kv-wrap{
    max-width:100%;
    height: auto;
}
.kv-main{
     width:100%;
     height: 800px;
     position: relative;
}
img.kv-ph{
    width:100%;
    height: 800px;
    object-fit: cover;
    object-position: center;
    position: relative;
    margin-top: 100px;
        z-index: 4;
}

img.kv-parts02{
    height: 100%;
   position: absolute;
    right: 0;
    top: 0;
        margin-top: 100px;
    mix-blend-mode: multiply;
        z-index: 4;

}
img.kv-parts01{
        height: 100%;
   position: absolute;
    margin-top: 100px;
    left: 0;
    top: 0;
            z-index: 4;
}
h1{
    font-size: 38px;
    line-height: 1.4;
    font-weight: 600;
    color: #fff;
    text-align: center;
            z-index: 4;
    position: absolute;
    white-space: nowrap;
    top: calc(50% + 100px);
    left: 50%;
    transform: translateX(-50%)translatey(-50%);
     -webkit- transform: translateX(-50%)translatey(-50%);
}


@media screen and (max-width: 1200px) {

img.kv-ph{
      height: 700px;
}
.kv-main{
      height: 700px;
}
}
@media screen and (max-width: 900px) {
img.kv-ph{
      height: 500px;
}
.kv-main{
      height: 500px;
}
h1{
    font-size: 30px;
}
}
@media screen and (max-width: 600px) {

img.kv-ph{
      height: 400px;
      margin-top: 70px;
}
.kv-main{
      height: 400px;
}
h1{
    font-size: 20px;
        top: calc(50% + 70px);
}


img.kv-parts02{
     margin-top: 70px;
}
img.kv-parts01{
     margin-top: 70px;
}
}

@media screen and (max-width: 480px) {
    img.kv-ph{
      height: 260px;
}
.kv-main{
      height: 260px;
}

h1{
    font-size: 16px;

}
}
/* ----- section02 ----- */

#section02{
    text-align: center;
    position: relative;
    margin: 0 0 0 0;
    background-color: #060606;
    padding: 200px 0 100px 0;
    z-index: 3;
}

.lead{
    font-size: 18px;
    line-height: 1.8;
    color: #fff;
    font-weight: 500;
    margin-top: 30px;
}

h2{
    font-size: 50px;
    line-height: 1.4;
    font-weight: 300;
    font-family: 'Lato', sans-serif;
}
.title-sub{
    font-size: 16px;
    line-height: 1.4;
}




@media screen and (max-width: 900px) {
#section02{
    padding: 170px 0 70px 0;

}
.newline{
    display: block;
}
}

@media screen and (max-width: 600px) {

#section02{
    padding: 120px 0 50px 0;


}
.lead{
    font-size: 15px;
}
h2{
    font-size: 36px;
}
}





/* ----- section03 ----- */


#section03{
    text-align: center;
    position: relative;
    padding: 200px 0 100px 0;
    margin-top: -100px;
    background-color: #fff;
    z-index: 2;
}


p.head-sub{
    color:#D60050;
    font-size: 20px;
    line-height: 1.4;
} 
.service-wrap{
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
}
.service-item{
   width: 320px;
   display: inline-block;
}


h3.service-name{
    font-size:22px;
    line-height: 1.4;
    color:#6FAC44;
    font-weight: 500;
}
.text01{
    font-size: 16px;
    line-height: 1.8;
    text-align: justify;
    color: #333;
}


@media screen and (max-width: 1200px) {


.content{
    width: 95%;
    display: inline-block;
}
#section03{
    padding: 170px 0 70px 0;
    margin-top: -100px;
} 
h3.service-name{
    font-size:20px;
}
.service-item{
   width: 220px;
   display: inline-block;
   margin-top: 20px;
}
.service-ph{
    height: 166px;
}
}
@media screen and (max-width: 750px) {
.service-wrap {
    display: block;
    margin-top: 0;
}
.service-item{
   width: 400px;
   margin-top: 40px;
}
}
@media screen and (max-width: 600px) {
#section03{
    padding: 120px 0 50px 0;
   margin-top: -70px;
}
.company01{
    width: 300px;
}

img.icon{
    width: 140px;
}
.text01{
    font-size: 14px;
}
}

@media screen and (max-width: 480px) {
.service-item{
   width: 300px;
}
}
/* ----- section04 ----- */

#section04{
    text-align: center;
    position: relative;
    margin-top: -100px;
    padding: 270px 0 100px 0;
    background-image: url(../img/company02.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    display: block;
}

.company-wrap{
    width: 100%;
    padding: 150px 100px 100px 100px;
    background-color: #fff;
}
.company01{
    position: relative;
}
.company01-wrap{
    position: absolute;
    top: 270px;
    left: 50%;
    transform: translateX(-50%)translatey(-50%);
     -webkit- transform: translateX(-50%)translatey(-50%);
    width: 100%;

}
.title-wrap{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%)translatey(-50%);
     -webkit- transform: translateX(-50%)translatey(-50%);
}

dl{
    display: flex;
    width: 100%;
    border-bottom: 1px solid #ccc;
}
dt,dd{
    font-size: 16px;
    line-height: 30px;
    color: #333;
    text-align: left;
    padding: 24px 0 24px 0;
}
dt{
    flex-basis: 20%;
    font-weight: 600;

}
dd{
   flex-basis: 80%;
}

.deco{
    border-left: 8px solid #6FAC44;
    padding: 0 0 0 20px;
}

@media screen and (max-width: 1200px) {
#section04{
    padding: 240px 0 70px 0;
 }
.company-wrap{
    padding: 130px 70px 70px 70px;

}
.company01-wrap{
    top: 240px;
}
}
@media screen and (max-width: 600px) {
#section04{
    padding: 220px 0 50px 0;
    margin-top: -70px;
 }
.company-wrap{
    padding: 100px 30px 50px 30px;
    flex-direction: column-reverse;
}
.company01-wrap{
    top: 220px;
}
img.company-ph{
    position: relative;
    width: 100%;
    height: 240px;
    padding-top: 70px;
}

.company-inner{
    position: relative;
    width: 100%;
    left: 0px;
    padding: 50px 20px 50px 15px;
    margin: -10px 5px 5px;
}
dt{
    flex-basis: 25%;
}
.company-left{
    padding-top: 0;
}
dt,dd{
    font-size: 14px;

}
}

@media screen and (max-width: 480px) {
dl{
    display: block;
}
dt{
    padding: 10px 0 0 0;
}
dd{
    padding: 0 0 10px 0;
}
.company-wrap{
    padding: 100px 20px 50px 20px;
}
}

/* ----- section05 ----- */


#section05{
    text-align: center;
    position: relative;
    padding: 200px 0 100px 0;
    margin-top: -100px;

}

.news-wrap{
    width: 100%;
    margin-top: 40px;

}
.news-left{
    width: 20%;
}
.news-right{
    width: 80%;
}
.news-item{
    display: inline-flex;
    width: 100%;
}
.news-underline{
    border: 1px solid #F2F2F2;
    margin: 20px 0 20px 0;
}

p.news-date{
    color: #333;
    text-align: left;
    font-size: 16px;
    line-height: 1.4;
    margin-left: 10px;
}
article.news-title{
    color: #333;
    text-align: left;
    font-size: 16px;
    line-height: 1.4;
    margin-left: 30px;
}
a.button02 {
    font-size: 14px;
    line-height: 50px;
    width: 260px;
    height: 50px;
    background-color: #6FAC44;
    color: #fff;
    display: inline-block;
    text-decoration: none;
}

a.button02:hover{
    background-color: #497728;
}

a{
    text-decoration: none;
}
@media screen and (max-width: 1200px) {
#section05{
    padding: 170px 0 70px 0;

}
.news-wrap{
    display: inline-block;
}
.news-left{
    width: 100%;
}
.news-right{
    width: 100%;
    margin-top: 30px;
}
}
@media screen and (max-width: 600px) {


#section05{
    padding: 120px 0 50px 0;
    margin-top: -70px;
}
.news-item{
    display: inline-block;
}
article.news-title{
    margin-left: 10px;
}
p.news-date{
    font-size: 14px;
}
article.news-title{
    font-size: 14px;
}
}


/* ----- section6 ----- */

#section06{
    text-align: center;
    position: relative;
}
.contact-wrap{
    display: inline-flex;
    width: 100%;
    height: 290px;
}
.contact-left{
    width: 50%;
    background-color: #F2F2F2;
    position: relative;
}
.text-wrap{
        position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
     -webkit- transform: translateY(-50%) translateX(-50%);
}
img.contac01{
    width: 100%;
    height: 290px;
    object-fit: cover;
    object-position: center;
}
.contact-right{
    width: 50%;
    position: relative;
}
.contact-right-inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
     -webkit- transform: translateY(-50%) translateX(-50%);
}
.button-wrap{
     display: inline-flex;
     margin-top: 20px;
}
.button-left{
    font-size: 14px;
    line-height: 50px;
    width: 260px;
    height: 50px;
    background-color: #6FAC44;
    color: #fff;
}
.button-right{
    width: 50px;
    height: 50px;
    background-color: #060606;
        line-height: 60px;
}

.text02{
    font-size: 22px;
    line-height: 1.4;
    font-weight: 500;

}

.button-left:hover{
    background-color: #497728;
}


@media screen and (max-width: 600px) {
.contact-wrap{
    display: inline-block;
    height: auto;
}
.contact-left,.contact-right{
    width: 100%;
    height: 200px;
}
img.contact-ph{
    height: 200px;
}
img.contac01{
    height: 200px;
}
.text02{
    font-size: 18px;
}
}


/* ----- footer ----- */
footer{
    width: 100%;
    background: #222222;
    text-align: center;
    padding-top: 20px;
}
#footer ul{
    display: inline-flex;
}
.copyright{
    width: 100%;
    color: #fff;
    font-size: 15px;
    line-height: 60px;
    display: inline-block;
    border-top: 1px solid #999;
    margin-top: 60px;
}

li.f-menu{
    font-size: 16px;
    line-height: 2;
    padding: 0 20px 0 20px;
    margin: 0 0 60px 0;
    border-left: 1px solid #575757;
} 

li.f-menu:first-child{
    border-left: 0px solid #575757;
}
li{
    list-style: none;
}
a.f-menu_link{
    color: #fff;
}    
a.f-menu_link:last-child{
    border-left: 0;
}
.footer-logo{
    width: 166px;
}

@media screen and (max-width: 600px) {
#footer ul{
    display: none;
}
footer{
    padding-top: 32px;
}
.copyright{
    margin-top: 30px;
}
.footer-logo{
    width: 120px;
}
}  
