@charset "utf-8";
/* ---------------------------------------------------------------------------------------------

　   MV

--------------------------------------------------------------------------------------------- */
#mv {
  position: relative;
  overflow: hidden;
}
/* slider */
#mv .slide-media {
  position: relative;
  overflow: hidden;
}

#mv .slide-media img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
}

#mv .splide {
  z-index: 0;
  height: 100vh;
  height: 100svh;
  visibility: visible !important;
}


#mv .splide__slide:focus-visible {
  outline: 3px solid rgba(180, 233, 0, 0.8);
  outline-offset: 3px;
  z-index: 1;
  transition: none;
}

#mv .splide-wrapper {
  position: relative;
}


#mv .splide-fade .splide__slide {
  pointer-events: none;
}

#mv .splide__track--fade .splide__slide.is-active {
  pointer-events: auto;
}

#mv .slide-media img {
  transition: 7s 1s ease-out;
}

#mv .splide__slide[class*=-active] .slide-media img {
  transition-delay: 0s;
  transform: scale(1.05);
}
#mv_wrapper {
  padding: 0 10px;
}

.mv_copy_wrap {
  position: absolute;
  color: #fff;
  z-index: 2;
}
.mv_copy,
.mv_copy_en {
  font-weight: 600;
  letter-spacing: 0.1em;
  text-shadow: 0 0 .3em rgba(0, 0, 0, 1);
}

/* スクロールダウンの位置 */
.scroll {
  position: absolute;
  writing-mode: vertical-rl;
  bottom: 0;
  z-index: 2;
  color: #fff;
}
/* 線のアニメーション部分 */
.scroll::before {
  animation: scroll 2s infinite;
  background-color: #fff;
  bottom: 0;
  content: "";
  height: 100px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}
/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

@media only screen and ( max-width : 767px ) {
  #mv .slide-media img {
    width: 100%;
    height: calc(100vh - 55px);
  }

  #mv .splide {
    height: calc(100vh - 55px);
    height: calc(100svh - 55px);
  }
  .mv_copy_wrap {
    left: 3rem;
    top: 8rem;
  }
  .mv_copy {
    font-size: 4.2rem;
  }
  .mv_copy_en {
    font-size: 1.1rem;
    margin-top: 2.5rem;
  }
  .scroll {
    left: 3rem;
    padding-bottom: 11rem;
    font-size: 1.1rem;
  }
  .scroll::before {
    height: 9.5rem;
  }
}
@media print, screen and ( min-width : 768px ) {
  .mv_copy_wrap {
    left: 8.75vw;
    top: 13.67vw;
  }
  .mv_copy {
    font-size: 4.06vw;
  }
  .mv_copy_en {
    font-size: 1.25vw;
    margin-top: 1.95vw;
  }
  .scroll {
    left: 4.69vw;
    padding-bottom: 8.59vw;
    font-size: .86vw;
  }
  .scroll::before {
    height: 7.42vw;
  }
}

/* ---------------------------------------------------------------------------------------------

　   ABOUT

--------------------------------------------------------------------------------------------- */
#about {
  overflow: hidden;
}
#about .container {
  position: relative;
}
.about_map {
  position: absolute;
  z-index: 1;
}
.about_text {
  position: relative;
  z-index: 2;
}
#about .title_heading {
  position: relative;
}
#about .title_heading:after {
  content: "";
  display: block;
  width: 4.6rem;
  height: 1px;
  background: var(--mainColor);
  position: absolute;
  left: 0;
  bottom: 0;
}
#about .title_heading .title_jp {
  border-bottom: none;
  padding-bottom: 0;
}
.about_text_txt {
  line-height: 2.4em;
  letter-spacing: .1em;
}
@media only screen and ( max-width : 767px ) {
  #about .container {
    padding-top: 4rem;
  }
  #about .splide__slide {
    width: 15rem;
  }
  .about_map {
    top: 0;
    left: 0;
  }
  #about .title_heading {
    margin-bottom: 20rem;
    align-items: flex-start;
  }
  #about .title_heading img {
    width: 17rem;
  }
  #about .title_heading {
    padding-bottom: 3.4rem;
  }
  .about_text_txt {
    margin-bottom: 3.6rem;
  }
  #about .splide {
    margin-top: 3.6rem;
    position: relative;
    z-index: 2;
  }
}
@media print, screen and ( min-width : 768px ) {
  #about {
    height: 100.8rem;
  }
  #about .container {
    padding-top: 14rem;
    padding-bottom: 14rem;
  }
  .about_map {
    width: 199.2rem;
    top: -53.5rem;
    left: -36rem;
  }
  .about_text {
    width: 53rem;
  }
  #about .title_heading img {
    width: 42.8rem;
  }
  #about .title_heading {
    padding-bottom: 4.5rem;
  }
  .about_text_txt {
    margin-bottom: 4.5rem;
  }
  #about .splide__slide {
    width: 28.4rem;
  }
  #about .splide {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 2;
  }
}


