@charset "utf-8";
/*------------------------  home  ------------------------*/

/*-----  mv  -----*/
#home .mv {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 640px;
  background: url(/img/home_mv.webp) no-repeat center;
  background-size: cover;
}
#home .mv .copy {
  position: absolute;
  bottom: 14%;
  right: 5%;
  color: #fff;
  font-size: 45px;
  font-weight: 800;
  text-decoration: underline;
  line-height: 1.6;
  text-underline-offset: 10px;
}
#home .sp {
  display: none;
}
@media screen and (max-width: 1020px) {
  #home .mv {
    height: 560px;
  }
}

@media screen and (max-width: 800px) {
  #home .mv {
    height: 340px;
  }
  #home .mv .copy {
    bottom: 14%;
    right: 7%;
    font-size: 30px;
  }
  #home .sp {
    display: none;
  }
}
@media screen and (max-width:500px) {
  #home .mv {
    background-position-x: -41px;
  }
  #home .sp {
    display: block;
  }

  #home .mv .copy {
    bottom: 6%;
    right: 7%;
    font-size: 30px;
  }

}
/*-----  top-farm  -----*/
#home .top_farm {
  padding: 10px 4% 0px;
}
#home  .farm_flex {
  display: flex;
  align-items: center;
  max-width: 1200px;
  height: 540px;
  background: url(/img/MF_topmap.png) no-repeat center;
  background-position: 100%;
  background-size: 590px 552px;
  margin: 10px auto 0;

}

#home .top_farm .txt-block {
  max-width: 728px;
}

#home .top_farm .txt-block .ttl {
  padding: 0px 0 15px;
  line-height: 1.6;
  position: relative;
  font-size: 30px;
}
#home .top_farm .txt-block .ttl::after {
  content: "";
  position: absolute;
  bottom: 0%;
  left: 0;
  width: 30px;
  height: 1px;
  background: #08A7DC;
}
#home .top_farm .txt-block .txt {
  line-height: 1.6;
  width: 78%;
  padding-top: 15px;
}
@media screen and (max-width: 1020px) {
  #home .top_farm {
    padding-top: 36px;

  }
  #home .top_farm .txt-block .ttl {
    font-size: 22px;
  }
  #home  .farm_flex {
    display: block;
  }

}
@media screen and (max-width:768px) {
  #home .top_farm {
    padding: 36px 0% 0px;
  }
  #home .farm_flex {
    background-position: bottom;
    background-size: contain;
    margin: 0 6%;
    height: 730px;

  }
  #home .top_farm .txt-block .ttl {
    font-size: 20px;
  }
  #home .top_farm .txt-block .txt {
    font-size: 15px;
    width: auto;
    padding-top: 15px;
  }
}
 
/*-----  stand  -----*/
#home .stand {
  padding: 90px 4% 30px;
  background: #EFF6F9;
}
#home .stand .stand-block {
  display: flex;
  align-items: center;
  margin: 0 auto 70px;
  max-width: 1200px;
  background: #fff;
}
#home .stand .stand-block:nth-of-type(odd) {
  flex-direction: row-reverse;
}
#home .stand .stand-block .photo {
  flex-basis: 58%;
}
#home .stand .stand-block .txt-block {
  flex-basis: 42%;
  padding: 0 4%;
}
#home .stand .stand-block .txt-block .ttl-block {
  position: relative;
  padding: 0 0 20px;
  line-height: 1.3;
}
#home .stand .stand-block .txt-block .ttl-block::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 30px;
  height: 1px;
  background: #08A7DC;
}
#home .stand .stand-block .txt-block .cap {
  padding: 0 0 1px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #08A7DC;
  letter-spacing: 0;
}
#home .stand .stand-block .txt-block .ttl {
  font-weight: 700;
  font-size: 30px;
}
#home .stand .stand-block .txt-block .txt {
  padding: 22px 0 0;
  line-height: 1.7;
}
#home .stand .stand-block .txt-block .stand-btn {
  margin: 30px 0 0 auto;
  width: 180px;
}

@media screen and (max-width: 1020px) {
  #home .stand {
    padding: 90px 3% 30px;
  }
  #home .stand .stand-block .photo {
  }
  #home .stand .stand-block .photo img {
    height: 400px;
    object-fit: cover;
  }
  #home .stand .stand-block .txt-block {
    padding: 0 5%;
  }
  #home .stand .stand-block .txt-block .ttl-block {
    padding: 0 0 18px;
  }
  #home .stand .stand-block .txt-block .cap {
    font-size: 15px;
  }
  #home .stand .stand-block .txt-block .ttl {
    font-size: 28px;
  }
  #home .stand .stand-block .txt-block .txt {
    padding: 20px 0 0;
    line-height: 1.6;
  }
}

