@charset "utf-8";
/* Kv
---------------------------------------------------------------------- */
.kv {
  max-width: 1436px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.kv .kv_inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding-top: 30px;
  padding-bottom: 227px;
}
.kv .txt_box {
  width: 100%;
  text-align: right;
}
.kv .txt_box h1 {
  font-family: "Noto Serif JP", serif;
  font-size: 56px;
  font-weight: 100;
  line-height: 1.14;
  margin: 0 0 25px;
}
.kv .txt_box .kv_lead {
  font-size: 14px;
  line-height: 2;
}
.kv .kv_img {
  position: absolute;
}
.kv .kv_img01 {
  width: 603px;
  top: 0;
  left: 0;
}
.kv .kv_img02 {
  width: 205px;
  top: 47px;
  left: 454px;
}
.kv .kv_img03 {
  width: 384px;
  top: 0;
  left: 578px;
}
.kv .kv_img04 {
  width: 308px;
  bottom: 20px;
  left: 561px;
}
.kv .kv_img05 {
  width: 575px;
  bottom: 0;
  left: 829px;
}
.kv .kv_img {
  overflow: hidden;
}
.kv-image {
  width: 100%;
  display: block;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.2s cubic-bezier(0.37, 0, 0.63, 1);
}
.kv-image.is-animated {
  clip-path: inset(0);
}

.kv .kv-image01 {
  transition-delay: 1.2s;
}
.kv .kv-image02 {
  transition-delay: 2.7s;
}
.kv .kv-image03 {
  transition-delay: 1.7s;
}
.kv .kv-image04 {
  transition-delay: 3.2s;
}
.kv .kv-image05 {
  transition-delay: 2.2s;
}
@media (max-width: 1436px)  and (min-width: 1301px) {
  .kv {
    max-width: 100%;
    width: 100%;
    overflow: hidden;
  }
  .kv .kv_inner {
    max-width: 1300px;
    width: 100%;
    margin: 0 8% 0 auto;
  }
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .kv {
    max-width: 100%;
    width: 1300px;
    overflow: hidden;
  }
  .kv .kv_inner {
    max-width: 100%;
    padding-top: 2.3077vw;
    padding-bottom: 19.4vw;
    padding-right: 6.9638vw;
  }
  .kv .txt_box h1 {
    font-size: 3.8997vw;
    margin: 0 0 1.9231vw;
  }
  .kv .txt_box .kv_lead {
    font-size: 0.9749vw;
  }
  .kv .kv_img01 {
    top: 0;
    left: -4.7354vw;
    width: 46.3846vw;
  }
  .kv .kv_img02 {
    top: 3.2730vw;
    width: 15.7692vw;
    left: calc(34.9231vw - 4.7354vw);
  }
  .kv .kv_img03 {
    top: 0;
    width: 29.5385vw;
    left: calc(44.4615vw - 4.7354vw);
  }
  .kv .kv_img04 {
    width: 23.6923vw;
    left: calc(43.1538vw - 4.7354vw);
    bottom: 1.5385vw;
  }
  .kv .kv_img05 {
    bottom: 0;
    width: 44.2308vw;
    left: calc(63.7692vw - 4.7354vw);
  }
}
@media screen and (max-width: 768px) {
  .kv {
    max-width: 100%;
    width: 100%;
    overflow: hidden;
  }
  .kv .kv_inner {
    max-width: 100%;
    padding-top: 71.3333vw;
    padding-bottom: 32.6667vw;
  }
  .kv .txt_box {
    width: 100%;
    text-align: center;
  }
  .kv .txt_box h1 {
    font-size: 8.1333vw;
    line-height: 1;
    margin: 0 0 4.6667vw;
  }
  .kv .txt_box .kv_lead {
    font-size: 2.8vw;
    line-height: 1.9;
  }
  .kv .kv_img {
    position: absolute;
  }
  .kv .kv_img01 {
    width: 72.1333vw;
    top: 0;
    left: -17.7333vw;
  }
  .kv .kv_img02 {
    width: 29.0667vw;
    top: 16vw;
    left: 40.4vw;
  }
  .kv .kv_img03 {
    width: 54.2667vw;
    top: 9.3333vw;
    left: auto;
    right: -12.1333vw;
  }
  .kv .kv_img04 {
    width: 39.6vw;
    bottom: 8.5333vw;
    left: -5.3333vw;
  }
  .kv .kv_img05 {
    width: 73.6vw;
    bottom: 0;
    left: auto;
    right: -5.0667vw;
  }
}