/* ---------------------------------------------------------------------------------------------

　   SERVICE

--------------------------------------------------------------------------------------------- */
#service {
  background: #f7f3ec;
  position: relative;
}
#service .container {
  position: relative;
}
.service_wrap {
  position: relative;
}
#service .service_inner {
  background: #fff;
  clip-path: var(--clip);
  position: relative;
  z-index: 2;
}
#service .service_text {
  letter-spacing: .1em;
  text-align: justify;
}
.service_item {
  position: relative;
}
.service_item_img {
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  position: relative;
}
.service_item_img a {
  display: block;
}
.service_item_img a:after {
  content: "";
  width: 100%;
  height: 100%;
  background: #d7cebc;
  opacity: .3;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.service_item_num {
  position: relative;
}
.service_item_num img {
  display: block;
}
.service_item_num:after {
  content: "";
  background: var(--mainColor);
  opacity: .5;
  width: 1px;
  position: absolute;
  display: block;
  left: 0;
  bottom: 0;
}
.service_item h3 span {
  box-decoration-break: clone;  
  -webkit-box-decoration-break: clone;
  display: inline;
  padding: .1em .3em;
  line-height: 1.8;
  background-color: var(--mainColor);
  color: #fff;
  font-weight: 500;
}

.service_item:nth-child(2n) .service_item_num:after {
  left: auto;
  right: 0;
}
.service_item_inner {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
}
.service_item:nth-child(2n) .service_item_inner {
  right: 0;
  left: auto;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
@media only screen and ( max-width : 767px ) {
  #service {
    padding: 1.5rem;
  }
  #service .container {
    padding: 0 2rem;
  }
  .service_item_num {
    width: 6.8rem;
    padding-bottom: 5rem;
    margin-bottom: 1.5rem;
  }
  .service_item_num:after {
    height: 3rem;
  }
  .service_item_img {
    width: 27.6rem;
  }
  .service_item h3 {
    font-size: 2.04rem;
  }
  #service .service_inner {
    padding: 2.4rem 0;
  }
  #service .service_text {
    line-height: 1.8em;
    margin-bottom: 2.5rem;
  }
  .service_item:nth-child(odd) {
    display: flex;
    justify-content: flex-end;
  }
  .service_item:nth-child(even) h3 {
    text-align: right;
  }
  #service .btn {
    margin-top: 5rem;
  }
}
@media print, screen and ( min-width : 768px ) {
  #service {
    padding: 6.4rem 0;
  }
  #service .service_wrap:after {
    content: "";
    display: block;
    background: #ccc;
    z-index: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 5rem rgba(0, 0, 0, 0.6);
    width: 96%;
    height: 96%;
  }
  #service .service_text {
    line-height: 2.4em;
  }
  .service_wrap {
    width: 115.2rem;
    margin: 0 auto;
  }
  #service .service_inner {
    padding: 4.4rem 0 7.6rem;
  }
  #service .service_text {
    width: 50rem;
  }
  .service_list {
    padding: 0 2rem;
  }
  .service_list01 {
    margin-top: -11rem;
  }
  .service_list02 {
    margin-top: -10rem;
  }
  .service_item {
    width: 63rem;
  }
  .service_item:nth-child(even) {
    margin-left: var(--service_item_mgn);
    margin-top: 21.2rem;
  }
  .service_item:nth-child(odd) {
    margin-right: var(--service_item_mgn);
    display: flex;
    justify-content: flex-end;
  }
  .service_item_inner {
    top: 1.5rem;
  }
  .service_item_img {
    width: 59.6rem;
  }
  .service_item_num {
    width: 15rem;
    padding-bottom: 10rem;
    margin-bottom: 2rem;
  }
  .service_item_num:after {
    height: 8.2rem;
  }
  .service_item h3 {
    font-size: 2.7rem;
  }
  #service .btn {
    position: absolute;
    bottom: 0;
    left: 5rem;
  }
}
:root {
  --service_item_mgn: -14rem;
}

