/* ============================================================
   recruit-page.css
   採用情報ページ専用スタイル
   style.min.css の後に読み込む
   ============================================================ */

/* ──────────────────────────────────────────
   全体背景
   ────────────────────────────────────────── */
.l-main {
  background-color: #f4f7f7;
}

/* ──────────────────────────────────────────
   アンカーナビゲーション
   ────────────────────────────────────────── */
.p-page-link {
  background: #fff;
  border-bottom: 1px solid #e0eaea;
  padding: 10px 0 8px;
  margin-bottom: 0;
  position: sticky;
  top: 60px;
  z-index: 80;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

@media screen and (min-width: 768px) {
  .p-page-link {
    top: 70px;
    padding: 14px 0;
  }
}

/* デフォルト（PC含む）：折り返し表示 */
.p-page-link__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  overflow-x: visible;
  padding: 4px 12px 6px;
  justify-content: flex-start;
}

@media screen and (min-width: 768px) {
  .p-page-link__list {
    justify-content: center;
    padding: 4px 0;
  }
}

/* スマートフォン（タッチ）のみ：1行横スクロール */
@media screen and (max-width: 767px) and (pointer: coarse) {
  .p-page-link__list {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    justify-content: flex-start;
  }

  .p-page-link__list::-webkit-scrollbar {
    display: none;
  }

  .p-page-link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 48px;
    height: 100%;
    background: linear-gradient(to right, transparent, #fff);
    pointer-events: none;
    z-index: 1;
  }
}

/* ナビボタン */
.p-page-link__item {
  margin: 0;
  font-size: 1.25rem;
  flex-shrink: 0;
}

@media screen and (min-width: 768px) {
  .p-page-link__item {
    font-size: 1.4rem;
    flex-shrink: 1;
  }
}

.p-page-link__item .c-button01--reverse {
  background-color: cadetblue;
  color: #fff;
  border: 1.5px solid cadetblue;
  border-radius: 999px;
  padding: 5px 13px;
  font-size: inherit;
  font-weight: 500;
  letter-spacing: 0.5px;
  line-height: 1.4;
  white-space: nowrap;
  transition: background 0.2s, color 0.2s, transform 0.15s;
  box-shadow: none;
}

.p-page-link__item .c-button01--reverse:hover {
  background-color: #fff;
  color: cadetblue;
  border-color: cadetblue;
  transform: translateY(-1px);
}

/* ──────────────────────────────────────────
   セクション共通
   ────────────────────────────────────────── */
.l-main section.p-page02 {
  background: transparent;
  padding: 0;
  margin-bottom: 0;
}

/* カードラッパー */
.p-page02__inner {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0, 100, 100, 0.07);
  border: none;
  padding: 28px 20px 24px;
  margin: 20px auto;
  width: 92%;
  max-width: 900px;
}

@media screen and (min-width: 768px) {
  .p-page02__inner {
    padding: 36px 36px 28px;
    margin: 28px auto;
  }
}

/* 白いカード（p-page02--bg01セクション内） */
.p-page02__inner.p-page02__inner--white {
  background: #fff;
}

/* l-container との組み合わせで幅が狭くならないよう調整 */
.p-page02.l-container {
  padding-left: 0;
  padding-right: 0;
}

/* ──────────────────────────────────────────
   淡いグレーの背景セクション (p-page02--bg01)
   ────────────────────────────────────────── */
.p-page02.p-page02--bg01 {
  background: #eaf2f2;
  padding: 20px 0;
  margin-top: 24px;
}

@media screen and (min-width: 768px) {
  .p-page02.p-page02--bg01 {
    padding: 28px 0;
  }
}

/* ──────────────────────────────────────────
   セクション H2 タイトル
   白背景＋左アクセントバー＋cadetblue文字
   ────────────────────────────────────────── */
.p-page02__title.c-heading03.c-heading03--bg {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  box-sizing: border-box;
  min-width: unset;
  margin-bottom: 28px;
  overflow: visible;

  background: none;
  border-radius: 0;
  border-left: 6px solid cadetblue;
  border-bottom: 2px solid rgba(95,158,160,0.2);
  padding: 10px 16px 10px 18px;
  color: #1a5050;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-shadow: none;
  box-shadow: none;
}

.p-page02__title.c-heading03.c-heading03--bg::before,
.p-page02__title.c-heading03.c-heading03--bg::after {
  display: none;
}

@media screen and (min-width: 768px) {
  .p-page02__title.c-heading03.c-heading03--bg {
    font-size: 2.1rem;
    padding: 12px 20px 12px 20px;
    margin-bottom: 32px;
  }
}

/* ──────────────────────────────────────────
   コンテンツエリア (p-page02__body)
   ────────────────────────────────────────── */
