@charset "UTF-8";

.mainVisual_wrap {
  width: 100%;
  position: relative;
  overflow: hidden;
}

.mainVisual_wrap .coppyWrap {
  margin-top: 30px;
}

.mainVisual_wrap .subCopy {
  font-size: 3.25rem;
  letter-spacing: 0.017em;
}

.mainVisual_wrap .mainCopy {
  position: absolute;
  top: 0;
  right: 23px;
  width: auto;
  height: 12.85em;
  padding: 15px 46px;
  writing-mode: vertical-rl;
  font-size: 2.6rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.22em;
  line-height: 1.75;
  background: #fff;
  z-index: 2;
}

.mainVisual_wrap .swiper {
  width: 100%;
  height: 100%;
}

.mainVisual_wrap .infinite-slider .swiper-wrapper {
  transition-timing-function: linear;
}

.infinite-slider .swiper-wrapper .swiper-slide {
  width: 80%;
  height: 80%;
  max-height: 900px;
}

.bgBlue {
  padding-top: 50px;
  padding-bottom: 50px;
}

.btnWrap,
.btnWrap p {
  font-size: 1.25rem;
}

.workWrap {
  margin-top: 30px;
  margin-bottom: 0px;
  position: relative;
  background: url(../img/work/bg_img.jpg) no-repeat center center;
  background-size: cover;
}

.workWrap .inner {
  padding: 30px 60px;
}

.workWrap .txtWrap {
  width: 65%;
  margin-bottom: var(--inner-padding-LR);
  margin-left: auto;
}

.workWrap .txtWrap .txtBox {
  line-height: 2.15;
}

.workWrap .txtWrap .titleWrap .ff_en1 {
  color: var(--col-blue04);
  font-weight: 200;
  font-size: 2.95rem;
  letter-spacing: 0;
}

.workWrap .txtWrap .titleWrap .title {
  font-size: 1.65rem;
  font-weight: var(--font-weight-bold);
}

.workWrap .txtWrap .titleWrap .title {
  font-size: 2.45rem;
  letter-spacing: 0.075em;
}

.workWrap .btnWrap {
  width: fit-content;
}

.workWrap .btnWrap a {
  margin-left: 0;
}

.workWrap .btnWrap {
  margin: 0.85em 0 0.5em;
}

.workWrap .btnWrap p {
  font-size: 1.8rem;
}


.workWrap .column3 {
  filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.25));
  transform: translateZ(0);
  will-change: filter;

}

hgroup {
  font-weight: var(--font-weight-bold);
}


.btnWrap.mlAuto {
  width: fit-content;
  margin-left: auto;
}

section {
  margin-top: 80px;
  margin-bottom: 120px;
}

.wideLR .txtBox {
  line-height: 2.25;
}

.wideLR .column2 {
  position: relative;
  flex-direction: row-reverse;
  /* width: calc(((100% - (var(--inner-maxWidth))) / 2) + var(--inner-maxWidth));
  padding-left: var(--inner-padding-LR); */
  margin-left: auto;
  flex-wrap: nowrap;
}

.wideLR .column2>* {
  width: 50%;
}

.wideLR .column2+.column2 {
  margin-top: 60px;
}

.wideLR .column2 .imgBox {
  position: relative;
}

.wideLR .column2 .imgBox picture {
  position: absolute;
}

.wideLR .column2 .imgBox picture,
.wideLR .column2 .imgBox picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wideLR .column2 .imgBox .subCopy {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  text-align: center;
  font-size: 2.5rem;
  font-family: var(--font-family-poppins);
  color: #fff;
  letter-spacing: 0;
}

.wideLR .column2 .txtWrap {
  width: 50%;
  max-width: var(--inner-maxWidth);
  margin: 0;
  padding: 40px var(--inner-padding-LR);
  background: #fff;
}

.wideLR .column2 .contentTitleWrap {
  font-weight: 600;
}

.wideLR .column2 .messageTittle {
  font-size: 1.45rem;
  margin: 30px 0;
}

.wideLR .column2 p+p {
  margin-top: 1.25em;
}

.wideLR .column2:nth-child(even) .imgBox {
  margin-right: auto;
  margin-left: 0;
}



.contentTitleWrap .tittle {
  font-size: 1.15rem;
  margin-bottom: 1.5em;
  line-height: 1.3;
}

.contentTitleWrap .mainCopy {
  font-size: 2rem;
  line-height: 1.5;
  margin-bottom: 1.15em;
}