/* Common Title
---------------------------------------------------------------------- */
#top h3.tit_en {
  display: inline-block;
  font-family: cormorant-garamond, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 60px;
  color: #dcdcdc;
  line-height: 1;
  position: relative;
}
#top h3.tit_en::after {
  display: block;
  content: "";
  width: 20px;
  height: 1px;
  background: #ff6a21;
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
}
#top p.tit_jp {
  font-size: 1.125rem;
  line-height: 1;
  color: #000;
  margin-top: 18px;
}
.contant_inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}

#top .more_btn {
  width: 220px;
  height: 36px;
  border-radius: 20px;
  background: linear-gradient(to right, #ff9658, #f55b00);
  position: relative;
}
#top .more_btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
#top .more_btn span {
  font-size: 0.875rem;
  color: #fff;
}
#top .more_btn img {
  width: 5px;
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 1300px)  and (min-width: 769px) {
  #top h3.tit_en {
    font-size: 4.6154vw;
  }
}
@media screen and (max-width: 768px) {
  #top h3.tit_en {
    font-size: 10vw;
  }
  #top h3.tit_en::after {
    width: 3.3333vw;
    bottom: -5px;
  }
  #top p.tit_jp {
    font-size: 2.6667vw;
    margin-top: 3.3333vw;
  }
  #top .more_btn {
    width: 58.6667vw;
    height: 9.6vw;
    border-radius: 4.8vw;
  }
  #top .more_btn span {
    font-size: 3.2vw;
  }
  #top .more_btn img {
    width: 1.3333vw;
    right: 3.4667vw;
  }
}




/* Information
---------------------------------------------------------------------- */
.information {
  max-width: 1405px;
  width: 100%;
  margin: 80px auto;
}
.information .info_inner {
  display: flex;
  align-items: center;
}
.information .info_inner .tit_box {
  width: 340px;
  margin-left: 100px;
  text-align: left;
}
#top .information h3.tit_en::after {
  left: 0;
  transform: translateX(0);
}
#top .information .more_btn_pc {
  margin-top: 40px;
}
#top .information .more_btn_sp {
  display: none;
}
.information .info_inner .slider_wrap {
  width: 965px;
  overflow: hidden;
  position: relative;
}
.information .overflow-right__sliderWrap {
  width: 100%;
  box-sizing: border-box;
}
.information .splide__list {
  align-items: flex-start;
}
.information .splide__slide {
  aspect-ratio: 1/1;
  display: grid;
  place-content: center;
  text-align: left;
}
.information .slider_wrap img {
  width: 100%;
  display: block;
  border-radius: 8px;
  object-fit: cover;
}
.information .slider_wrap .txt_top {
  margin-top: 10px;
  margin-bottom: 10px;
}
.information .slider_wrap .txt_top time {
  font-size: 12px;
  color: #888888;
}
.information .slider_wrap .txt_top .cat {
  display: inline-block;
  font-size: 10px;
  color: #fff;
  border-radius: 2px;
  padding: 1px 6px 2px;
  box-sizing: border-box;
}
.information .slider_wrap .txt_top .press_release {
  background: #4aa8b9;
}
.information .slider_wrap .txt_top .recruit {
  background: #2471d9;
}
.information .slider_wrap .txt_top .topics {
  background: #eb2e7e;
}

.information .slider_wrap .txt_top .new_icon {
  font-size: 10px;
  color: #fff;
  padding: 1px 6px 2px;
  border-radius: 2px;
  box-sizing: border-box;
  border-radius: 2px;
  background: #f30061;
  display: none;
}

.information .slider_wrap .cont_txt {
  font-size: 14px;
  line-height: 1.75;
  display: -webkit-box;
  display: box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-clamp: 2;
  -webkit-line-clamp: 2;
}
.information .custom-pagination {
  position: relative;
  display: flex;
  justify-content: flex-end;
  gap: 5px;
  margin-top: 20px;
  margin-right: 115px;
}
.information .pagination-dot {
  width: 50px;
  height: 2px;
  background: #000;
  border: none;
  cursor: pointer;
  position: relative;
  z-index: 1;
}
.information .pagination-dot.active{
  background: #f37022;
  transition: transform 0.3s ease;
  z-index: 0;
}
.information .pagination-indicator {
  position: absolute;
  bottom: 0;
  height: 2px;
  width: 50px;
  background-color: #f37022;
  transition: transform 0.3s ease;
  z-index: 2;
  display: none;
}


