.header__logo {
    position: relative;
}
.header__logo .white {
    display: block;
}

.header__logo .blue {
    display: none;
}

.hamburger_line {
    background-color: #fff;
}

.hamburger.active .hamburger_line {
    background-color: #fff;
}

.gnav a {
    color: #fff;
}

.ctaBtn a {
    background-color: #fff;
    color: var(--color01);
}

.ctaBtn--message a::before {
    background-image: url(../images/icon_message.svg);
}

.child .ctaBtn a:hover {
    background-color: #fff;
    color: var(--color01);
}

.child .ctaBtn--message a:hover::before {
    background-image: url(../images/icon_mail.svg);
}

@media screen and (max-width: 1024px) {
    .hamburger.active .hamburger_line {
        background-color: #fff;
    }

    .gnav a {
        color: #fff;
    }

    .ctaBtn a {
        background-color: #fff;
        color: var(--color01);
    }

    .ctaBtn--message a::before {
        background-image: url(../images/icon_message.svg);
    }

    .child .ctaBtn a:hover {
        background-color: var(--color01);
        color: #fff;
    }

    .child .ctaBtn--message a:hover::before {
        background-image: url(../images/icon_mail.svg);
    }
}

.recruit__main {
  max-width: inherit;
  padding: 0;
  margin: 0;
}
@media screen and (max-width: 1024px) {
  .pageContent {
    padding: 0;
    margin: 0;
  }
}


.recruit__mv {
  width: 100%;
  /* height: calc(100vh - 80px); */
  height: 100vh;
  min-height: 650px;
  /* max-height: 900px; */
  background-image: url("../images/recruit/recruit_mv_pc.webp");
  background-position: center top;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-top: -120px;
  position: relative;
}

.recruit__mvTitle {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.recruit__mvTitle span {
  font-size: clamp(38px, calc(60 / 1920 * 100vw), 60px);
  color: #fff;
  font-weight: 500;
  padding-left: 30px;
}

.recruit__mvTitle div {
  width: clamp(580px, calc(850 / 1920 * 100vw), 850px);
  color: #fff;
  margin-top: 20px;
}

.recruitEnvironment {
  margin-top: 90px;
}

.recruitEnvironment__inner {
  max-width: var(--content-width);
  padding: 0 var(--content-padding);
  margin: auto;
}

.recruitEnvironment__title {
  font-size: var(--font-size-xxlarge);
  color: #333;
  margin-bottom: 20px;
  text-align: center;
  position: relative;
  font-weight: 600;
}

.recruitEnvironment__title::after {
  content: "";
  display: block;
  width: 45px;
  height: 5px;
  background-color: var(--color-primary);
  margin: 20px auto 0;
}

.recruitEnvironment__items {
  display: flex;
  justify-content: space-between;
  margin-top: 60px;
  align-items: stretch; /* 高さを揃える */
}

.recruitEnvironment__item {
  width: calc((100% - 50px * 2) / 3); /* 3列に分ける */
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: var(--color-white); /* アイテムの背景色 */
}

/* 最初と2番目のアイテムの右側に線を追加 */
.recruitEnvironment__item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -25px;
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: #dfdfdf;
}

.recruitEnvironment__itemIcon {
  width: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
  height: 110px; /* 固定の高さ */
}

.recruitEnvironment__itemIcon img {
  width: 100%;
}

.recruitEnvironment__itemContent {
  margin-bottom: 30px;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
}

.recruitEnvironment__itemTitle {
  font-size: var(--font-size-xlarge);
  color: var(--color-text-secondary);
  font-weight: 600;
  margin-bottom: 15px;
  height: 2.8em;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
}

.recruitEnvironment__itemText {
  color: #333;
  line-height: 1.7;
  text-align: left;
  flex-grow: 1;
}

.recruitEnviroment__image {
  width: 100%;
  height: 250px;
  border-radius: 8px;
  overflow: hidden;
}

.recruitEnviroment__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recruitInterview {
  background-color: #fafafa;
  padding: 100px 0;
  margin-top: 100px;
}

.recruitInterview__inner {
  max-width: var(--content-width);
  padding: 0 var(--content-padding);
  margin: auto;
}

.recruitInterview__title {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 60px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--color-primary);;
}

.recruitInterview__titleEn {
  font-family: var(--font-family-en);
  font-size: var(--font-size-xxlarge);
  color: #333;
  font-weight: 600;
}

.recruitInterview__titleJa {
  font-size: var(--font-size-base);
  color: #333;
  font-weight: 600;
  margin-bottom: 14px;
}

.recruitInterview__item {
  display: flex;
  gap: 40px;
  padding: 0 20px;
  position: relative;
}

.recruitInterview__item:not(:first-child) {
  margin-top: 80px;
}

.recruitInterview__image {
  width: 335px;
  overflow: hidden;
  flex-shrink: 0;
}

