.news-hub {
  background: linear-gradient(135deg, rgba(15,31,51,0.95), rgba(10,21,35,0.88));
}

.news-hub__heading {
  max-width: 78ch;
  margin-bottom: var(--space-5);
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
  align-items: stretch;
}

.news-grid--compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.news-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.08);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.news-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: rgba(255,255,255,0.12);
}

.news-card__media {
  position: relative;
  display: block;
  aspect-ratio: 5 / 3;
  overflow: hidden;
}

.news-grid--compact .news-card__media {
  aspect-ratio: 16 / 9;
}

.news-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform 0.25s ease;
}

.news-card:hover .news-card__media img {
  transform: scale(1.05);
}

.news-card__badge {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  padding: var(--space-2) var(--space-3);
  border-radius: 999px;
  background: rgba(8, 19, 32, 0.88);
  border: 1px solid rgba(255,255,255,0.1);
  font-size: var(--text-xs);
}

.news-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.news-card__meta {
  margin: 0;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 11px;
}

.news-card__excerpt {
  margin: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.news-card__cta {
  margin-top: auto;
  display: inline-flex;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.news-card__cta:hover {
  transform: translateY(-1px);
}

.news-card__cta:focus-visible {
  outline: 2px solid var(--focus-outline);
  outline-offset: 3px;
}

.news-pager {
  margin-top: 22px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.news-pager__link {
  display: inline-grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.04);
  color: var(--muted);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.news-pager__link:hover,
.news-pager__link.is-active {
  color: var(--text);
  background: rgba(255,255,255,0.08);
}

.news-pager__link:focus-visible {
  outline: 2px solid var(--focus-outline);
  outline-offset: 3px;
}

.news-article {
  background: linear-gradient(135deg, rgba(18,39,65,0.96), rgba(7,16,28,0.94));
}

.news-article__header {
  max-width: 82ch;
}

.news-article__lead {
  font-size: 18px;
  line-height: 1.65;
  margin-top: 10px;
}

.news-article__hero {
  margin-top: 18px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}

.news-article__hero img {
  width: 100%;
  height: auto;
}

.news-article__body {
  max-width: 78ch;
  font-size: 18px;
  line-height: 1.7;
  margin-top: 18px;
}

.news-article__body a {
  text-decoration: underline;
  text-decoration-color: rgba(255,255,255,0.24);
  text-underline-offset: 4px;
}

.news-article__back {
  margin-top: 18px;
}

@media (max-width: 1100px) {
  .news-grid,
  .news-grid--compact {
    grid-template-columns: 1fr;
  }
}
.news-featured {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-6);
  min-height: 420px;
}

.news-featured img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  filter: saturate(1.06) contrast(1.05);
}

.news-featured__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-9);
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.58) 58%, rgba(0,0,0,0.92) 100%);
}

.news-featured__meta,
.news-featured h2,
.news-featured__excerpt {
  text-shadow: 0 2px 18px rgba(0,0,0,0.7);
}

.news-featured__meta {
  margin: 0 0 10px;
  color: rgba(255,255,255,0.78);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 11px;
}

.news-featured h2 {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-size: clamp(26px, 3.2vw, 44px);
  line-height: 1.05;
}

.news-featured__excerpt {
  margin: 0;
  max-width: 78ch;
  color: rgba(255,255,255,0.86);
  font-size: 16px;
  line-height: 1.6;
}

.news-featured__cta {
  display: inline-flex;
  align-self: flex-start;
  margin-top: 18px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.08);
}

@media (max-width: 780px) {
  .news-featured {
    min-height: 320px;
  }

  .news-featured__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-9);
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.58) 58%, rgba(0,0,0,0.92) 100%);
}

.news-featured__meta,
.news-featured h2,
.news-featured__excerpt {
  text-shadow: 0 2px 18px rgba(0,0,0,0.7);
}
/* Home magazine block: compact list (avoid stretched tiny columns) */
.magazine-feature__grid.news-grid--compact {
  grid-template-columns: 1fr;
}

.magazine-feature__grid .news-card {
  flex-direction: row;
  align-items: stretch;
}

.magazine-feature__grid .news-card__media {
  width: 220px;
  flex: 0 0 auto;
  aspect-ratio: auto;
}

.magazine-feature__grid .news-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 780px) {
  .magazine-feature__grid .news-card {
    flex-direction: column;
  }

  .magazine-feature__grid .news-card__media {
    width: auto;
    aspect-ratio: 16 / 9;
  }
}
