@charset "UTF-8";
.font-so {
  font-family: "Source Sans Pro", sans-serif;
}

.recruit-catch .container .catch-img img {
  width: 100%;
}
.recruit-catch .container .catch-message {
  background-color: white;
  margin: -8rem auto 0;
  max-width: 920px;
  width: 100%;
  padding: 47px 95px;
  position: relative;
  z-index: 10;
  line-height: 1.7;
}
@media (max-width: 991.98px) {
  .recruit-catch .container .catch-message {
    width: 90%;
  }
}
@media (max-width: 991.98px) and (max-width: 767.98px) {
  .recruit-catch .container .catch-message {
    width: 100%;
    margin-top: 0;
    padding: 40px 0;
  }
}
.recruit-catch .container .catch-message .message-title {
  font-size: 2.2rem;
  font-weight: bold;
  color: #00A8EC;
  line-height: 35/22;
}
.recruit-catch .container .catch-message .message-text {
  margin-top: 3.2rem;
  font-size: 1.5rem;
}
.recruit-catch .container .catch-message .message-recruit {
  margin-top: 5rem;
  font-size: 2.2rem;
  padding-bottom: 0.5em;
  border-bottom: 4px solid #D5D5D5;
  margin-bottom: 2rem;
  font-weight: bold;
  position: relative;
}
.recruit-catch .container .catch-message .message-recruit::before {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 4rem;
  height: 4px;
  background-color: #00A8EC;
}
.recruit-catch .container .catch-message .message-link {
  text-decoration: none;
  color: #00A8EC;
  font-size: 1.5rem;
  transition: opacity 0.3s ease;
}
.recruit-catch .container .catch-message .message-link:hover {
  opacity: 0.7;
}
.recruit-catch .container .catch-message span {
  font-size: 1.5rem;
}

.recruit-work {
  background-color: #222222;
}
.recruit-work .work-box {
  margin-top: 4.2rem;
  display: flex;
  justify-content: center;
  gap: 4rem;
}
@media (max-width: 767.98px) {
  .recruit-work .work-box {
    flex-direction: column;
    align-items: center;
  }
}
.recruit-work .work-box .work-img {
  width: calc(50% - 4rem);
  margin-bottom: 0;
}
@media (max-width: 767.98px) {
  .recruit-work .work-box .work-img {
    width: 90%;
  }
}
.recruit-work .work-box .work-img img {
  width: 100%;
  height: auto;
  box-shadow: 1rem 1rem 0px 0 #00A8EC;
}
.recruit-work .work-box .work-textBox {
  color: white;
  width: calc(50% - 4rem);
}
@media (max-width: 767.98px) {
  .recruit-work .work-box .work-textBox {
    width: 100%;
  }
}
.recruit-work .work-box .work-textBox .work-title {
  font-size: 2.2rem;
  font-weight: bold;
  padding-top: 1em;
  line-height: 1.8;
}
.recruit-work .work-box .work-textBox .work-text {
  font-size: 1.5rem;
  margin-top: 3.2rem;
  line-height: 2.2;
}
.recruit-work .work-video {
  margin-top: 11.2rem;
}
.recruit-work .work-video figcaption {
  font-size: 2.4rem;
  color: white;
  font-weight: bold;
  margin-bottom: 2rem;
  text-transform: uppercase;
}
.recruit-work .work-video-inner {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}
.recruit-work .work-video-inner iframe {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}

.recruit-flow .flow-container .flow-desc {
  background-color: #222222;
  color: white;
  padding-left: 5.6rem;
  display: flex;
  align-items: center;
  gap: 6rem;
  height: 8rem;
  margin-top: 4rem;
}
@media (max-width: 767.98px) {
  .recruit-flow .flow-container .flow-desc {
    width: 100% !important;
    gap: 3rem;
  }
}
@media (max-width: 767.98px) and (max-width: 575.98px) {
  .recruit-flow .flow-container .flow-desc {
    height: 10rem;
    padding-left: 2.6em;
  }
}
.recruit-flow .flow-container .flow-desc dt {
  font-size: 1.7rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 0.4em;
}
.recruit-flow .flow-container .flow-desc dt span {
  font-size: 2.9rem;
  color: #00A8EC;
  line-height: 1.7rem;
}
.recruit-flow .flow-container .flow-desc:nth-of-type(1) {
  width: 58.6956521739%;
}
.recruit-flow .flow-container .flow-desc:nth-of-type(2) {
  width: 69.0217391304%;
}
.recruit-flow .flow-container .flow-desc:nth-of-type(3) {
  width: 79.347826087%;
}
.recruit-flow .flow-container .flow-desc:nth-of-type(4) {
  width: 89.6739130435%;
}
.recruit-flow .flow-container .flow-desc:not(:last-of-type) {
  position: relative;
}
.recruit-flow .flow-container .flow-desc:not(:last-of-type)::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 7.2rem;
  width: 1px;
  height: 4rem;
  background-color: #707070;
}
@media (max-width: 575.98px) {
  .recruit-flow .flow-container .flow-desc:not(:last-of-type)::after {
    left: 5.8rem;
  }
}

