/* ==========================================================================
   共通コンポーネント: 求人カード一覧（c-jobs）  Figma 76:30880
   白背景。クリーム地・#89705b 太枠(3px)・角丸8pxのカードを 4列(PC)/3列(SP)。
   各カード：上に雇用形態ピル（正社員=黄 / パート・アルバイト=青）＋職種名、右に丸矢印。

   採用ランディング（template-saiyo.php／PC8件・SP9件＋「もっと見る」）と
   求人アーカイブ（archive-recruit.php／.c-jobs--all で全件・初期隠しなし）で共用。
   ========================================================================== */
.c-jobs {
  background-color: var(--color-white);
  padding-block: var(--space-40) var(--space-80);
  /* 外部からのアンカーリンク（#jobs 等）が固定ヘッダーに隠れないよう余白を確保。 */
  scroll-margin-top: var(--space-96);
}
.c-jobs__inner {
  width: 100%;
  max-width: var(--layout-max);
  margin-inline: auto;
  padding-inline: var(--space-24);
}

/* 求人カードのグリッド */
.c-jobs__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-16);
  margin: var(--space-48) 0 0;
  padding: 0;
  list-style: none;
}
.c-jobs__item {
  margin: 0;
  /* grid トラックの min-width:auto による膨張を防ぐ（中身が 1fr を押し広げないように） */
  min-width: 0;
}

/* カード本体（クリーム地・茶サブ色の太枠・角丸8px） */
.c-jobs__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  height: 100%;
  padding: var(--space-12) var(--space-8) var(--space-12) var(--space-12);
  /* Figma 76:30897 の枠線は #89705b の「手描き（クレヨン）」フレーム。
     クリーンな solid 線ではないため border-image で再現（素材は @4x のフレーム画像）。
     非対応・読込失敗時は solid #89705b にフォールバック。 */
  border: 3px solid var(--color-brown-sub);
  border-image: url("../../images/saiyo/job-card-frame.webp") 20 / 10px round;
  border-radius: var(--radius-sm);
  /* Figma 76:30897: 背景色_オフホワイト地のクレヨン紙テクスチャ（346.8×327.8px タイル）。
     フラット塗りではなくテクスチャ付き。 */
  background-color: var(--color-bg-offwhite);
  background-image: url("../../images/common/tex-offwhite.webp");
  background-repeat: repeat;
  background-position: top left;
  background-size: 346.8px 327.8px;
  color: var(--color-brown-text);
  text-decoration: none;
  transition: transform 0.2s ease;
}
.c-jobs__card:hover {
  /* テクスチャを保持したまま浮かせる（背景の上書きはしない） */
  transform: translateY(-2px);
}

.c-jobs__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: flex-start;
  /* カード幅を超えないよう縮小可に（タイトルの折り返しを効かせる） */
  min-width: 0;
}

/* 雇用形態ピル（既定：正社員＝黄） */
.c-jobs__type {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4) var(--space-12);
  border-radius: var(--radius-pill);
  background: var(--color-bg-yellow);
  color: var(--color-brown-text);
  font-size: var(--font-size-h6);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-heading);
  white-space: nowrap;
}

/* パート・アルバイト＝青 */
.c-jobs__type--part {
  background: #d6eef6;
}

.c-jobs__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-base);
  letter-spacing: -0.02em;
  color: var(--color-brown-text);
  /* 長い職種名はカード内で折り返す */
  overflow-wrap: anywhere;
}

/* 右端の丸い矢印 */
.c-jobs__arrow {
  flex: 0 0 auto;
  width: var(--space-24);
  height: var(--space-24);
  border-radius: var(--radius-pill);
  background: var(--color-brown-sub)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 10 10' fill='none'%3E%3Cpath d='M1 5h7M5 2l3 3-3 3' stroke='%23ffffff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    center / 0.75rem no-repeat;
}

/* もっと見るボタンは共通コンポーネント .c-morebtn（components/buttons.css）を使用。
   ラッパーは中央寄せ＋上マージンのみ担う。PC・SPともに「もっと見る」UIを使う。 */
.c-jobs__action {
  display: flex;
  justify-content: center;
  margin-top: var(--space-40);
}