.p-page02__body {
  padding: 0;
  margin-bottom: 24px;
}

.p-page02__body:last-child {
  margin-bottom: 0;
}

/* ──────────────────────────────────────────
   H3 サブ見出し（c-heading05.c-heading05--lg）
   ────────────────────────────────────────── */
.p-page02__body h3.c-heading05,
h3.c-heading05.c-heading05--lg.p-page02__sub-title {
  display: block;
  width: 100%;
  color: #1a5050;
  font-size: 1.6rem;
  font-weight: 700;
  border-left: 3px solid cadetblue;
  padding: 4px 0 4px 12px;
  margin-bottom: 10px;
  letter-spacing: 0.04em;
  background: none;
}

@media screen and (min-width: 768px) {
  .p-page02__body h3.c-heading05,
  h3.c-heading05.c-heading05--lg.p-page02__sub-title {
    font-size: 1.8rem;
    margin-bottom: 12px;
  }
}

/* ──────────────────────────────────────────
   STEP 見出し
   ────────────────────────────────────────── */
h3.c-heading05.c-heading05--lg.p-page02__sub-title[class*="STEP"] {
  /* JS/CSSでSTEPラベルを装飾したい場合用（将来拡張） */
}

/* STEP番号を数字バッジで強調 */
.p-page02__body h3.c-heading05.p-page02__sub-title,
.p-page02 h3.p-page02__sub-title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #1a5050;
  font-size: 1.6rem;
  font-weight: 700;
  border-left: 3px solid cadetblue;
  padding: 6px 0 6px 14px;
  margin-bottom: 10px;
  background: rgba(95,158,160,0.05);
  border-radius: 0 6px 6px 0;
  letter-spacing: 0.04em;
}

@media screen and (min-width: 768px) {
  .p-page02__body h3.c-heading05.p-page02__sub-title,
  .p-page02 h3.p-page02__sub-title {
    font-size: 1.8rem;
  }
}

/* ──────────────────────────────────────────
   本文テキスト
   ────────────────────────────────────────── */
.p-page02__body p,
.p-page02__inner > section.p-page02__body > p {
  font-size: 1.5rem;
  line-height: 1.9;
  color: #333;
  margin-bottom: 10px;
}

.p-page02__body p:last-child {
  margin-bottom: 0;
}

@media screen and (min-width: 768px) {
  .p-page02__body p,
  .p-page02__inner > section.p-page02__body > p {
    font-size: 1.6rem;
    line-height: 2;
    margin-bottom: 12px;
  }
}

/* ──────────────────────────────────────────
   リスト (c-list02)
   ────────────────────────────────────────── */
.p-page02__body .c-list02,
.p-page02__body.c-list02 {
  margin: 8px 0 12px 0;
  padding: 0;
}

.p-page02__body .c-list02__item,
.c-list02.p-page02__body .c-list02__item {
  font-size: 1.5rem;
  padding: 4px 0 4px 2px;
  line-height: 1.8;
}

@media screen and (min-width: 768px) {
  .p-page02__body .c-list02__item,
  .c-list02.p-page02__body .c-list02__item {
    font-size: 1.6rem;
  }
}

/* ──────────────────────────────────────────
   募集状況テーブル (p-recruit-table) リデザイン
   ────────────────────────────────────────── */
.p-recruit-table {
  width: 100%;
  margin: 0 auto;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #d4e8e8;
  font-size: 1.5rem;
}

/* ヘッダー行 */
.p-recruit-table .p-recruit-table__thead th,
.p-recruit-table tr.p-recruit-table__thead th {
  background: linear-gradient(135deg, #3d8f91 0%, #5f9ea0 100%);
  color: #fff;
  font-weight: 700;
  font-size: 1.45rem;
  padding: 12px 14px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,0.2);
}

.p-recruit-table tr.p-recruit-table__thead th:last-child {
  border-right: none;
}

/* データ行 */
.p-recruit-table th,
.p-recruit-table td {
  padding: 12px 14px;
  border: 1px solid #e0eeee;
  vertical-align: middle;
  line-height: 1.7;
}

/* 職種ラベル列（左端） */
.p-recruit-table td:first-child,
.p-recruit-table .p-recruit-table__td:first-child {
  background: rgba(95,158,160,0.08);
  color: #1a5050;
  font-weight: 700;
  text-align: center;
  /* width: 22%; */
}

/* 交互ストライプ */
/* .p-recruit-table tr:nth-child(even) td {
  background-color: #f8fbfb;
} */

/* .p-recruit-table tr:nth-child(odd) td {
  background-color: #fff;
} */

