* { box-sizing: border-box; }
body { font-family: system-ui, -apple-system, sans-serif; margin: 0; padding: 2rem; background: #f8fafc; color: #111827; }
.container { max-width: 1000px; margin: 0 auto; }
h1 { margin: 1.245rem 0 0.5rem; font-size: 2rem; }
.header-desc { color: #6b7280; margin: 0.25rem 0 1.5rem; font-size: 0.9rem; }
a { color: #1d4ed8; text-decoration: none; }
a:hover { text-decoration: underline; }
.back-link { display: inline-block; margin-bottom: 1rem; font-size: 0.9rem; color: #6b7280; }

.news-list-compact { background: white; border: 1px solid #e5e7eb; border-radius: 0.75rem; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.news-row { display: grid; grid-template-columns: 80px 1fr 90px; align-items: start; gap: 0.75rem; padding: 0.75rem 1.25rem; border-bottom: 1px solid #f3f4f6; }
.news-row:last-child { border-bottom: none; }
.news-row:hover { background: #f9fafb; }
.news-row-thumb { width: 80px; height: 54px; border-radius: 0.375rem; overflow: hidden; background: #f3f4f6; }
.news-row-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.news-row-body { min-width: 0; }
.news-row-source { font-size: 0.72rem; font-weight: 600; color: #1d4ed8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 0.2rem; }
.news-row-title { font-size: 0.9rem; line-height: 1.2; }
.news-row-title a { color: #111827; text-decoration: none; }
.news-row-title a:hover { color: #1d4ed8; }
.news-row-title strong { font-weight: 600; }
.news-row-desc { font-size: 0.82rem; color: #6b7280; line-height: 1.45; margin-top: 0.25rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.news-row-author { font-size: 0.72rem; color: #9ca3af; margin-top: 0.25rem; }
.news-row-time { font-size: 0.75rem; color: #9ca3af; text-align: right; white-space: nowrap; padding-top: 0.1rem; }
.footer { margin-top: 2rem; font-size: 0.85rem; color: #9ca3af; text-align: center; }