/* もっと見るトグル（チェックボックス）はラベルで操作。視覚的に隠す（キーボードフォーカスは保持）。 */
.c-jobs__toggle {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

/* --- もっと見る（PCは8件まで初期表示し、トグルで全件表示） --- */
/* 9件目以降は隠す。.c-jobs--all（アーカイブ全件表示）では隠さない。 */
.c-jobs:not(.c-jobs--all) .c-jobs__item:nth-child(n + 9) {
  display: none;
}
/* もっと見る押下（:checked）で9件目以降も表示。 */
.c-jobs__toggle:checked ~ .c-jobs__grid .c-jobs__item:nth-child(n + 9) {
  display: block;
}
/* 押下後は「もっと見る」ボタンを隠す。 */
.c-jobs__toggle:checked ~ .c-jobs__action {
  display: none;
}
/* キーボード操作時のフォーカス可視化（ラベルに表示）。 */
.c-jobs__toggle:focus-visible ~ .c-jobs__action .c-morebtn {
  outline: 2px solid var(--color-brown-text);
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .c-jobs {
    padding-block: var(--space-8) var(--space-32);
  }
  .c-jobs__inner {
    padding-inline: var(--space-16);
  }
  /* SP は3カラム（Figma 76:32644）。 */
  .c-jobs__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    margin-top: var(--space-24);
  }

  /* SPカード：縦積み中央寄せ。枠はSP専用の手描きフレームに差し替え。右端に細い矢印。 */
  .c-jobs__card {
    position: relative;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    padding: var(--space-10) var(--space-12);
    border-image: url("../../images/saiyo/job-card-frame_sp.png") 20 / 10px round;
  }
  .c-jobs__body {
    align-items: center;
    gap: var(--space-4);
  }
  /* 雇用形態ピル：Figma 10px。 */
  .c-jobs__type {
    padding: var(--space-4) var(--space-8);
    font-size: var(--font-size-2xs);
  }
  .c-jobs__type--part {
    letter-spacing: -0.12em;
  }
  /* 職種名：中央寄せ・40pxの行高ボックスに上下中央（1〜2行を吸収）。 */
  .c-jobs__title {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: var(--space-40);
    text-align: center;
    font-size: var(--font-size-h6); /* ≒ Figma 13.5px */
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
  }
  /* 矢印：円なしの細いシェブロン（#674428）。右端・縦中央。 */
  .c-jobs__arrow {
    position: absolute;
    right: var(--space-4);
    /* ピルの下の職種名に高さを合わせる（中央からピル+gapの半分ぶん下／Figma 76:32644）。 */
    top: calc(52% + var(--space-12));
    transform: translateY(-50%);
    width: 4px;
    height: 7px;
    border-radius: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='7' viewBox='0 0 4 7' fill='none'%3E%3Cpath d='M0.5 6.5L3.5 3.5L0.5 0.5' stroke='%23674428' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
      center / contain no-repeat;
  }

  /* --- もっと見る（SPは9件まで表示し、トグルで全件表示。JS不要のチェックボックス方式） --- */
  /* PCの8件制限をリセットし、9件目までは表示。
     PC側ルール（.c-jobs:not(.c-jobs--all) …）と同等の詳細度にして上書きする。 */
  .c-jobs:not(.c-jobs--all) .c-jobs__item:nth-child(n + 9) {
    display: block;
  }
  /* 10件目以降は隠す。.c-jobs--all では隠さない。 */
  .c-jobs:not(.c-jobs--all) .c-jobs__item:nth-child(n + 10) {
    display: none;
  }
  /* もっと見る押下（:checked）で10件目以降も表示。 */
  .c-jobs__toggle:checked ~ .c-jobs__grid .c-jobs__item:nth-child(n + 10) {
    display: block;
  }
  /* もっと見るボタンの上マージンはSPで詰める。 */
  .c-jobs__action {
    margin-top: var(--space-32);
  }
  /* 総数が9件以下のとき（PC専用表示）はSPでは「もっと見る」を隠す。 */
  .c-jobs__action--pc-only {
    display: none;
  }
}