.recruitInterview__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.rectuitInterview__content {
  flex: 1;
  position: relative;
}

.recruitInterview__number {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 100px;
  line-height: 0.8;
  color: #e7e7e7;
  font-weight: 600;
  font-family: var(--font-family-en);
  z-index: -1;
}

.recruitInterview__info {
  margin-top: 25px;
}

.recruitInterview__name {
  font-size: 2rem;
  color: #333;
  font-weight: 600;
  margin-bottom: 5px;
}

.recruitInterview__position {
  font-size: var(--font-size-small);
  color: var(--color-text-accent);
  font-weight: 400;
}

.recruitInterview__questions {
  margin-top: 20px;
}

.recruitInterview__question {
  border-bottom: 1px solid #e5e5e5;
}
.recruitInterview__question:first-child {
  border-top: 1px solid #e5e5e5;
}

.recruitInterview__questionBtn {
  width: 100%;
  padding: 20px 0;
  padding-left: 40px;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 15px;
  font-size: 2rem;
  color: var(--color-text-secondary);
  font-weight: 600;
  position: relative;
}

.recruitInterview__questionBtn::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "Q";
  width: 30px;
  height: 30px;
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  font-weight: 600;
  flex-shrink: 0;
  line-height: 1;
  font-family: var(--font-family-en);
}

.recruitInterview__questionText {
  flex: 1;
}

.recruitInterview__questionIcon {
  width: 20px;
  height: 20px;
  color: var(--color-accent-02);
  font-size: 1.8rem;
  font-weight: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}

.recruitInterview__questionBtn.is-open .recruitInterview__questionIcon {
  transform: rotate(45deg);
}

.recruitInterview__answer {
  display: none;
  padding-bottom: 20px;
  background-color: #f9f9f9;
  margin-left: 39px;
  color: #333;
  line-height: 1.6;
}

.recruitInterview__answer p {
}

.recruitInterview__answer.is-open {
  display: block;
}

.recruitJob {
  margin-top: 100px;
  background-color: var(--color-white);
}

.recruitJob__inner {
  max-width: var(--content-width);
  padding: 0 var(--content-padding);
  margin: auto;
}

.recruitJob__title {
  font-size: var(--font-size-xxlarge);
  color: #333;
  font-weight: 600;
  position: relative;
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 10px;
}

.recruitJob__items {
  margin-top: 35px;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.recruitJob__item {
  background-color: var(--color-white);
  overflow: hidden;
}

.recruitJob__itemTitle {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-large);
  font-weight: 600;
  padding: 10px 16px;
  margin: 0;
}

.recruitJob__itemContent {
  padding: 0;
}

.recruitJob__table {
  width: 100%;
  border-collapse: collapse;
}

.recruitJob__tableRow {
  border-bottom: 1px solid #e5e5e5;
}
.recruitJob__tableHeader {
  background-color: #eaf6ff;
  color: #333;
  font-weight: 600;
  padding: 16px;
  text-align: left;
  vertical-align: top;
  width: 150px;
  border-right: 1px solid #e5e5e5;
}

.recruitJob__tableData {
  color: #333;
  padding: 16px 20px;
  vertical-align: top;
  line-height: 1.6;
}
 .recruitJob__tableRow th,
  .recruitJob__tableRow td {
    font-size: 1.8rem;
  }

.recruitEntry {
  text-align: center;
  padding: 0 var(--content-padding);
  max-width: var(--content-width);
  margin: auto;
  margin-top: 100px;
  margin-bottom: 100px;
}

.recruitEntry__inner {
  position: relative;
  background-color: #eaf6ff;
  border-radius: 12px;
  padding: 50px 30px;
}

.recruitEntry__title {
  font-size: clamp(2.4rem, calc(32 / 1920 * 100vw), 3.2rem);
  color: #333;
  font-weight: 600;
  line-height: 1.4;
}

.recruitEntry__text {
  color: #333;
  margin-top: 10px;
  line-height: 1.6;
}

.recruitEntry__wrap {
  margin-top: 30px;
  display: flex;
  gap: 30px;
  justify-content: center;
  align-items: center;
}

.recruitEntry__buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}

.recruitEntry__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 250px;
  padding: 15px 30px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  font-size: var(--font-size-base);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.recruitEntry__button--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border: 2px solid var(--color-primary);
}

.recruitEntry__button--primary:hover {
  background-color: #005a9e;
  border-color: #005a9e;
}

.recruitEntry__button--primary::after,
.recruitEntry__button--secondary::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-image: url("../images/recruit/link-icon.webp");
  background-size: contain;
  background-repeat: no-repeat;
}

.recruitEntry__buttonText {
  flex: 1;
  text-align: center;
}

.recruitEntry__button--secondary {
  background-color: var(--color-accent);
  color: var(--color-white);
  border: 2px solid var(--color-accent);
}