.slider-toggle-btn {
  width: 14px;
  height: 14px;
  font-size: 6px;
  line-height: 1;
  color: #fff;
  background: #000;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: -5px;
}
.slider-toggle-btn.paused {
  font-size: 10px;
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .information .info_inner {
    overflow: hidden;
  }
  .information .info_inner .tit_box {
    width: 26.1538vw;
    margin-left: 2%;
    margin-bottom: 30px;
  }
  .information .info_inner .slider_wrap {
    width: 74.2308vw;
    margin-left: 5%;
  }
}
@media screen and (max-width: 768px) {
  .information {
    max-width: 100%;
    margin: 8vw auto 13.3333vw;
  }
  .information .info_inner {
    flex-direction: column;
    width: 100vw;
    padding-left: 5.3333vw;
    box-sizing: border-box;
  }
  .information .info_inner .tit_box {
    width: 100%;
    margin-left: 0;
  }
  #top .information .more_btn_pc {
    display: none;
  }
  #top .information .more_btn_sp {
    display: block;
  }
  .information .info_inner .slider_wrap {
    width: 94.6667vw;
    margin-left: 0;
    margin-top: 8vw;
    margin-bottom: 8vw;
  }
  .information .slider_wrap .txt_top {
    margin-top: 2.6667vw;
    margin-bottom: 1.3333vw;
  }
  .information .slider_wrap .txt_top time {
    font-size: 2.8vw;
  }
  .information .slider_wrap .txt_top .cat {
    font-size: 2.4vw;
    padding: 1px 6px 2px;
  }
  .information .slider_wrap .txt_top .new_icon {
    font-size: 2.4vw;
    padding: 1px 6px 2px;
  }

  .information .slider_wrap .cont_txt {
    font-size: 3.2vw;
    line-height: 1.5;
    width: 70.6667vw;
    height: 8.6667vw;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
    text-overflow: ellipsis;
  }
  .information .custom-pagination {
    justify-content: center;
    margin-top: 6.6667vw;
    margin-right: 0;
  }
  .information .pagination-dot {
    width: 6.6667vw;
  }
  .information .pagination-indicator {
    display: none;
  }
}




/* 企業情報はこちら
---------------------------------------------------------------------- */
.company {
  padding: 100px 0;
  background: #ddd url('../img/top/company_bg_pc.jpg') no-repeat;
  background-position: center 70%;
  background-size: cover;
}
.company .tit_box {
  width: 540px;
  margin: 0 0 0 auto;
  text-align: left;
}
.company .tit_box h3 {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 36px;
  color: #000000;
  line-height: 1;
  margin-bottom: 30px;
}
.company .tit_box p {
  font-size: 16px;
  color: #000000;
  line-height: 1.75;
}
.company .more_btn {
  margin: 50px 0 0 auto;
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .company .tit_box {
    margin: 0 2% 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .company {
    padding: 49.3333vw 0 10.6667vw;
    background: #ddd url('../img/top/company_bg_sp.jpg') no-repeat;
    background-position: center;
    background-size: cover;
  }
  .company .tit_box {
    width: 89.6vw;
    margin: 0 5.3333vw 0 auto;
  }
  .company .tit_box h3 {
    font-size: 6.6667vw;
    margin-bottom: 6.6667vw;
    text-align: right;
  }
  .company .tit_box p {
    width: 52vw;
    margin: 0 0 0 auto;
    font-size: 3.2vw;
  }
  .company .tit_box p.txt span {
    display: none;
  }
  .company .more_btn {
    margin: 22vw auto 0;
  }
}




/* Case Study
---------------------------------------------------------------------- */
.case {
  padding-top: 195px;
  padding-bottom: 330px;
  max-width: 1630px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}
.image-wrap {
  max-width: 300px;
  width: 100%;
  height: auto;
  overflow: hidden;
  transform: rotate(45deg);
  position: absolute;
}
.image-wrap01 {
  right: 575px;
  top: -200px;
}
.image-wrap02 {
  right: 380px;
  top: -112px;
}
.image-wrap03 {
  right: 65px;
  top: 203px;
}
.smooth-image {
  width: 100%;
  display: block;
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.2s cubic-bezier(0.37, 0, 0.63, 1);
}
.smooth-image.show {
  clip-path: inset(0);
}
.smooth02 {
  transition-delay: 0.0s;
}
.smooth01 {
  transition-delay: 0.2s;
}
.smooth03 {
  transition-delay: 0.4s;
}

.case .tit_box {
  width: 470px;
  text-align: left;
}
.case .tit_box.fade-up.show {
  transition-delay: 1.5s;
}

#top .case h3.tit_en::after {
  left: 0;
  transform: translateX(0);
}
.case .tit_box p.txt {
  font-size: 16px;
  line-height: 1.75;
  margin-top: 15px;
  margin-bottom: 40px;
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .case {
    padding-top: 15vw;
    padding-bottom: 23.0769vw;
    max-width: 100%;
    width: 100%;
  }
  .image-wrap {
    max-width: 23.0769vw;
  }
  .image-wrap01 {
    right: 30vw;
    top: -15.3846vw;
  }
  .image-wrap02 {
    right: 15vw;
    top: -8.6154vw;
  }
  .image-wrap03 {
    right: -9vw;
    top: 15.6154vw;
  }
  .case .tit_box {
    margin-left: 2%;
  }
}
@media screen and (max-width: 768px) {
  .case {
    padding-left: 5.3333vw;
    padding-right: 5.3333vw;
    padding-top: 30vw;
    padding-bottom: 52vw;
    max-width: 100%;
  }
  .image-wrap {
    max-width: 100%;
    width: 32.9333vw;
  }
  .image-wrap01 {
    right: 3vw;
    top: -22vw;
  }
  .image-wrap02 {
    right: -11vw;
    top: -5vw;
  }
  .image-wrap03 {
    right: -12vw;
    top: 63.5vw;
  }
  .case .tit_box {
    width: 100%;
  }
  .case .tit_box p.txt {
    width: 49.3333vw;
    font-size: 3.2vw;
    margin-top: 6.6667vw;
    margin-bottom: 0;
  }
  .case .more_btn {
    margin: 22vw auto 0;
  }

}