/* ---------------------------------------------------------------------------------------------

　   WORKS

--------------------------------------------------------------------------------------------- */
#works {
  color: #fff;
}
.works_inner {
  position: relative;
}
#works .title_en {
  background: #fff;
  color: var(--mainColor);
}
#works .title_heading .title_jp {
  border-bottom: 1px solid #fff;
}
#works .thumb-wrapper {
  display: flex;
  flex-wrap: wrap;
}
#works .splide__arrow svg {
  opacity: 0;
}
#works .splide__arrow {
  width: 3.6rem;
  height: 3.6rem;
  transform: translateY(0%);
  opacity: 1;
}
#works .splide__arrow:disabled {
  opacity: .6;
}
#works .splide__arrow--prev {
  background: url(../img/prev.png) no-repeat center / 100%;
  left: -1.8rem;
}
#works .splide__arrow--next {
  background: url(../img/next.png) no-repeat center / 100%;
  right: -1.8rem;
}
#works .thumb-wrapper .thumb-media {
  opacity: .6;
}
#works .thumb-wrapper .thumb-media.is-active {
  opacity: 1;
}
@media only screen and ( max-width : 767px ) {
  #works .thumb-wrapper {
    gap: 2%;
    margin-top: 3rem;
    margin-bottom: 4rem;
  }
  #works .thumb-wrapper .thumb-media {
    height: 3.8rem;
    width: 18.4%;
    margin-bottom: 2%;
  }
  #works .thumb-wrapper .thumb-media:last-child {
    margin-right: 0;
  }
  .works-media {
    height: 20rem;
  }
  #works .splide__arrow {
    top: 8.5rem;
  }
}
@media print, screen and ( min-width : 768px ) {
  .works_right {
    width: 60rem;
  }
  .works_left {
    width: 35rem;
  }
  #works .thumb-wrapper {
    width: 35rem;
    position: absolute;
    top: 23rem;
    left: 0;
  }
  .works-media {
    height: 37.6rem;
  }
  #works .splide__arrow {
    top: 17rem;
  }
  #works .thumb-wrapper {
    gap: 1rem;
  }
  #works .thumb-wrapper .thumb-media {
    width: 11rem;
    height: 7rem;
  }
}




/* ---------------------------------------------------------------------------------------------

　   RECRUIT

--------------------------------------------------------------------------------------------- */
#recruit {
  position: relative;
}
#recruit:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  width: 100%;
}
.recruit_wrap {
  position: relative;
}
.recruit_inner {
  background: #f7f3ec;
  position: relative;
  z-index: 2;
  clip-path: polygon(0 0, calc(100% - 20px) 0, 100% 20px, 100% 100%, 0 100%);
}
#recruit .recruit_wrap:before {
  content: "";
  background: url(../img/index/recruit_illust02.png) no-repeat right top / contain;
  position: absolute;
  bottom: 0;
  z-index: 3;
}
.recruit_inner:after {
  content: "";
  background: url(../img/index/recruit_illust.png) no-repeat right top / contain;
  position: absolute;
  bottom: 0;
}
#recruit .btn {
  background: #fff;
}
@media only screen and ( max-width : 767px ) {
  #recruit {
    background: url(../img/index/recruit_img_sp.jpg) no-repeat left top / 100%;
    padding-top: 18rem;
  }
  .recruit_wrap {
    margin-left: -3rem;
    margin-right: -3rem;
  }
  .recruit_inner {
    padding: 4rem 3rem 18rem;
  }
  #recruit .recruit_wrap:before {
    width: 14.4rem;
    height: 13.3rem;
    top: 2rem;
    left: 3rem;
  }
  #recruit .title_heading {
    margin-bottom: 6rem;
  }
  .recruit_text {
    line-height: 1.8em;
    margin-bottom: 3rem;
  }
  .recruit_inner:after {
    width: 27rem;
    height: 15rem;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media print, screen and ( min-width : 768px ) {
  #recruit {
    padding-top: 10rem;
    height: 42.34vw;
    max-height: 80rem;
    margin-bottom: 6rem;
  }
  #recruit:after  {
    background: url(../img/index/recruit_img.jpg) no-repeat right top / 100%;
    height: 42.34vw;
    max-height: 80rem;
  }
  #recruit .container {
    height: 100%;
    display: flex;
    align-items: flex-end;
  }
  #recruit .recruit_wrap {
    width: 69.5rem;
    margin-left: -13rem;
    margin-bottom: -6rem;
  }
  #recruit .recruit_wrap:before {
    width: 18rem;
    height: 16.7rem;
    top: -.5rem;
    left: 9rem;
  }
  #recruit .recruit_wrap:after {
    content: "";
    background: #f7f3ec;
    position: absolute;
    top: 0;
    width: 2000%;
    left: -2000%;
    height: 100%;
    z-index: 2;
  }
  .recruit_inner {
    padding: 5rem 13rem 8rem 8rem;
  }
  .recruit_inner:after {
    right: 1rem;
    width: 33.5rem;
    height: 18.6rem;
  }
  .recruit_text {
    line-height: 2.4em;
    margin-bottom: 3rem;
  }
}




