@charset "utf-8";
/* ── news.css — お知らせページ専用 ── */

/* ページ全体 */
.news-page {
  padding-top: 140px; /* 固定ヘッダー分 */
}

/* セクション */
.news-section {
  padding: 80px 20px;
  text-align: center;
  background-color: var(--color-bg-light);
}
.news-section .section-heading {
  margin-bottom: 8px;
}
.news-section .section-sub {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: #666;
  margin-bottom: 40px;
}

/* リスト */
.news-list {
  display: flex;
  flex-direction: column;
  gap: 32px;
  max-width: 800px;
  margin: 0 auto;
}

/* 各アイテム */
.news-item {
  display: flex;
  background-color: var(--color-bg-base);
  border-radius: 4px;
  overflow: hidden;
}
.news-item:nth-child(even) {
  flex-direction: row-reverse; /* 偶数は画像を左、テキストを右 */
}

.news-content,
.news-image {
  flex: 1;
}

/* テキスト側 */
.news-content {
  padding: 24px;
  text-align: left;
}
.news-date {
  display: block;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: #999;
  margin-bottom: 8px;
}
.news-title {
  font-family: var(--font-catch);
  font-size: var(--font-size-lg);
  margin: 0 0 12px;
}
.news-excerpt {
  font-family: var(--font-body);
  font-size: var(--font-size-md);
  line-height: var(--lh-loose);
  color: #333;
}

/* 画像側 */
.news-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ページネーション */
.pagination {
  margin: 40px 0 80px;
  text-align: center;
}
.pagination .page-num {
  display: inline-block;
  margin: 0 4px;
  padding: 8px 12px;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: var(--color-bg-dark);
  text-decoration: none;
  border: 1px solid #ccc;
  border-radius: 4px;
  transition: background-color 0.3s;
}
.pagination .page-num.active,
.pagination .page-num:hover {
  background-color: var(--color-bg-mid);
  color: #fff;
  border-color: var(--color-bg-mid);
}
.pagination .ellipsis {
  display: inline-block;
  margin: 0 8px;
  color: #999;
}

/* レスポンシブ */
@media (max-width: 767px) {
  .news-item {
    flex-direction: column !important;
  }
  .news-image {
    order: -1; /* 画像を上に */
  }
  .news-image img {
    height: auto;
  }
}
