/* ============================================================
   index.css — Punto de Mira
   Estilos para páginas índice de sección:
   /deporte/reviews, /deporte/reportajes, etc.

   Reutiliza de common.css:
     · Variables, reset, tipografía, header, footer
     · .container, .breadcrumb-nav
     · .section-label, .section-label--*
     · .article-tag, .article-tag--*
     · .article-card, .card-*, .review-card-footer, .review-score
   Reutiliza de home.css:
     · .review-score, .review-score-value, .review-score-max
     · .review-card-footer
     · .reportaje-item, .reportaje-img-wrap, .reportaje-body, etc.
   ============================================================ */


/* ── 1. CABECERA DE SECCIÓN ────────────────────────────────── */

.index-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-8);
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
  border-bottom: 4px solid var(--color-rule);
  margin-bottom: var(--space-10);
}

/* Acento de color por categoría en la línea inferior */
.index-header--review    { border-bottom-color: #f5ede0; }
.index-header--reportaje { border-bottom-color: #e8eef5; }
.page-index--deporte .index-header { border-bottom-color: #e8f0e8; }

.index-header-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.index-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  font-weight: 700;
  color: var(--color-ink);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}

.index-description {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink-light);
  line-height: 1.65;
  max-width: 60ch;
  margin: 0;
}

.index-header-meta {
  flex-shrink: 0;
  text-align: right;
}

.index-count {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-ink-ghost);
}

.index-count strong {
  font-size: var(--text-2xl);
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--color-ink);
  display: block;
  line-height: 1;
}


/* ── 2. FEATURED — artículo destacado ──────────────────────── */

.index-featured {
  margin-bottom: var(--space-12);
}

.featured-link {
  display: block;
  text-decoration: none;
}

.featured-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--color-rule);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition-base);
}

.featured-link:hover .featured-card {
  box-shadow: var(--shadow-md);
}

.featured-img-wrap {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background-color: var(--color-ink);
}

.featured-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-slow);
}

.featured-link:hover .featured-img-wrap img {
  transform: scale(1.03);
}

.featured-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-8);
  background-color: var(--color-paper-card);
}

.featured-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.featured-meta time {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  color: var(--color-ink-ghost);
  margin-left: var(--space-1);
}

.featured-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-lg), 2vw, var(--text-2xl));
  font-weight: 700;
  color: var(--color-ink);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0;
  transition: color var(--transition-fast);
}

.featured-link:hover .featured-title {
  color: var(--color-accent);
}

.featured-excerpt {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink-light);
  line-height: 1.65;
  margin: 0;
  flex: 1;
}

.featured-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-rule);
  margin-top: auto;
}

.featured-author {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-ink-light);
}

.featured-read-time {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-ink-ghost);
}


/* ── 3. LISTA DE ARTÍCULOS ─────────────────────────────────── */

.index-list {
  margin-bottom: var(--space-16);
}

.index-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--space-5);
  border-bottom: 1.5px solid var(--color-ink);
  margin-bottom: var(--space-8);
}

.index-list-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-ink);
  margin: 0;
}


/* ── 4. FILTROS POR SUBCATEGORÍA ───────────────────────────── */

.index-filters {
  margin-bottom: var(--space-10);
}

.filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.filter-pill {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-ink-mid);
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-rule);
  border-radius: 999px;
  text-decoration: none;
  transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast);
  white-space: nowrap;
}

.filter-pill:hover {
  border-color: var(--color-ink-mid);
  color: var(--color-ink);
}

.filter-pill--active {
  background-color: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-paper);
}

.filter-pill--active:hover {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-paper);
}

/* Variante review — pill activo en color acento review */
.page-index--review .filter-pill--active {
  background-color: var(--color-tag-review);
  border-color: var(--color-tag-review);
}

/* Variante reportaje */
.page-index--reportaje .filter-pill--active {
  background-color: var(--color-tag-reportaje);
  border-color: var(--color-tag-reportaje);
}


/* ── 5. LISTA DEPORTE — reviews y reportajes mezclados ─────── */

.deporte-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Los botones de filtro en /deporte usan button en lugar de a */
.filter-list button.filter-pill {
  background: none;
  border: 1px solid var(--color-rule);
  cursor: pointer;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-ink-mid);
  padding: var(--space-2) var(--space-4);
  border-radius: 999px;
  transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast);
  white-space: nowrap;
}

.filter-list button.filter-pill:hover {
  border-color: var(--color-ink-mid);
  color: var(--color-ink);
}

.filter-list button.filter-pill.filter-pill--active {
  background-color: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-paper);
}

.filter-list button.filter-pill.filter-pill--active:hover {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
}


/* ── 6. PAGINACIÓN ─────────────────────────────────────────── */

.index-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding-top: var(--space-10);
  border-top: 1px solid var(--color-rule);
  margin-top: var(--space-8);
}

.pagination-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-ink-mid);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.pagination-btn:hover {
  color: var(--color-accent);
  background-color: var(--color-accent-light);
}

.pagination-btn--prev[aria-disabled="true"] {
  color: var(--color-ink-ghost);
  pointer-events: none;
}

.pagination-pages {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0;
}

.pagination-page {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-ink-mid);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.pagination-page:hover {
  color: var(--color-accent);
  background-color: var(--color-accent-light);
}

.pagination-page--active {
  background-color: var(--color-ink);
  color: var(--color-paper);
}

.pagination-page--active:hover {
  background-color: var(--color-accent);
  color: var(--color-paper);
}

.pagination-ellipsis {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-ink-ghost);
  padding: 0 var(--space-1);
}


/* ── 6. RESPONSIVE ─────────────────────────────────────────── */

@media (max-width: 900px) {
  .index-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
  }

  .index-header-meta {
    text-align: left;
  }

  .featured-card {
    grid-template-columns: 1fr;
  }

  .featured-img-wrap {
    aspect-ratio: 16 / 9;
  }

  .featured-body {
    padding: var(--space-6);
  }
}

@media (max-width: 640px) {
  .featured-body {
    padding: var(--space-5);
  }

  .featured-title {
    font-size: var(--text-xl);
  }
}