.recruit-content {
  background-color: #222222;
}
.recruit-content .content-container {
  margin-top: 4.2rem;
}
.recruit-content .content-container .desc-recruit {
  color: white;
}
@media (max-width: 575.98px) {
  .recruit-content .content-container .desc-recruit {
    gap: 1.5rem;
  }
}
.recruit-content .content-container .desc-recruit .desc-recruit-label {
  border-bottom: 1px solid #00A8EC;
}
@media (max-width: 575.98px) {
  .recruit-content .content-container .desc-recruit .desc-recruit-label {
    width: 100px;
    padding: 1.6rem 0;
  }
}
.recruit-content .content-container .desc-recruit .desc-recruit-value {
  border-bottom: 1px solid #D5D5D5;
}
.recruit-content .content-container .desc-recruit .desc-recruit-value a {
  font-weight: bold;
  color: #00A8EC;
  text-decoration: none;
  transition: all 0.3s ease;
}
.recruit-content .content-container .desc-recruit .desc-recruit-value a:hover {
  opacity: 0.7;
}
.recruit-content .content-container .desc-recruit .desc-recruit-value a.open {
  position: relative;
}
.recruit-content .content-container .desc-recruit .desc-recruit-value a.open::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: calc(100% + 1em);
  width: 1em;
  height: 1em;
  background: url(../img/common/icon_open-blue.svg) no-repeat center center/contain;
}
@media (max-width: 575.98px) {
  .recruit-content .content-container .desc-recruit .desc-recruit-value {
    width: calc(100% - 100px + 1.5rem);
    padding: 1.6rem 0;
  }
}
.recruit-content .content-container .desc-recruit .desc-recruit-value ul {
  list-style: none;
  padding-left: 0;
}
@media (max-width: 767.98px) {
  .recruit-content .content-container .desc-recruit .desc-recruit-value ul {
    padding-left: 1em;
  }
}
.recruit-content .content-container .desc-recruit .desc-recruit-value ul li {
  position: relative;
}
.recruit-content .content-container .desc-recruit .desc-recruit-value ul li::before {
  content: "■";
  position: absolute;
  top: 1.5em;
  left: -4em;
  font-size: 0.2em;
  color: #00A8EC;
}
.recruit-content .content-container .desc-recruit:nth-of-type(1) .desc-recruit-label {
  border-top: 1px solid #00A8EC;
}
.recruit-content .content-container .desc-recruit:nth-of-type(1) .desc-recruit-value {
  border-top: 1px solid #D5D5D5;
}

.recruit-contact .row > * {
  padding-left: calc(var(--bs-gutter-x) * 1);
  padding-right: calc(var(--bs-gutter-x) * 1);
  padding-top: calc(var(--bs-gutter-x) * 1);
  padding-bottom: calc(var(--bs-gutter-x) * 1);
}
.recruit-contact .row {
  max-width: 920px;
  margin: 0 auto;
}
.recruit-contact .row .card {
  transition: all 0.3s ease;
}
.recruit-contact .row .card:hover figure img {
  transform: scale(1.1);
}
.recruit-contact .row .card:hover figure::after {
  transition: all 0.3s ease;
  right: 0.5em;
}
.recruit-contact .row .card figure {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
.recruit-contact .row .card figure img {
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
}
@media (max-width: 767.98px) {
  .recruit-contact .row .card figure img {
    aspect-ratio: 510/370;
  }
}
.recruit-contact .row .card figure p {
  position: absolute;
  right: 1em;
  bottom: 0.5em;
  font-size: 1.5rem;
  font-weight: bold;
  width: calc(100% - 2em);
  padding: 0 0 0.5em;
  border-bottom: 1px solid white;
  color: white;
}
.recruit-contact .row .card figure::after {
  content: "";
  position: absolute;
  right: 1em;
  bottom: 1.5em;
  background: url(../img/common/icon_arrow.svg) no-repeat center center/contain;
  width: 1em;
  height: 1em;
}
/*# sourceMappingURL=map/recruit.css.map */

/* 共通スタイル */
.columns {
  display: flex;
  flex-wrap: wrap; /* 必要に応じて折り返し可能に */
}

.left-col {
  flex: 1; /* カラムの幅を均等に */
  padding: 0; /* 任意の余白を設定 */
}

.right-col {
  flex: 1; /* カラムの幅を均等に */
  padding: 0; /* 任意の余白を設定 */
}

/* PC（デスクトップ）用スタイル */
@media (min-width: 768px) { /* 768px以上の画面幅に適用 */
  .columns {
    flex-direction: row; /* 左右に並べる */
  }
  .left-col, .right-col {
    max-width: 50%; /* 各カラムを50%幅に制限 */
  }
.right-col {
  padding: 0px 0; /* 任意の余白を設定 */
}
}

/* スマホ（モバイル）用スタイル */
@media (max-width: 767.98px) { /* 767.98px以下の画面幅に適用 */
  .columns {
    flex-direction: column; /* 縦方向に並べる */
  }
  .left-col, .right-col {
    max-width: 100%; /* 各カラムを100%幅に */
  }
}
