@charset "UTF-8";

/* project1Wrap
***************************************************************/
.project1Wrap {
  position: relative;
  overflow: hidden;
  background-color: #fafafa;
  margin-top: 150px;
  padding: 120px 0 150px;
}
.project1_inner {
  position: relative;
  z-index: 1;
}
.project_titBox1 {
  width: 1150px;
  margin: 0 auto;
  display: flex;
}
.project_titBox1_tit1 {
  font-size: 39px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.4;
  width: 463px;
}
.project_titBox1_txt1 {
  font-size: 16px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0.05em;
  line-height: 1.88;
  width: calc(100% - 463px);
}

.project1_slideWrap {
  padding-top: 40px;
  margin-left: calc((100% - 1150px) / 2);
  padding-bottom: 70px;
  position: relative;
}
.project1_slide1_item {
  width: 363px;
  height: 505px;
  margin: 0 15px;
  overflow: hidden;
  border-radius: 5px;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  position: relative;
}
.project1_slide1_img {
  width: 100%;
  height: 100%;
  background: no-repeat center / cover;
}
.project1_slide1_textBox1 {
  position: absolute;
  bottom: 22px;
  left: 20px;
  z-index: 1;
  color: #fff;
}
.project1_slide1_textBox1_t1 {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.7;
}
.project1_slide1_textBox1_t2 {
  margin-top: 8px;
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.52;
}
@media all and (min-width: 681px) {
  .project1_slideWrap .work_slide1_custom {
    bottom: 5px;
    left: 5px;
  }
}
@media all and (max-width: 680px) {
  .project1Wrap {
    margin-top: 60px;
    padding: 60px 0;
  }
  .project_titBox1 {
    width: 100%;
    padding: 0 30px;
    display: block;
  }
  .project_titBox1_tit1 {
    font-size: 26px;
    width: 100%;
  }
  .project_titBox1_txt1 {
    font-size: 14px;
    line-height: 1.71;
    width: 100%;
    margin-top: 16px;
  }

  .project1_slideWrap {
    padding-top: 30px;
    margin-left: 0;
    padding-bottom: 0;
  }
  .project1_slide1_item {
    width: 268px;
    height: 373px;
    margin: 0 7.5px;
  }
  .project1_slide1_textBox1_t2 {
    font-size: 24px;
  }
}
@media all and (max-width: 370px) {
}

/* p1_gallery
***************************************************************/
.p1_gallery {
  margin-top: 175px;
  overflow: hidden;
}
.p1_gallery + .p1_gallery {
  margin-top: 0;
}
.p1_gallery_titBox1 {
  position: relative;
}
.p1_gallery_tit1 {
  width: auto;
  margin: 0 25px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1;
  display: flex;
  align-items: center;
  padding-left: 25px;
}
.p1_gallery_tit1::before {
  content: "";
  width: 17.67px;
  height: 17.67px;
  background: url(../img/common/ico_circle1.svg) no-repeat center / contain;
  position: absolute;
  top: 6px;
  bottom: 0;
  left: 0;
  margin: auto;
}
.p1_gallery_eng {
  font-size: 150px;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
  color: #f5f5f5;
  white-space: nowrap; /* 改行を禁止 */
  overflow: hidden; /* はみ出た部分を非表示 */
}
.relay_img {
  position: relative;
  top: -24px;
  margin-bottom: -24px;
  overflow: hidden;
  width: 100%;
}
.relay_img .img {
  display: flex;
  width: fit-content;
}
.relay_img1 .img,
.relay_img3 .img,
.relay_img5 .img {
  animation: scroll-left 40s linear infinite;
}
.relay_img2 .img,
.relay_img4 .img {
  flex-flow: row-reverse;
  animation: scroll-right 40s linear infinite;
}

.relay_img img {
  max-width: none;
  margin-right: 20px;
}
.relay_img1 img {
  width: 3790px;
}
.relay_img2 img {
  width: 3790px;
}
.relay_img3 img {
  width: 4040px;
}
.relay_img4 img {
  width: 3260px;
}
.relay_img5 img {
  width: 3585px;
}
@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes scroll-right {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(50%);
  }
}
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
  .p1_gallery {
    margin-top: 60px;
  }
  .p1_gallery + .p1_gallery {
    margin-top: 30px;
  }
  .p1_gallery_tit1 {
    width: calc(100% - 60px);
    margin: auto;
    font-size: 22px;
    bottom: 20px;
  }
  .p1_gallery_eng {
    font-size: 56px;
    letter-spacing: 0.03em;
  }
  .relay_img {
    top: -18px;
    margin-bottom: -18px;
  }
  .relay_img1 img {
    width: calc(3790px * 0.7);
  }
  .relay_img2 img {
    width: calc(3790px * 0.7);
  }
  .relay_img3 img {
    width: calc(4040px * 0.7);
  }
  .relay_img4 img {
    width: calc(3260px * 0.7);
  }
  .relay_img5 img {
    width: calc(3585px * 0.7);
  }
}
@media all and (max-width: 370px) {
}

/* project2Wrap
***************************************************************/
.project2Wrap {
  position: relative;
  overflow: hidden;
  padding: 120px 0;
}
.project2_inner {
  position: relative;
  z-index: 1;
}
.point_list1 {
  padding-top: 40px;
  display: flex;
  justify-content: center;
  gap: 0 35px;
}
.point_list1 .li1 {
  width: 360px;
}
.point_list1_thumb {
  width: 100%;
  height: 240px;
  overflow: hidden;
  border-radius: 5px;
}
.point_list1_thumb img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.point_list1_tit {
  font-size: 22px;
  font-weight: 500;
  text-align: justify;
  letter-spacing: 0.1em;
  line-height: 1.4;
  margin-top: 15px;
}
.point_list1_txt {
  font-size: 15px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0.05em;
  line-height: 2;
  margin-top: 10px;
}
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
  .project2Wrap {
    padding: 60px 0;
  }
  .point_list1 {
    padding: 50px 30px 0;
    display: block;
  }
  .point_list1 .li1 {
    width: 100%;
  }
  .point_list1 .li1:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  .point_list1_thumb {
    width: 100%;
    height: 48vw;
  }
  .point_list1_tit {
    font-size: 20px;
    text-align: center;
    margin-top: 10px;
  }
  .point_list1_txt {
    font-size: 13px;
    letter-spacing: 0;
    line-height: 1.69;
    margin-top: 5px;
  }
}
@media all and (max-width: 370px) {
}

/* コンテンツ
***************************************************************/
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
}
@media all and (max-width: 370px) {
}

/* コンテンツ
***************************************************************/
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
}
@media all and (max-width: 370px) {
}