/* 左端セルはストライプ上書き */
.p-recruit-table tr:nth-child(even) td:first-child,
.p-recruit-table tr:nth-child(odd) td:first-child {
  background: rgba(95,158,160,0.08) !important;
}

/* ラベル（::before content）を非表示 */
@media screen and (min-width: 768px) {
  .p-recruit-table tr.p-recruit-table__thead {
    display: table-row;
  }

  .p-recruit-table td:before {
    display: none;
  }

  .p-recruit-table .p-recruit-table__td {
    display: table-cell;
    text-align: left;
    min-height: unset;
  }

  .p-recruit-table td:first-child {
    width: 22%;
    padding-top: 12px;
  }
}

/* モバイル：カード型レイアウト */
@media screen and (max-width: 767px) {
  .p-recruit-table,
  .p-recruit-table tbody,
  .p-recruit-table tr,
  .p-recruit-table td {
    display: block;
  }

  .p-recruit-table tr.p-recruit-table__thead {
    display: none;
  }

  .p-recruit-table tr {
    margin-bottom: 10px;
    border: 1px solid #d4e8e8;
    border-radius: 8px;
    overflow: hidden;
  }

  .p-recruit-table .p-recruit-table__td {
    display: block;
    text-align: left;
    min-height: 40px;
    padding: 10px 14px;
    font-size: 1.45rem;
    line-height: 1.8;
  }

  .p-recruit-table td:first-child {
    background: rgba(95,158,160,0.15);
    color: #1a5050;
    font-weight: 700;
    text-align: center;
    width: 100%;
    padding: 8px 14px;
    font-size: 1.45rem;
  }

  .p-recruit-table td:before {
    display: none;
  }
}

/* ──────────────────────────────────────────
   採用サイトリンクエリア (p-recruit)
   ────────────────────────────────────────── */
.p-recruit {
  display: block;
  width: 100%;
}

@media screen and (min-width: 768px) {
  .p-recruit {
    display: flex;
    align-items: center;
    gap: 32px;
  }
  .p-recruit__thum {
    width: 50%;
    flex-shrink: 0;
  }
}

.p-recruit__img {
  width: 90%;
  display: block;
  margin: 0 auto;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.10);
}

@media screen and (min-width: 768px) {
  .p-recruit__img {
    width: 100%;
  }
}

/* ──────────────────────────────────────────
   CTAボタン (.p-page02__button / .c-button)
   ────────────────────────────────────────── */
.p-page02__button.c-button,
.p-recruit__button .c-button.p-page02__button {
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  min-height: 56px;
  max-width: 420px;
  width: 90%;
  margin: 24px auto 8px;
  padding: 14px calc(2rem + 16px + 1rem) 14px 2rem;
  font-size: 1.6rem;
  font-weight: 600;
  border-radius: 8px;
  letter-spacing: 0.08em;
  background-color: cadetblue;
  color: #fff;
  border: 2px solid cadetblue;
  box-shadow: 0 3px 10px rgba(95,158,160,0.25);
  transition: all 0.25s ease;
  white-space: normal;
  text-align: center;
  line-height: 1.5;
}

.p-page02__button.c-button:hover,
.p-recruit__button .c-button.p-page02__button:hover {
  background-color: #fff;
  color: cadetblue;
  border-color: cadetblue;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(95,158,160,0.2);
}

@media screen and (min-width: 768px) {
  .p-page02__button.c-button {
    font-size: 1.7rem;
    min-height: 60px;
    max-width: 480px;
  }
}

/* p-page02__wrap の余白調整 */
.p-page02__wrap {
  margin-top: 16px;
}

/* ──────────────────────────────────────────
   電話番号表示
   ────────────────────────────────────────── */
p.p-page02__sub-title {
  color: #1a5050;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 6px 0 12px 0;
}

/* ──────────────────────────────────────────
   セクション間の余白
   ────────────────────────────────────────── */
.l-main section.p-page02 + section.p-page02 {
  margin-top: 0;
}

/* ハローワークのリンク用のボタン風クラスと大きめ文字サイズを追加 */
.p-recruit-link {
  display: inline-block;
  font-size: 1.25rem;
  font-weight: 600;
  color: #fff !important;
  background: #3d8f91;
  border-radius: 6px;
  padding: 10px 22px;
  margin: 10px 0;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, box-shadow 0.2s;
  box-shadow: 0 2px 8px rgba(61,143,145,0.10);
}
.p-recruit-link:hover {
  background: #fff;
  color: #3d8f91 !important;
  border: 1.5px solid #3d8f91;
  box-shadow: 0 4px 16px rgba(61,143,145,0.15);
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .p-recruit-link {
    font-size: 1.45rem;
    padding: 12px 32px;
  }
}
