@charset "UTF-8";
/*Variable
－－－－－－－*/
/*
ブレークポイント

基本  1920px
ipad 1050px
sp   767px;

コンテンツ幅1000px

*/
/* MV */
.mv {
  position: relative;
}
.mv__img {
  width: 100%;
  height: auto;
}
.mv__img img {
  width: 100%;
  height: auto;
}
.mv__content {
  position: absolute;
  top: 35%;
  left: 0;
  right: 0;
  width: 1140px;
  max-width: 100%;
  margin: auto;
  padding: 0 20px;
}
@media screen and (max-width: 767px) {
  .mv__content {
    top: 21%;
  }
}
.mv__title {
  position: relative;
  left: 3px;
  margin-bottom: 13px;
  font-size: 46px;
  font-weight: normal;
  line-height: 1.52;
  letter-spacing: 0.05em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .mv__title {
    font-size: 40px;
    line-height: 1.25;
  }
}
.mv__lead {
  position: relative;
  left: 7px;
  font-size: 20px;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Barlow", serif;
}
@media screen and (max-width: 767px) {
  .mv__lead {
    font-size: 18px;
    line-height: 1.22;
  }
}

.text-carousel {
  position: absolute !important;
  left: 0;
  bottom: -60px;
  width: 100%;
  z-index: 2;
  mix-blend-mode: color-burn;
}
@media screen and (max-width: 1200px) {
  .text-carousel {
    bottom: -45px;
  }
}
@media screen and (max-width: 1050px) {
  .text-carousel {
    bottom: -30px;
  }
}

/* concept */
.concept {
  position: relative;
  padding: 123px 0 41px 0;
  background: url("../img/concept-bg01.png") no-repeat 0% 0%;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .concept {
    padding: 80px 0 41px 0;
    background: url("../img/concept-bg01-sp.jpg") no-repeat 0% 0%;
    background-size: cover;
  }
}

.concept-block01__content {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 51%;
  padding-left: 20px;
}
@media screen and (max-width: 1050px) {
  .concept-block01__content {
    width: 54%;
  }
}
@media screen and (max-width: 767px) {
  .concept-block01__content {
    width: 100%;
    margin-bottom: 38px;
    padding: 0 20px;
  }
}
.concept-block01__content-inner {
  width: 436px;
  margin-right: 125px;
}
@media screen and (max-width: 1050px) {
  .concept-block01__content-inner {
    margin-right: 45px;
  }
}
@media screen and (max-width: 767px) {
  .concept-block01__content-inner {
    margin: 0;
  }
}
.concept-block01__content-img {
  margin-bottom: 47px;
}
@media screen and (max-width: 767px) {
  .concept-block01__content-img {
    position: absolute;
    right: 0;
    width: 55%;
  }
}
@media screen and (max-width: 767px) {
  .concept-block01__content-img-wrap {
    position: relative;
    width: 100%;
    z-index: 3;
  }
}
.concept-block01__lead {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Barlow", serif;
}
@media screen and (max-width: 767px) {
  .concept-block01__lead {
    font-size: 18px;
  }
}
.concept-block01__img {
  position: relative;
  top: 102px;
  width: 49%;
}
@media screen and (max-width: 1050px) {
  .concept-block01__img {
    width: 46%;
  }
}
@media screen and (max-width: 767px) {
  .concept-block01__img {
    width: 85%;
  }
}
.concept-block01__img > img {
  width: 100%;
  height: 666px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 636/666;
}
@media screen and (max-width: 767px) {
  .concept-block01__img > img {
    height: 278px;
    aspect-ratio: 300/278;
  }
}
.concept-block01__title {
  margin-bottom: 15px;
  font-size: 30px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.33;
  letter-spacing: normal;
  text-align: left;
  color: #054429;
}
@media screen and (max-width: 767px) {
  .concept-block01__title {
    font-size: 22px;
  }
}
.concept-block01__text p {
  font-size: 15px;
  line-height: 2;
  color: #fff;
}

/* SERVICE */
.service {
  position: relative;
  padding: 131px 0 0px 0;
}
@media screen and (max-width: 767px) {
  .service {
    padding: 104px 0 0px 0;
  }
}
.service__heading {
  text-align: center;
  line-height: 1.4;
}
.service__heading-title {
  font-size: 42px;
  font-weight: bold;
  font-family: "Barlow", serif;
  letter-spacing: 0.05em;
  color: #054429;
}
@media screen and (max-width: 767px) {
  .service__heading-title {
    font-size: 38px;
  }
}
.service__heading-lead {
  font-size: 18px;
  letter-spacing: 0.05em;
  color: #054429;
}
@media screen and (max-width: 767px) {
  .service__heading-lead {
    font-size: 16px;
  }
}

