@charset "UTF-8";

/* ==========================================================================
  our_jobs.css
========================================================================== */

.our-jobs {
  padding: 80px 0 50px;
}

.our-jobs .anchor__list {
  margin-bottom: 75px;
}

.our-jobs .content__box {
  padding-bottom: 25px;
}

.our-jobs .box__titlebox {
  position: relative;
  margin-bottom: 75px;
}

.our-jobs .box__titlebox img {
  width: 100%;
}

.our-jobs .box__title:not(#box04 .box__title) {
  position: absolute;
  bottom: 0;
  color: #fff;
  margin: 0;
  width: 100%;
}

.our-jobs #box04 .box__title {
  margin-bottom: 20px;
}

.our-jobs .box__title span {
  max-width: 900px;
}

.our-jobs .box__item {
  max-width: 940px;
  margin: 0 auto 50px;
  padding: 0 20px;
}

.our-jobs .box__body-title {
  font-size: 2rem;
  line-height: 2;
  letter-spacing: 1px;
}

.our-jobs .table__row {
  padding: 40px 0;
}

.our-jobs .table__row:first-of-type:not(#box04 .table__row:first-of-type) {
  border-top: 1px solid #4d4d5c;
}

.our-jobs #box04 .table__row {
  flex-direction: column;
}

.our-jobs .table__label {
  border-right: none;
  justify-content: flex-start;
  align-items: flex-start;
  width: 200px;
}

.our-jobs #box04 .table__label {
  margin-bottom: 15px;
  width: 100%;
}

.our-jobs .table__data {
  padding-left: 0;
}

.our-jobs .table__data a:not(.interview a) {
  color: var(--color-navy);
  margin-left: 9.2%;
  position: relative;
}

.our-jobs .table__data a:not(.interview a)::before,
.our-jobs .table__data a:not(.interview a)::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  left: -20px;
  width: 10px;
  height: 2px;
  background: #333;
  transform-origin: calc(100% - 1px) 50%;
}

.our-jobs .table__data a:not(.interview a)::before {
  transform: rotate(45deg);
}

.our-jobs .table__data a:not(.interview a)::after {
  transform: rotate(-45deg);
}

.our-jobs .table__data a:not(.interview a):hover {
  opacity: 0.5;
}

.our-jobs .table__data.interview a {
  max-width: 600px;
  margin-left: auto;
  display: block;
}

.our-jobs .table__data.interview a:hover {
  opacity: 0.5;
}

@media screen and (max-width: 768px) {
  .our-jobs {
    padding: 20px 0 0;
  }

  .our-jobs .anchor__list {
    margin-bottom: 30px;
  }

  .our-jobs .content__box {
    padding-bottom: 10px;
    margin-bottom: 50px;
  }

  .our-jobs .box__titlebox {
    margin-bottom: 25px;
  }

  .our-jobs #box04 .box__title {
    margin-bottom: 5px;
  }

  .our-jobs .box__title span {
    font-size: 1.9rem;
    letter-spacing: 1px;
    max-width: 100%;
  }

  .our-jobs #box04 .box__title span {
    font-size: 1.6rem;
  }

  .our-jobs .box__item {
    max-width: 100%;
    margin: 0 auto 25px;
  }

  .our-jobs .box__body-title {
    font-size: 1.5rem;
    line-height: 1.8;
    letter-spacing: 0;
  }

  .our-jobs .table__row {
    flex-direction: column;
    gap: 10px;
    padding: 15px 0 25px;
  }

  .our-jobs .table__label {
    font-size: 1.5rem;
    width: 100%;
  }

  .our-jobs #box04 .table__label {
    margin-bottom: 0;
    width: 100%;
  }

  .our-jobs .table__data a:not(.interview a):last-of-type {
    display: inline-block;
    margin-top: 5px;
  }

  .our-jobs .table__data a:not(.interview a) {
    margin-left: 11.2%;
  }

  .our-jobs .table__data a:not(.interview a)::before,
  .our-jobs .table__data a:not(.interview a)::after {
    width: 8px;
    transform-origin: calc(100% - 0.5px) 50%;
  }

  .our-jobs .table__data.interview a {
    max-width: 100%;
  }
}