.recruitEntry__button--secondary:hover {
  background-color: #0f5a78;
  border-color: #0f5a78;
}
.recruitEntry__contact {
}

.recruitEntry__phone {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: -10px;
}

.recruitEntry__phoneNumber {
  font-size: 3.6rem;
  color: #333;
  font-weight: 600;
  font-family: var(--font-family-en);
  letter-spacing: 0.05em;
}

.recruitEntry__phoneTime {
  font-size: var(--font-size-small);
  color: var(--color-text-accent);
  font-weight: 400;
}

/* レスポンシブ対応 */
@media screen and (max-width: 1024px) {
  .recruitEntry__wrap {
    flex-direction: column;
  }
  .recruitEntry__phone {
    flex-direction: row;
    column-gap: 20px;
  }
  .recruitEntry__phoneTime {
    margin-top: 0;
  }
}

@media screen and (max-width: 770px) {
  .recruitEnvironment {
    margin-top: 60px;
  }
  .recruitEnvironment__title::after {
    height: 1px;
    margin-top: 10px;
  }
  .recruitEnvironment__items {
    flex-direction: column;
    align-items: center;
    row-gap: 30px;
    margin-top: 40px;
  }
  .recruitEnvironment__item {
    width: 80%;
        border-bottom: solid 1px #ddd;
        padding-bottom: 40px;
  }
  .recruitEnvironment__item:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}
  .recruitEnvironment__item:not(:last-child)::after {
    display: none; /* 最後のアイテムの線を非表示 */
  }
  .recruitEnvironment__itemTitle {
    height: auto;
    margin-bottom: 20px;
  }
  .recruitEnvironment__itemContent {
    margin-bottom: 20px;
  }
  .recruitEnviroment__image {
    height: 200px;
  }

  .recruitInterview {
    margin-top: 80px;
    padding: 80px 0;
  }
  .recruitInterview__title {
    margin-bottom: 0px;
  }
  .recruitInterview__titleJa {
    margin-bottom: 8px;
    font-size: 1.6rem;
  }
  .recruitInterview__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    position: relative;
    margin-top: 60px;
    padding: 0;
  }
  .recruitInterview__item:not(:first-child) {
    margin-top: 60px;
  }
  .recruitInterview__image {
    width: 60%;
  }
  .recruitJob {
    margin-top: 70px;
  }
  .recruitEntry {
    margin-top: 80px;
  }
}

@media screen and (max-width: 600px) {
  /* セクションタイトル: 2.8rem */
  .recruitEnvironment__title {
    font-size: 2.8rem;
  }

  .recruitInterview__titleEn {
    font-size: 2.8rem;
  }

  .recruitJob__title {
    font-size: 2.8rem;
  }
.recruitEnvironment__itemIcon {
  width: 100px;
}
  /* アイテムタイトル: 2.4rem */
  .recruitEnvironment__itemTitle {
    font-size: 2.2rem;
  }

  .recruitEntry__title {
    font-size: 2.4rem;
  }

  /* インタビューの名前: 2rem */
  .recruitInterview__name {
    font-size: 1.8rem;
  }

  /* 電話番号: 2.4rem */
  .recruitEntry__phoneNumber {
    font-size: 2.8rem;
  }
  

  .recruit__mv {
    /* height: calc(100vh - 90px); */
    height: calc(100vh - 50px);
    max-height: 1080px;
    margin-top: -80px;
      background-image: url("../images/recruit/recruit_mv_sp.webp");

  }

  .recruit__mvTitle span {
    font-size: clamp(34px, calc(60 / 1920 * 100vw), 60px);
    font-size: 3rem;
    color: #fff;
    font-weight: 500;
    padding-left: 30px;
  }

  .recruit__mvTitle div {
    /* width: 80%; */
    width: 250px;
    color: #fff;
    margin-top: 20px;
  }

  .recruitInterview {
    margin-top: 60px;
    padding: 60px 0;
  }
  .recruitInterview__item:not(:first-child) {
    margin-top: 50px;
  }
  .recruitInterview__questionBtn {
    font-size: 1.8rem;
  }
  .recruitInterview__answer {
    margin-left: 0px;
  }
  .recruitJob {
    margin-top: 50px;
  }
.recruitJob__itemTitle {
  font-size: 1.8rem;
  padding: 5px 10px;
}
  .recruitJob__tableHeader {
    border-right: none;
  }

  .recruitJob__tableRow th,
  .recruitJob__tableRow td {
    display: block;
    width: 100%;
    font-size: 1.5rem;
  }

  .recruitEntry {
    margin-top: 60px;
    margin-bottom: 60px;
  }

  .recruitEntry__inner {
    padding: 50px 10px;
  }
  .recruitEntry__buttons {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 18px;
  }
  .recruitEntry__button {
    padding: 5px 30px;
    font-size: 1.5rem;
  }
  .recruitEntry__phone {
    flex-direction: column;
  }
}
