/*
 * Archive UI — toolbar (sort + view toggle), AJAX pagination, list view.
 * Layered onto existing .news-grid markup; doesn't replace it.
 */

.archive-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sf-space-4);
  margin: var(--sf-space-6) 0 var(--sf-space-4);
  padding-bottom: var(--sf-space-3);
  border-bottom: 1px solid var(--sf-color-border);
  font-size: var(--sf-text-sm);
}

.archive-count {
  font-weight: 600;
  color: var(--sf-color-text-muted);
}

/* ---------- Sort pills ---------- */

.archive-sort {
  display: flex;
  align-items: center;
  gap: var(--sf-space-2);
  margin-left: auto;
}

.archive-sort__label {
  color: var(--sf-color-text-muted);
  margin-right: var(--sf-space-1);
}

.archive-sort button,
.archive-view button {
  appearance: none;
  background: transparent;
  border: 1px solid var(--sf-color-border);
  border-radius: var(--sf-radius-pill);
  padding: var(--sf-space-1) var(--sf-space-3);
  cursor: pointer;
  font-family: var(--sf-font-body);
  font-size: var(--sf-text-sm);
  color: var(--sf-color-text);
  transition: border-color var(--sf-duration-fast) var(--sf-ease),
              background    var(--sf-duration-fast) var(--sf-ease),
              color         var(--sf-duration-fast) var(--sf-ease);
}

.archive-sort button:hover,
.archive-view button:hover {
  border-color: var(--sf-color-accent);
  color: var(--sf-color-accent);
}

.archive-sort button.active,
.archive-view button.active {
  background: var(--sf-color-accent);
  border-color: var(--sf-color-accent);
  color: var(--sf-color-text-inverse);
}

/* ---------- View toggle ---------- */

.archive-view {
  display: inline-flex;
  gap: var(--sf-space-1);
}

.archive-view button {
  width: 2rem;
  padding: var(--sf-space-1);
  font-size: var(--sf-text-md);
  text-align: center;
}

/* ---------- List view ---------- */

.news-grid.view-list {
  display: flex;
  flex-direction: column;
  gap: var(--sf-space-4);
}

.news-grid.view-list .news-article {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sf-space-4);
  align-items: start;
}

.news-grid.view-list .news-image {
  margin: 0;
}

@media (max-width: 640px) {
  .news-grid.view-list .news-article {
    grid-template-columns: 1fr;
  }
}

/* ---------- Loading state ---------- */

.news-grid.is-loading {
  opacity: 0.5;
  pointer-events: none;
  transition: opacity var(--sf-duration-fast) var(--sf-ease);
}

/* ---------- AJAX pagination ---------- */

.archive-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--sf-space-1);
  margin: var(--sf-space-12) 0 var(--sf-space-4);
}

.archive-pagination button {
  appearance: none;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 var(--sf-space-2);
  border: 1px solid var(--sf-color-border);
  border-radius: var(--sf-radius-sm);
  background: transparent;
  cursor: pointer;
  font-family: var(--sf-font-body);
  font-size: var(--sf-text-sm);
  color: var(--sf-color-text);
  transition: all var(--sf-duration-fast) var(--sf-ease);
}

.archive-pagination button:hover:not(:disabled) {
  border-color: var(--sf-color-accent);
  color: var(--sf-color-accent);
}

.archive-pagination button.active {
  background: var(--sf-color-accent);
  border-color: var(--sf-color-accent);
  color: var(--sf-color-text-inverse);
  cursor: default;
}

.archive-pagination button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.archive-pagination .ellipsis {
  padding: 0 var(--sf-space-1);
  color: var(--sf-color-text-muted);
}

@media (max-width: 480px) {
  .archive-toolbar {
    gap: var(--sf-space-2);
  }
  .archive-sort {
    margin-left: 0;
    width: 100%;
    flex-wrap: wrap;
  }
}
