/* ======================================
   recruit.css - 求人情報ページ専用スタイル
====================================== */

/* ======================================
   固定ページヘッダー（heroと同じ仕様）
====================================== */
.page-header-fixed {
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 400px;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--header-height) + var(--spacing-2xl)) 0 var(--spacing-2xl);
}

/* ページヘッダーの後のコンテンツ用スペーサー */
.page-header-spacer {
  height: 400px;
  pointer-events: none;
}

/* コンテンツラッパー（白背景でページヘッダーを覆う） */
.recruit-content-wrapper {
  position: relative;
  z-index: 2;
  background-color: var(--color-white);
  min-height: 100vh;
}

/* ======================================
   セクション共通
====================================== */
.recruit-section {
  padding: var(--spacing-4xl) 0;
}

.recruit-section-alt {
  background-color: var(--color-gray-100);
}

.recruit-description {
  margin-bottom: var(--spacing-2xl);
  color: var(--color-text-light);
  line-height: 1.8;
}

/* ======================================
   代表メッセージセクション
====================================== */
.message-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}

.message-content {
  text-align: left;
}

.message-image {
  position: relative;
  overflow: hidden;
}

.message-img {
  width: 100%;
  height: auto;
  display: block;
}

.message-lead {
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--spacing-xl);
  line-height: 1.8;
}

.message-text {
  margin-bottom: var(--spacing-lg);
  line-height: 2;
  color: var(--color-text-light);
}

.message-signature {
  margin-top: var(--spacing-2xl);
  font-weight: 600;
  color: var(--color-text);
  font-size: var(--font-size-lg);
  text-align: right;
}

/* ======================================
   求める人物像セクション
====================================== */
.ideal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-lg);
}

.ideal-card {
  background-color: var(--color-white);
  padding: var(--spacing-xl);
  text-align: center;
  border: 1px solid var(--color-gray-200);
}

.ideal-number {
  font-size: var(--font-size-3xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--spacing-md);
  line-height: 1;
}

.ideal-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin-bottom: var(--spacing-md);
  line-height: 1.5;
}

.ideal-text {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  line-height: 1.8;
  text-align: left;
}

/* ======================================
   募集要項テーブル
====================================== */
.recruit-table-wrapper {
  overflow-x: auto;
}

.recruit-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--color-gray-200);
}

.recruit-table th,
.recruit-table td {
  padding: var(--spacing-md) var(--spacing-lg);
  border: 1px solid var(--color-gray-200);
  text-align: left;
  vertical-align: top;
}

.recruit-table th {
  width: 150px;
  font-weight: 600;
  background-color: var(--color-gray-100);
  white-space: nowrap;
}

.recruit-table td {
  color: var(--color-text-light);
}

.recruit-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.recruit-list li {
  position: relative;
  padding-left: var(--spacing-lg);
  margin-bottom: var(--spacing-xs);
}

.recruit-list li::before {
  content: '・';
  position: absolute;
  left: 0;
}

.recruit-list li.nomarking::before {
  content: '　';
  position: absolute;
  left: 0;
}

.recruit-list li:last-child {
  margin-bottom: 0;
}

/* ======================================
   レスポンシブデザイン (モバイル)
====================================== */
@media (max-width: 767px) {
  .recruit-section {
    padding: var(--spacing-2xl) 0;
  }

  /* 代表メッセージ */
  .message-wrapper {
    flex-direction: column;
  }

  .message-lead {
    font-size: var(--font-size-lg);
  }

  /* テーブルモバイル対応 */
  .recruit-table th,
  .recruit-table td {
    padding: var(--spacing-sm) var(--spacing-md);
    display: block;
    width: 100%;
  }

  .recruit-table th {
    border-bottom: none;
  }

  .recruit-table tr {
    border-bottom: 1px solid var(--color-gray-200);
  }

  /* 求める人物像カード */
  .ideal-card {
    padding: var(--spacing-lg);
  }
}

/* ======================================
   レスポンシブデザイン (タブレット)
====================================== */
@media (min-width: 768px) {
  .message-wrapper {
    flex-direction: row;
    align-items: flex-start;
  }

  .message-content {
    flex: 1;
  }

  .message-image {
    flex: 0 0 45%;
    max-width: 45%;
  }

  .recruit-table th {
    width: 200px;
  }

  .ideal-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ======================================
   レスポンシブデザイン (PC)
====================================== */
@media (min-width: 1024px) {
  .ideal-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