.business_wrap {
  position: relative;
}

.business_wrap dl {
  position: relative;
  width: 40%;
  z-index: 2;
}

.business_wrap dl dt {
  font-size: 2.2rem;
  color: var(--col-blue00);
}

.business_wrap dl dd {
  font-size: 1.35rem;
}

.business_wrap dl dd+dt {
  margin-top: 1em;
  padding-top: 1em;
  border-top: 1px solid #BDBDBD;
}

.business_wrap .imgBox {
  position: absolute;
  width: 60%;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
  z-index: 1;
}

.wellnessWrap {
  margin: 50px auto;
  padding-top: 50px;
  padding-bottom: 50px;
}

.wellnessWrap .contentTitleWrap .mainCopy {
  margin-bottom: 0;
}

.wellnessWrap .contentTitleWrap p {
  margin: 20px 0;
}

.wellnessWrap .subTittle {
  color: var(--col-blue04);
  font-size: 1.75rem;
}

.wellnessWrap .mainTittle {
  font-size: 2rem;
}

.wellnessWrap .txtBox {
  margin: 20px 0 0;
}

.wellnessWrap .txtBox .mainTittle {
  font-size: 1.15rem;
  font-weight: 600;
  margin: .85em 0;
}

.business_img {
  text-align: center;
}

.business_img img {
  max-width: 800px;
  margin: 50px auto 0;
}

@media only screen and (min-width: 768px) and (max-width: 1163px) {
  .workWrap {
    background-size: 1800px;
  }

  .mainVisual_wrap .subCopy {
    font-size: 3rem;
  }

}

@media only screen and (min-width: 768px) and (max-width: 959px) {}

/*==========================================================================================
ここからSP
==========================================================================================*/

@media only screen and (max-width: 767px) {
  .contentTitleWrap .mainCopy {
    font-size: 5.5vw;
  }

  .mainVisual_wrap .subCopy {
    font-size: 6.2vw;
  }

  .mainVisual_wrap .mainCopy {
    right: 4vw;
    height: 12.75em;
    padding: 4vw;
    font-size: 6.75vw;
    letter-spacing: 0.2em;
    line-height: 1.45;
  }

  .mainVisual_wrap .infinite-slider .swiper-slide,
  .mainVisual_wrap .infinite-slider .swiper-slide img {
    width: 230vw;
  }

  section {
    margin-top: 10vw;
    margin-bottom: 12vw;
  }

  .workWrap {
    margin-top: 10vw;
    margin-bottom: 5vw;
    background: url(../img/work/bg_img_sp.jpg) no-repeat top center;
    background-size: 100vw;
  }

  .workWrap .inner {
    padding: 30px 20px;
  }

  .workWrap .txtWrap {
    width: 55%;
    padding: 0;
  }

  .workWrap .txtWrap .titleWrap .ff_en1 {
    font-size: 6vw;
  }

  .workWrap .btnWrap {
    flex-wrap: wrap;
  }

  .workWrap .btnWrap a {
    margin-top: 0.5em;
    margin-left: 0;
  }

  .workWrap .column3 {
    margin-top: 8vw;
  }

  .workWrap .column3>*+* {
    margin-top: 5vw;
  }

  .workWrap .txtWrap .titleWrap .title {
    font-size: 1.5rem;
    padding-bottom: 50px;
  }

  .wideLR .column2 {
    width: 100%;
    padding: 0;
    flex-direction: column;
    flex-wrap: wrap;
  }

  .wideLR .column2>* {
    width: 100%;
  }

  .wideLR .column2 .imgBox,
  .wideLR .column2 .imgBox picture,
  .wideLR .column2 .imgBox picture img {
    position: relative;
    width: 100%;
    height: auto;
  }

  .wideLR .column2 .txtWrap {
    width: 100%;
  }

  .business_wrap dl {
    width: 100%;
    margin-bottom: 6vw;
  }

  .business_wrap dl dt {
    font-size: 5vw;
  }

  .business_wrap .imgBox {
    position: relative;
    width: 100%;
    top: 0;
    right: 0;
    transform: translate(0, 0%);
  }

  .business_wrap dl dd {
    font-size: 3.75vw;
  }

  .wellnessWrap {
    margin: 0px auto;
    padding-top: 0px;
    padding-bottom: 0vw;
    background: none;
  }

  .wellnessWrap .column2>*+* {
    margin-top: 8vw;
  }
}