/* ===== News Page Specific Styles ===== */

.news-card {
  background: #fff; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--border); transition: all var(--transition);
}
.news-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.news-image { height: 180px; background: var(--bg-alt); overflow: hidden; }
.news-image .image-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-light); font-size: 14px; background: var(--bg-alt);
}
.news-body { padding: 20px; }
.news-date { font-size: 12px; color: var(--text-light); display: block; margin-bottom: 8px; }
.news-body h3 { font-size: 17px; margin-bottom: 8px; line-height: 1.4; }
.news-body h3 a { color: var(--text); }
.news-body h3 a:hover { color: var(--primary); }
.news-body p { font-size: 14px; margin-bottom: 12px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.news-link { font-size: 13px; font-weight: 600; color: var(--primary); }
.news-link:hover { color: var(--accent); }

.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 40px; }
.page-num {
  padding: 8px 16px; border-radius: 6px; border: 1px solid var(--border);
  font-size: 14px; color: var(--text); transition: all var(--transition);
}
.page-num:hover, .page-num.active { background: var(--primary); color: #fff; border-color: var(--primary); }
