/* ── Rinsa News · news.css ──────────────────────────────────────────────── */
:root {
  --hub-accent: #1A2E50;
  --news-red:   #B01C2E;
  --news-navy:  #1A2E50;
}

/* ── Layout ────────────────────────────────────────────────────────────── */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 1024px) { .news-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .news-grid { grid-template-columns: 1fr; } }

/* ── Year filter tabs ───────────────────────────────────────────────────── */
.year-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  border-bottom: 2px solid var(--color-gray-100);
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-7);
}
.year-tab {
  padding: 8px 20px;
  border-radius: var(--radius-full);
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  background: transparent;
  color: var(--color-gray-500);
  transition: all 180ms ease;
}
.year-tab:hover { color: var(--color-black-soft); background: var(--color-gray-100); }
.year-tab.is-active {
  background: var(--news-navy);
  color: white;
  border-color: var(--news-navy);
}

/* ── News card ──────────────────────────────────────────────────────────── */
.news-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-gray-100);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 250ms ease, transform 250ms ease;
  position: relative;
}
.news-card:hover { box-shadow: 0 8px 28px rgba(0,0,0,0.09); transform: translateY(-3px); }

/* Destacada */
.news-card--featured { border-color: var(--news-red); box-shadow: 0 0 0 2px rgba(176,28,46,0.12); }
.news-card__featured-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background: var(--news-red);
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 4px;
  z-index: 1;
}

.news-card__thumb {
  width: 100%;
  height: 180px;
  object-fit: cover;
  background: linear-gradient(135deg, #E8E4DE 0%, #D4CFC8 100%);
  display: block;
  position: relative;
}
.news-card__thumb-placeholder {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, #E8E4DE 0%, #D4CFC8 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.news-card__body { padding: var(--space-5); flex: 1; display: flex; flex-direction: column; gap: var(--space-2); }
.news-card__meta { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.news-card__date { font-size: 12px; color: var(--color-gray-400); }
.news-card__cat {
  font-size: 11px;
  font-weight: 600;
  color: var(--news-navy);
  background: color-mix(in srgb, var(--news-navy) 8%, transparent);
  padding: 2px 9px;
  border-radius: 20px;
}
.news-card__title {
  font-family: var(--font-heading);
  font-size: 15px;
  font-weight: 700;
  color: var(--color-black-soft);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card__summary {
  font-size: 13px;
  color: var(--color-gray-600);
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}
.news-card__tags { display: flex; flex-wrap: wrap; gap: 4px; }
.news-card__tag  { font-size: 11px; color: var(--color-gray-400); background: var(--color-gray-100); padding: 2px 8px; border-radius: 20px; }
.news-card__footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-gray-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.news-card__read-btn {
  font-size: 13px;
  font-weight: 600;
  color: var(--news-navy);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  text-decoration: none;
  transition: gap 180ms ease;
}
.news-card__read-btn:hover { gap: 8px; }
.news-card__read-btn--disabled {
  color: var(--color-gray-300);
  cursor: not-allowed;
  pointer-events: none;
}

/* ── Stats strip ────────────────────────────────────────────────────────── */
.news-stats {
  display: flex;
  gap: var(--space-8);
  justify-content: center;
  padding: var(--space-6) 0;
}
.news-stat { text-align: center; }
.news-stat__num { font-family: var(--font-heading); font-size: 2.2rem; font-weight: 800; color: var(--news-navy); line-height: 1; }
.news-stat__label { font-size: 13px; color: var(--color-gray-500); margin-top: 4px; }

/* ── Loading skeleton ───────────────────────────────────────────────────── */
.skeleton { background: linear-gradient(90deg, #f0ede8 25%, #e6e2dc 50%, #f0ede8 75%); background-size: 200% 100%; animation: skeleton-shimmer 1.5s infinite; border-radius: var(--radius-md); }
@keyframes skeleton-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .news-stats { gap: var(--space-5); }
  .news-stat__num { font-size: 1.6rem; }
}