/* ---------------------------------------------------------------------------------------------

　   NEWS

--------------------------------------------------------------------------------------------- */
#news {
  position: relative;
}
.tab-panel {
  position: relative;
}
#news .panel {
  display: none;
  position: relative;
  z-index: 2;
}
#news .panel.is-show {
  display: block;
}
#news .tab {
  background: var(--mainColor);
  color: #fff;
  border-radius: 3rem;
  padding: 0.5em 1em;
  line-height: 1.2em;
  letter-spacing: 0.1em;
  text-align: center;
  cursor: pointer;
}
#news .tab.is-active {
  opacity: .6;
}
.news_list li {
  border-bottom: 1px solid var(--mainColor);
}
.news_list li:last-child {
  border-bottom: none;
}
.news_list li a {
  display: flex;
  position: relative;
}
.news_list li .news_list_txt:after {
  content: "";
  position: absolute;
  width: 1.5rem;
  height: 1.5rem;;
  background: url(../img/arrow.png) no-repeat center / 100%;
}
.news_date {
  color: #b2bfc6;
}
#news .btn {
  background: #fff;
}
@media only screen and ( max-width : 767px ) {
}
@media print, screen and ( min-width : 768px ) {
  #news .title_heading {
    width: 28rem;
  }
  #news .btn {
    position: absolute;
    right: 0;
    top: -11.5rem;
  }
}

/* ---------------------------------------------------------------------------------------------

　   COPORATE

--------------------------------------------------------------------------------------------- */
#coporate {
  position: relative;
}
#coporate:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
}
#coporate .btn {
  background: #fff;
}
.coporate_inner {
  background: #f7f3ec;
  position: relative;
  z-index: 2;
  clip-path: polygon(20px 0, 100% 0, 100% 100%, 0 100%, 0 20px);
}
@media only screen and ( max-width : 767px ) {
  #coporate {
    background: url(../img/index/coporate_img_sp.jpg) no-repeat left top / 100%;
    padding-top: 20rem;
  }
  .coporate_wrap {
    margin-left: -3rem;
    margin-right: -3rem;
  }
  .coporate_inner {
    padding: 4rem 3rem;
  }
  .coporate_text {
    line-height: 1.8em;
    margin-bottom: 3rem;
  }
  #coporate .title_heading .title_jp {
    font-size: 2.2rem;
  }
}
@media print, screen and ( min-width : 768px ) {
  #coporate {
    padding-top: 10rem;
    height: 42.34vw;
    max-height: 80rem;
    margin-bottom: 6rem;
  }
  #coporate:after  {
    background: url(../img/index/coporate_img.jpg) no-repeat left center / 100%;
    height: 42.34vw;
    max-height: 80rem;
    width: 60%;
  }
  #coporate .container {
    height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
  }
  #coporate .title_heading .title_jp {
    font-size: 3.5rem;
  }
  .coporate_wrap {
    position: relative;
    width: 69.5rem;
    margin-right: -13rem;
    margin-bottom: -6rem;
  }
  #coporate .coporate_inner {
    padding: 5rem 8rem 10rem;
  }
  #coporate .coporate_wrap:after {
    content: "";
    background: #f7f3ec;
    position: absolute;
    top: 0;
    width: 2000%;
    right: -2000%;
    height: 100%;
    z-index: 2;
  }
  .coporate_img {
    width: 75.4rem;
    margin-right: -7rem;
    margin-left: -13rem;
  }
  .coporate_text {
    line-height: 2.4em;
    margin-bottom: 3rem;
  }
}



/* ---------------------------------------------------------------------------------------------

　   XXX

--------------------------------------------------------------------------------------------- */

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