@media screen and (max-width: 800px) {
  #home .stand {
    padding: 45px 5% 10px;
  }
  #home .stand .stand-block {
    display: block;
    margin: 0 auto 35px;
  }
  #home .stand .stand-block .photo {
  }
  #home .stand .stand-block .photo img {
    height: auto;
    object-fit: contain;
  }
  #home .stand .stand-block .txt-block {
    padding: 18px 5% 28px;
  }
  #home .stand .stand-block .txt-block .ttl-block {
    padding: 0 0 16px;
  }
  #home .stand .stand-block .txt-block .cap {
    font-size: 14px;
  }
  #home .stand .stand-block .txt-block .ttl {
    font-size: 22px;
  }
  #home .stand .stand-block .txt-block .txt {
    padding: 16px 0 0;
    line-height: 1.6;
  }
  #home .stand .stand-block .txt-block .stand-btn {
    margin: 22px auto 0;
    width: 170px;
  }
}

/*-----  news  -----*/
#home .news {
  position: relative;
  margin: 0 0 80px;
  border-bottom: 1px solid #e9e9e9;
}
#home .news::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 50%;
  width: 30px;
  height: 1px;
  background: #00763c;
  transform: translate(-50%, 0);
}
#home .news .news-inner {
  margin: 0 auto;
  padding: 70px 6% 70px;
  max-width: 1200px;
}
#home .news .ttl-block {
  position: relative;
  padding: 0 0 24px;
  line-height: 1.3;
}
#home .news .ttl-block .cap {
  padding: 0 0 1px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #00763c;
  letter-spacing: 0;
}
#home .news .ttl-block .ttl {
  font-weight: 700;
  font-size: 28px;
}
#home .news .news-list {
}
#home .news .news-list .item {
  border-bottom: 1px solid #e9e9e9;
  line-height: 1.5;
}
#home .news .news-list .item:first-of-type {
  border-top: 1px solid #e9e9e9;
}
#home .news .news-list .link {
  display: flex;
  padding: 20px 10px;
}
#home .news .news-list .nolink {
  display: flex;
  padding: 20px 10px;
}
#home .news .news-list .date {
  flex-basis: 7.4em;
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  letter-spacing: 0;
}
#home .news .news-list .news-title {
  flex: 1;
}
#home .news .news-btn {
  margin: 35px auto 0;
  width: 180px;
}

@media screen and (max-width: 1020px) {
  #home .news .ttl-block .cap {
    font-size: 15px;
  }
  #home .news .ttl-block .ttl {
    font-size: 28px;
  }
}

@media screen and (max-width: 800px) {
  #home .news {
    margin: 0 0 50px;
  }
  #home .news .news-inner {
    padding: 45px 6% 45px;
  }
  #home .news .ttl-block {
    padding: 0 0 18px;
  }
  #home .news .ttl-block .cap {
    font-size: 14px;
  }
  #home .news .ttl-block .ttl {
    font-size: 22px;
  }
  #home .news .news-list .link {
    display: block;
    padding: 16px 0;
  }
  #home .news .news-list .nolink {
    display: block;
    padding: 16px 0;
  }
  #home .news .news-list .date {
    padding: 0 0 1px;
  }
  #home .news .news-btn {
    margin: 25px auto 0;
    width: 170px;
  }
}

/*-----  lower  -----*/
#home .lower {
  margin: 70px auto;
  padding: 0 3% 90px;
  max-width: 1200px;
}
#home .lower .lower-inner {
  display: flex;
  justify-content: center;
}
#home .lower .item {
  flex-basis: calc(100% / 3);
  line-height: 1.3;
}
#home .lower .item:not(:last-of-type) {
  margin: 0 3% 0 0;
}
#home .lower .item .photo {
  padding: 0 0 22px;
}
#home .lower .item .ttl-block {
  position: relative;
  padding: 0 0 20px;
}
#home .lower .item .cap {
  padding: 0 0 1px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #08A7DC;
  letter-spacing: 0;
}
#home .lower .item .ttl {
  font-weight: 700;
  font-size: 22px;
}
#home .lower .item .lower-btn {
  text-align: right;
}

@media screen and (max-width: 1020px) {
  #home .lower .item .cap {
    font-size: 14px;
  }
  #home .lower .item .ttl {
    font-size: 20px;
  }
}

@media screen and (max-width: 800px) {
  #home .lower {
    padding: 0 6% 40px;
  }
  #home .lower .lower-inner {
    display: block;
  }
  #home .lower .item:not(:last-of-type) {
    margin: 0;
    padding: 0 0 35px;
  }
  #home .lower .item .photo {
    padding: 0 0 14px;
  }
  #home .lower .item .ttl-block {
    padding: 0 0 16px;
  }
  #home .lower .item .cap {
    font-size: 14px;
  }
  #home .lower .item .ttl {
    font-size: 20px;
  }
}
