/* components/list.css — 一覧/詳細まわりの分子コンポーネント
   Figma: NewsListRow / CategoryFilter / Pagination / Breadcrumb / RelatedSidebar / ArticleGrid */

/* --- 記事カードのグリッド ------------------------------------------------- */
.c-article-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-32);
}
@media (max-width: 900px) { .c-article-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .c-article-grid { grid-template-columns: 1fr; } }

/* --- お知らせリスト行（NewsListRow）-------------------------------------- */
/* トップページのお知らせ（.top-news）と同一レイアウト。 */
.c-news-list { list-style: none; margin: 0; padding: 0; }
.c-news-list__row {
  display: flex;
  align-items: center;
  gap: var(--space-24);
  padding: var(--space-24) 0;
  border-bottom: 1px solid var(--color-brown-text);
}
.c-news-list__date {
  flex: 0 0 auto;
  color: var(--color-brown-text);
  font-size: var(--font-size-h6);
  font-weight: var(--font-weight-bold);
}
.c-news-list__tags { flex: 0 0 auto; display: flex; gap: var(--space-8); }
/* 行内タグは小さめ（Figma: px-12 py-4 / 11.6px） */
.c-news-list__tags .c-tag { padding: var(--space-4) var(--space-12); }
.c-news-list__title {
  flex: 1;
  margin: 0;
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
}
.c-news-list__title a { color: var(--color-brown-text); text-decoration: none; }
.c-news-list__title a:hover { text-decoration: underline; }
/* SP：日付＋カテゴリを1行目、タイトルを2行目に折り返し（.top-news と同じ）。 */
@media (max-width: 768px) {
  .c-news-list__row { flex-wrap: wrap; gap: var(--space-8) var(--space-12); padding-block: var(--space-16); }
  .c-news-list__title { flex-basis: 100%; font-size: var(--font-size-sm); line-height: var(--line-height-base); }
  .c-news-list__date { font-size: var(--font-size-h6); }
}

/* --- カテゴリフィルタ（CategoryFilter）-----------------------------------
   「カテゴリー」ラベル＋縦罫線＋ALL/各カテゴリのピルチップ。
   ALL・選択中＝アクセント塗り、未選択＝茶アウトライン。 */
.c-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-24);
}
.c-filter__label {
  flex: 0 0 auto;
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  color: var(--color-brown-text);
}
.c-filter__divider {
  flex: 0 0 auto;
  align-self: stretch;
  width: 1px;
  background: var(--color-brown-text);
}
.c-filter__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-16);
  margin: 0;
  padding: 0;
  list-style: none;
}
.c-filter__chip {
  display: inline-flex;
  align-items: center;
  padding: 0.2em var(--space-16);
  border: 1px solid var(--color-brown-text);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--color-brown-text);
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-base);
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.c-filter__chip:hover,
.c-filter__chip.is-active {
  background: var(--color-accent) url(../../images/common/label-bg.png) center / cover no-repeat;
  border-color: var(--color-accent);
  color: var(--color-white);
}
/* SP（Figma 76:24698）：縦積みに切替。ラベル → 全幅の横罫線 → チップ折り返し。
   ラベル12.8px ExtraBold／チップ11.6px。 */
@media (max-width: 768px) {
  .c-filter {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-8);
  }
  .c-filter__label { font-size: var(--font-size-h6); font-weight: var(--font-weight-extrabold); }
  /* 縦罫線 → 全幅の横罫線へ */
  .c-filter__divider { width: 100%; height: 1px; align-self: auto; }
  /* 罫線 → チップ間を 16px に（親 gap 8 + margin 8）。チップ間は 8px。 */
  .c-filter__list { gap: var(--space-8); margin-top: 0; }
  .c-filter__chip { font-size: var(--font-size-xs); padding: 0.2em var(--space-16); }
}

/* --- パンくず（Breadcrumb）---------------------------------------------- */
.c-breadcrumb { font-size: var(--font-size-h6); color: var(--color-brown-sub); }
.c-breadcrumb ol {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin: 0;
  padding: var(--space-16) 0;
}
.c-breadcrumb li { display: flex; align-items: center; gap: var(--space-8); }
.c-breadcrumb li:not(:first-child)::before { content: "›"; color: var(--color-gray); }
.c-breadcrumb a { color: var(--color-brown-sub); text-decoration: none; }
.c-breadcrumb a:hover { text-decoration: underline; }

/* --- ページネーション（Pagination）------------------------------------- */
.c-pagination { margin-top: var(--space-48); }
.c-pagination ul {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: var(--space-8);
  margin: 0;
  padding: 0;
}
.c-pagination a,
.c-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--space-40);
  height: var(--space-40);
  padding: 0 var(--space-8);
  border: 1px solid var(--color-brown-text);
  border-radius: var(--radius-sm);
  color: var(--color-brown-text);
  font-weight: var(--font-weight-bold);
  text-decoration: none;
}
.c-pagination .current {
  background: var(--color-brown-text);
  border-color: var(--color-brown-text);
  color: var(--color-white);
}
.c-pagination a:hover { background: var(--color-bg-yellow); }
.c-pagination .dots { border-color: transparent; }

/* --- 一覧/詳細の2カラム ------------------------------------------------- */
.c-content-2col {
  display: grid;
  grid-template-columns: 1fr 18rem;
  gap: var(--space-48);
  max-width: var(--layout-max);
  margin-inline: auto;
  padding: var(--space-48) var(--space-24);
}
@media (max-width: 900px) { .c-content-2col { grid-template-columns: 1fr; } }

/* --- 関連記事サイドバー（RelatedSidebar）-------------------------------- */
.c-sidebar__heading {
  font-size: var(--font-size-h4);
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: var(--space-8);
  margin-bottom: var(--space-16);
}
.c-sidebar__list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-16); }