.service-block01__content {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 42.3%;
  padding-right: 20px;
}
@media screen and (max-width: 1050px) {
  .service-block01__content {
    width: 48%;
  }
}
@media screen and (max-width: 767px) {
  .service-block01__content {
    width: 100%;
    padding: 0 20px;
  }
}
.service-block01__content-inner {
  width: 384px;
  margin-left: 61px;
  padding-top: 20px;
}
@media screen and (max-width: 1050px) {
  .service-block01__content-inner {
    margin-left: 40px;
  }
}
@media screen and (max-width: 767px) {
  .service-block01__content-inner {
    width: 100%;
    margin-left: 0;
  }
}
.service-block01__content-img {
  margin-bottom: 55px;
}
.service-block01__lead {
  font-size: 20px;
  color: #8ec174;
}
@media screen and (max-width: 767px) {
  .service-block01__lead {
    font-size: 15px;
  }
}
.service-block01__title {
  position: relative;
  top: -10px;
  margin-bottom: 6px;
  font-size: 48px;
  line-height: 1.46;
  color: #054429;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .service-block01__title {
    top: -5px;
    font-size: 36px;
  }
}
.service-block01__text p {
  font-size: 16px;
  line-height: 1.88;
}
@media screen and (max-width: 767px) {
  .service-block01__text p {
    font-size: 14px;
  }
}
.service-block01__img {
  position: relative;
  top: 0px;
  width: 57.7%;
}
@media screen and (max-width: 1050px) {
  .service-block01__img {
    width: 52%;
  }
}
@media screen and (max-width: 767px) {
  .service-block01__img {
    width: 100%;
  }
}
.service-block01__img > img {
  width: 100%;
  height: 520px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 750/520;
}
@media screen and (max-width: 767px) {
  .service-block01__img > img {
    height: auto;
    aspect-ratio: inherit;
  }
}

.list-area01 {
  padding: 21px 27px 57px 27px;
  background-color: #ececec;
}
.list-area01__title {
  margin-bottom: 10px;
  font-size: 17px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .list-area01__list {
    font-size: 15px;
  }
}

.service-block02 {
  position: relative;
  top: 75px;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .service-block02 {
    top: 0px;
    flex-direction: column-reverse;
  }
}
.service-block02__content {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 42.3%;
  padding-left: 20px;
}
@media screen and (max-width: 1050px) {
  .service-block02__content {
    width: 48%;
  }
}
@media screen and (max-width: 767px) {
  .service-block02__content {
    width: 100%;
    padding: 0 20px;
  }
}
.service-block02__content-inner {
  width: 384px;
  margin-right: 66px;
  padding-top: 30px;
}
@media screen and (max-width: 1050px) {
  .service-block02__content-inner {
    margin-right: 40px;
  }
}
@media screen and (max-width: 767px) {
  .service-block02__content-inner {
    width: 100%;
    margin-right: 0;
    padding-top: 20px;
  }
}
.service-block02__content-img {
  margin-bottom: 55px;
}
.service-block02__lead {
  font-size: 20px;
  color: #8ec174;
}
@media screen and (max-width: 767px) {
  .service-block02__lead {
    font-size: 15px;
  }
}
.service-block02__title {
  position: relative;
  top: -11px;
  left: -11px;
  margin-bottom: 7px;
  font-size: 48px;
  line-height: 1.46;
  color: #054429;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .service-block02__title {
    top: -6px;
    font-size: 36px;
  }
}
.service-block02__text p {
  font-size: 16px;
  line-height: 1.88;
}
@media screen and (max-width: 767px) {
  .service-block02__text p {
    font-size: 14px;
  }
}
.service-block02__img {
  position: relative;
  top: 0px;
  width: 57.7%;
}
@media screen and (max-width: 1050px) {
  .service-block02__img {
    width: 52%;
  }
}
@media screen and (max-width: 767px) {
  .service-block02__img {
    width: 100%;
  }
}
.service-block02__img > img {
  width: 100%;
  height: 520px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 750/520;
}
@media screen and (max-width: 767px) {
  .service-block02__img > img {
    height: auto;
    aspect-ratio: inherit;
  }
}

.service-block03 {
  padding: 144px 0 140px 0;
  background: url("../img/service-bg01.jpg") no-repeat 50% 50%;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .service-block03 {
    padding: 45px 0 55px 0;
  }
}
.service-block03__inner {
  gap: 20px;
}
.service-block03__item {
  width: calc(25% - 15px);
  color: #fff;
}
@media screen and (max-width: 1050px) {
  .service-block03__item {
    width: calc(50% - 10px);
  }
}
.service-block03__img {
  margin-bottom: 15px;
  text-align: center;
}
.service-block03__title {
  margin-bottom: 15px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  padding: 10px;
  color: #000;
}
@media screen and (max-width: 767px) {
  .service-block03__title {
    font-size: 16px;
  }
}
.service-block03__title > img {
  position: relative;
  top: -4px;
  left: -3px;
}
@media screen and (max-width: 767px) {
  .service-block03__title > img {
    width: 119px;
  }
}
.service-block03__text {
  font-size: 15px;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .service-block03__text {
    font-size: 12px;
    line-height: 1.5;
  }
}

