@charset "UTF-8";
/*変数設定用*/
body.home {
  padding: 0;
}
body.home .mv-area {
  position: relative;
}
body.home .mv-area .mv-wrap {
  position: relative;
}
body.home .mv-area .mv-wrap .mv-ttl-wrap {
  padding-top: 80px;
  display: flex;
  align-items: center;
  row-gap: 30px;
  justify-content: space-between;
  transform: translateY(50px);
}
@media screen and (max-width: 768px) {
  body.home .mv-area .mv-wrap .mv-ttl-wrap {
    row-gap: 10px;
    flex-direction: column;
    align-items: flex-start;
    padding-top: 60px;
  }
}
body.home .mv-area .mv-wrap .mv-ttl-wrap .mv-sub-ttl {
  font-size: 6rem;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .mv-wrap .mv-ttl-wrap .mv-sub-ttl {
    font-size: 22px;
  }
}
body.home .mv-area .mv-wrap .mv-ttl-wrap .mv-sub-des {
  letter-spacing: 0.05em;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .mv-wrap .mv-ttl-wrap .mv-sub-des {
    font-size: 12px;
  }
}
body.home .mv-area .about-area {
  padding: 140px 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area {
    padding: 60px 0;
  }
}
body.home .mv-area .about-area::after {
  content: "";
  background: url(../img/top/img_about01.png) no-repeat center center;
  background-size: cover;
  right: 0;
  top: 0;
  position: absolute;
  width: 45%;
  height: 100%;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area::after {
    width: 100%;
    height: 433px;
    background: url(../img/top/img_about01.png) no-repeat center bottom;
    background-size: cover;
    top: initial;
    bottom: 0;
  }
}
body.home .mv-area .about-area .inner .about-flex {
  display: flex;
  column-gap: 11%;
  align-items: flex-start;
  width: 100%;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .inner .about-flex {
    flex-direction: column;
    row-gap: 20px;
  }
}
body.home .mv-area .about-area .inner .about-flex .section-ttl .en-txt {
  white-space: nowrap;
}
body.home .mv-area .about-area .about-list-wrap {
  margin: 60px 0 40px;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap {
    margin: 30px 0 30px;
  }
}
body.home .mv-area .about-area .about-list-wrap .about-list {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap .about-list {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
}
body.home .mv-area .about-area .about-list-wrap .about-list li {
  width: 380px;
  background-color: white;
  padding: 40px;
  text-align: center;
  box-shadow: 0px 10px 16px rgba(0, 0, 0, 0.1);
  border-radius: 6px;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap .about-list li {
    width: 335px;
    position: relative;
    display: flex;
    gap: 20px;
    padding: 20px;
    text-align: left;
  }
}
body.home .mv-area .about-area .about-list-wrap .about-list li .about-ttl {
  min-height: clamp(60px, 8vw, 70px);
  display: flex;
  align-items: center;
  font-size: clamp(13px, 9px + 0.8vw, 24px);
  line-height: 1.5;
  justify-content: center;
  text-align: center;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap .about-list li .about-ttl {
    font-size: 1.8rem;
    min-height: initial;
    text-align: left;
    justify-content: flex-start;
    margin-bottom: 10px;
  }
}
body.home .mv-area .about-area .about-list-wrap .about-list li .about-des {
  line-height: 1.7142857143;
  font-size: clamp(10px, 8.6666666667px + 0.3555555556vw, 14px);
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap .about-list li .about-des {
    font-size: 1.2rem;
  }
}
body.home .mv-area .about-area .about-list-wrap .about-list li .about-icon {
  width: 60px;
  height: 60px;
  margin: auto;
}
@media screen and (max-width: 768px) {
  body.home .mv-area .about-area .about-list-wrap .about-list li .about-icon {
    width: 40px;
    height: 40px;
    margin: initial;
  }
}
body.home .service-area {
  padding: 140px 0;
  position: relative;
  background-color: #F5F5F5;
}
body.home .service-area::after {
  content: "";
  background: url(../img/top/img_service03.png) no-repeat center center;
  background-size: cover;
  right: 0;
  bottom: 0;
  position: absolute;
  width: 315px;
  height: 562px;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  body.home .service-area::after {
    width: 122px;
    height: 217px;
  }
}
@media screen and (max-width: 768px) {
  body.home .service-area {
    padding: 60px 0 60px;
  }
}
body.home .service-area .service-list-wrap {
  margin: 60px 0 40px;
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap {
    margin: 30px 0 30px;
  }
}
body.home .service-area .service-list-wrap .service-list {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap .service-list {
    flex-direction: column;
    align-items: center;
  }
}
body.home .service-area .service-list-wrap .service-list li {
  width: 585px;
  background-color: white;
  text-align: center;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap .service-list li {
    width: 100%;
    position: relative;
  }
}
body.home .service-area .service-list-wrap .service-list li .service-ttl {
  min-height: clamp(60px, 8vw, 70px);
  display: flex;
  align-items: center;
  font-size: clamp(13px, 9px + 0.8vw, 24px);
  line-height: 1.5;
  justify-content: center;
  text-align: center;
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap .service-list li .service-ttl {
    font-size: 1.8rem;
    min-height: 65px;
  }
}
body.home .service-area .service-list-wrap .service-list li .service-des {
  line-height: 1.7142857143;
  font-size: clamp(10px, 8.6666666667px + 0.3555555556vw, 14px);
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap .service-list li .service-des {
    font-size: 1.2rem;
  }
}
body.home .service-area .service-list-wrap .service-list li .service-pos {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 60px 110px;
  background-color: rgba(0, 0, 0, 0.34);
  color: white;
  border-radius: 6px;
  width: max-content;
}
@media screen and (max-width: 768px) {
  body.home .service-area .service-list-wrap .service-list li .service-pos {
    padding: 20px 30px;
  }
}
body.home .works-area {
  position: relative;
  padding: 140px 0;
  background: url(../img/top/img_works01.jpg) no-repeat center center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  body.home .works-area {
    padding: 60px 0 60px;
  }
}
body.home .works-area .works-list-wrap {
  margin: 60px 0 40px;
}
@media screen and (max-width: 768px) {
  body.home .works-area .works-list-wrap {
    margin: 30px 0 30px;
  }
}
body.home .works-area .works-list-wrap .works-list {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  body.home .works-area .works-list-wrap .works-list {
    flex-direction: column;
    align-items: center;
  }
}
body.home .works-area .works-list-wrap .works-list li {
  width: 380px;
}
@media screen and (max-width: 768px) {
  body.home .works-area .works-list-wrap .works-list li {
    width: 100%;
  }
}
body.home .works-area .works-list-wrap .works-list li .works-ttl {
  font-size: 16px;
  margin-top: 10px;
}
body.home .news-area {
  padding: 140px 0 0;
}
@media screen and (max-width: 768px) {
  body.home .news-area {
    padding: 60px 0 0;
  }
}
body.home .news-area .news-flex {
  display: flex;
  gap: 80px;
  margin-top: 50px;
  align-items: end;
}
@media screen and (max-width: 768px) {
  body.home .news-area .news-flex {
    flex-direction: column-reverse;
    row-gap: 30px;
    align-items: center;
  }
}
body.home .news-area .news-flex .news-list-wrap {
  width: 70%;
}
@media screen and (max-width: 768px) {
  body.home .news-area .news-flex .news-list-wrap {
    width: 100%;
  }
}
body.home .news-area .news-flex .news-list-wrap .template-btn {
  margin: 20px 0 0 auto;
}
body.home:not(:has(.works-area .works-archive-list li)) .company-area {
  margin: 400px 0 0;
}
@media screen and (max-width: 768px) {
  body.home:not(:has(.works-area .works-archive-list li)) .company-area {
    margin: 250px 0 0;
  }
}/*# sourceMappingURL=top.css.map */