/* Our Properties
---------------------------------------------------------------------- */
.searvice {
  width: 100%;
  margin: 0 auto;
  position: relative;
  background: #ddd url('../img/top/our_bg.jpg') no-repeat;
  background-position: center bottom;
  background-size: cover;
}
.searvice_map {
  max-width: 1800px;
  width: 100%;
  margin: 0 auto;
  padding-right: 332px;
}
.searvice_inner {
  max-width: 1800px;
  width: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.searvice_inner .tit_box {
  position: absolute;
  top: -175px;
  left: 50%;
  transform: translateX(-50%);
}
.searvice_inner .tit_box .txt {
  display: inline-block;
  font-size: 16px;
  line-height: 1.75;
  padding: 25px 50px;
  background: #fff;
}
.searvice_inner ul.work_list {
  width: 878px;
  margin: 154px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 22px;
}
.searvice_inner ul.work_list li {
  width: 128px;
}

.searvice_inner ul.work_list li:nth-child(1) {
  transition-delay: 0s;
}
.searvice_inner ul.work_list li:nth-child(2) {
  transition-delay: 0.2s;
}
.searvice_inner ul.work_list li:nth-child(3) {
  transition-delay: 0.4s;
}

.searvice_inner ul.work_list li:nth-child(4) {
  transition-delay: 0.6s;
}
.searvice_inner ul.work_list li:nth-child(5) {
  transition-delay: 0.8s;
}
.searvice_inner ul.work_list li:nth-child(6) {
  transition-delay: 1s;
}

.searvice_inner .more_btn {
  position: absolute;
  top: 467px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 1800px)  and (min-width: 769px) {
  .searvice_map {
    padding-right: 18.4444vw;
  }
  .searvice_inner .tit_box {
    top: -9.7222vw;
  }
  .searvice_inner .tit_box .txt {
    font-size: 0.8889vw;
    padding: 1.3889vw 2.7778vw;
  }
  .searvice_inner ul.work_list {
    width: 48.7778vw;
    margin-top: 8.5556vw;
    gap: 1.2222vw;
  }
  .searvice_inner ul.work_list li {
    width: 7.1111vw;
  }
  .searvice_inner .more_btn {
    top: 25.9444vw;
  }
}
@media screen and (max-width: 768px) {
  .searvice {
    background: none;
  }
  .searvice_map {
    max-width: 100%;
    padding-right: 0;
  }
  .searvice_inner {
    max-width: 100%;
  }
  .searvice_inner .tit_box {
    top: -37.3333vw;
  }
  .searvice_inner .tit_box .txt {
    width: 89.3333vw;
    font-size: 3.2vw;
    line-height: 2;
    text-align: left;
    padding: 5.3333vw 4vw;
    border-radius: 5px;
  }
  .searvice_inner ul.work_list {
    width: 100%;
    margin-top: 20.2667vw;
    margin-left: 0;
    gap: 4.9333vw;
    justify-content: center;
    position: absolute;
  }
  .searvice_inner ul.work_list li {
    width: 23.3333vw;
  }
  .searvice_inner .more_btn {
    top: 59.3333vw;
  }
}




/* Recruite
---------------------------------------------------------------------- */
.recruit {
  max-width: 1100px;
  width: 100%;
  margin: 80px auto 0;
  position: relative;
}
.recruit .tit_box {
  position: absolute;
  top: 195px;
  left: 50%;
  transform: translateX(-50%);
}
.recruit .more_btn {
  margin: 30px auto 0;
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .recruit {
    padding: 0 2%;
  }
  .recruit .tit_box {
    top: 15vw;
  }
}
@media screen and (max-width: 768px) {
  .recruit {
    width: 89.3333vw;
    margin: 10.6667vw auto 0;
    padding: 0;
  }
  .recruit .tit_box {
    top: 36.6667vw;
  }
  .recruit .more_btn {
    margin: 18vw auto 0;
  }
}

#top .recruit h3.tit_en,
#top .recruit p.tit_jp,
#top .contact_btn_box h3.tit_en,
#top .contact_btn_box p.tit_jp {
  text-shadow: -1px 1.73px 2px rgba(0, 0, 0, 0.5);
  color: #fff;
}
#top .recruit p.tit_jp,
#top .contact_btn_box p.tit_jp {
  font-size: 1rem;
}
@media screen and (max-width: 768px) {
  #top .recruit p.tit_jp,
  #top .contact_btn_box p.tit_jp {
    font-size: 2.6667vw;
  }
}