/* carousel */
.img-carousel {
  padding: 120px 0 120px 0;
}
@media screen and (max-width: 767px) {
  .img-carousel {
    padding: 35px 0 35px 0;
  }
}
.img-carousel__list {
  padding: 0 10px;
}
@media screen and (max-width: 767px) {
  .img-carousel__list {
    padding: 0 5px;
  }
}

/* company */
@media screen and (max-width: 767px) {
  .company {
    padding: 20px 0 50px 0;
    background: url("../img/k-sp.png") no-repeat 50% 60px;
    background-size: cover;
  }
}
.company__heading {
  margin-bottom: 37px;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .company__heading {
    margin-bottom: 10px;
  }
}
.company__heading-lead {
  font-size: 20px;
  color: #8ec174;
  font-family: "Barlow", serif;
}
@media screen and (max-width: 767px) {
  .company__heading-lead {
    font-size: 16px;
  }
}
.company__heading-title {
  position: relative;
  top: -4px;
  left: -4px;
  font-size: 48px;
  font-weight: 400;
  color: #054429;
}
@media screen and (max-width: 767px) {
  .company__heading-title {
    font-size: 34px;
  }
}

.company-block01 {
  position: relative;
}
.company-block01__content {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 51%;
  padding: 36px 0 0 20px;
}
@media screen and (max-width: 1050px) {
  .company-block01__content {
    width: 55%;
  }
}
@media screen and (max-width: 767px) {
  .company-block01__content {
    width: 100%;
    padding: 0 20px;
  }
}
.company-block01__content-inner {
  width: 463px;
  margin-right: 99px;
}
@media screen and (max-width: 1050px) {
  .company-block01__content-inner {
    margin-right: 40px;
  }
}
@media screen and (max-width: 767px) {
  .company-block01__content-inner {
    width: 100%;
    margin-right: 0;
  }
}
.company-block01__list {
  display: flex;
  flex-wrap: wrap;
}
.company-block01__list dt {
  width: 135px;
  padding: 15px 0 13px 0;
  font-size: 18px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .company-block01__list dt {
    width: 100%;
    padding: 15px 0 0px 0;
    font-size: 13px;
  }
}
.company-block01__list dd {
  width: calc(100% - 135px);
  padding: 15px 0 13px 0;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .company-block01__list dd {
    width: 100%;
    padding: 0px 0 13px 0;
    font-size: 13px;
    line-height: 1.5;
  }
}
.company-block01__img {
  position: relative;
  top: 0px;
  width: 49%;
}
@media screen and (max-width: 1050px) {
  .company-block01__img {
    width: 45%;
  }
}
@media screen and (max-width: 767px) {
  .company-block01__img {
    display: none;
  }
}
.company-block01__img > img {
  width: 100%;
  height: 683px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 632/683;
}

/* map */
.map iframe {
  width: 100%;
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  .map iframe {
    height: 250px;
  }
}

/* contact */
.contact {
  padding: 80px 0 110px 0;
  background-color: #054429;
}
@media screen and (max-width: 767px) {
  .contact {
    padding: 35px 0 50px 0;
  }
}
.contact__heading {
  text-align: center;
  margin-bottom: 40px;
  line-height: 1.4;
}
.contact__heading-title {
  position: relative;
  font-size: 42px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
  font-family: "Barlow", serif;
}
@media screen and (max-width: 767px) {
  .contact__heading-title {
    font-size: 38px;
  }
}
.contact__heading-lead {
  font-size: 20px;
  color: #8ec174;
}
@media screen and (max-width: 767px) {
  .contact__heading-lead {
    font-size: 16px;
  }
}
.contact__form-wrap {
  padding: 40px 60px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .contact__form-wrap {
    padding: 20px;
  }
}

/* privacy policy */
.privacy-body .header__menu a {
  color: #000;
}

.privacy {
  padding-top: 200px;
}
.privacy h1 {
  margin-bottom: 5px;
  font-size: 30px;
}
.privacy h2 {
  margin-bottom: 5px;
  font-size: 24px;
}
.privacy p {
  margin-bottom: 20px;
}
.privacy p a {
  text-decoration: underline;
}
.privacy ul,
.privacy ol {
  margin-bottom: 20px;
}
.privacy ul li,
.privacy ol li {
  margin-bottom: 5px;
}
.privacy .list-none {
  list-style: none;
}
.privacy table td p {
  margin-bottom: 0;
}

/* Thanks */
.thanks-body .header__menu a {
  color: #000;
}

.thanks {
  padding-top: 200px;
}
.thanks h1 {
  margin-bottom: 5px;
  font-size: 30px;
}
.thanks h2 {
  margin-bottom: 5px;
  font-size: 24px;
}
.thanks p {
  margin-bottom: 20px;
}
.thanks p a {
  text-decoration: underline;
}