/* Contact Us
---------------------------------------------------------------------- */
.contact_btn_box {
  width: 540px;
  height: 140px;
  border-radius: 4px;
  margin: 80px auto;
  background: #ddd url('../img/top/contact_img.png') no-repeat;
  background-size: cover;
  position: relative;
}
.contact_btn_box a {
  display: block;
  width: 100%;
  height: 100%;
  padding-top: 13px;
}
.contact_btn_box .arrow_img {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background: linear-gradient(to right, #ff9658, #f55b00);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}
.contact_btn_box .arrow_img img {
  width: 5px;
}
@media screen and (max-width: 768px) {
  .contact_btn_box {
    width: 89.3333vw;
    height: 23.2vw;
    margin: 10.6667vw auto;
  }
  .contact_btn_box a {
    padding-top: 2vw;
  }
  .contact_btn_box .arrow_img {
    width: 5.8667vw;
    height: 5.8667vw;
    right: 3.2vw;
  }
  .contact_btn_box .arrow_img img {
    width: 0.8vw;
  }
}

/* banner
---------------------------------------------------------------------- */
.ft_bnr {
  width: 100%;
  background: #ddd url('../img/top/ft_bnr_bg.jpg') no-repeat;
  background-size: cover;
  background-position: center;
  padding: 80px 0;
}
.ft_bnr .flex_box {
  justify-content: center;
  gap: 20px;
}
.ft_bnr .bnr_top li {
  width: 520px;
}
.ft_bnr .bnr_bt {
  margin-top: 20px;
}
.ft_bnr .bnr_bt li {
  width: 340px;
}
@media (max-width: 1300px)  and (min-width: 769px) {
  .ft_bnr {
    padding: 6.1538vw 2%;
  }
  .ft_bnr .bnr_top li {
    width: 40vw;
  }
  .ft_bnr .bnr_bt li {
    width: 26.1538vw;
  }
}
@media screen and (max-width: 768px) {
  .ft_bnr {
    padding: 10.6667vw 0;
  }
  .ft_bnr .cont_inner {
    width: 89.3333vw;
  }
  .ft_bnr .flex_box {
    flex-wrap: wrap;
    gap: 0;
  }
  .ft_bnr .bnr_top li {
    width: 100%;
  }
  .ft_bnr .bnr_top li {
    margin-bottom: 2.6667vw;
  }
  .ft_bnr .bnr_bt {
    margin-top: 0;
    justify-content: space-between;
  }
  .ft_bnr .bnr_bt li {
    width: 43.3333vw;
  }
}