/* =========================================================
  posts-all-main.css
  - 전체보기 페이지 전용
  - tokens.css 기반 (색/간격/라운드/보더)
========================================================= */

/* 페이지 헤더(타이틀) */
.posts-all__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-12);
}

/* =========================
  1) 고정(공지) 영역
========================= */

.posts-all__notice {
  margin-top: var(--space-16);
  padding: var(--space-16);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  background: var(--color-surface);
}

.posts-all__notice-title {
  margin: 0 0 var(--space-12);
  font-size: var(--text-small);
  color: var(--color-text-sub);
}

/* 고정 리스트 컨테이너 */
.posts-all__notice-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* =========================
  2) 탭
========================= */

.posts-all__tabs {
  margin-top: var(--space-16);
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-wrap: wrap;
}

/* 탭 버튼(침하하 느낌: 심플, pill) */
.tab-btn {
  height: 34px;
  padding: 0 var(--space-12);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--text-small);
  cursor: pointer;
}

.tab-btn:hover {
  filter: brightness(0.98);
}

.tab-btn.is-active,
.tab-btn[aria-selected='true'] {
  border-color: var(--color-primary);
  background: var(--color-primary-sub);
}

/* =========================
  3) 게시물 리스트
========================= */

.posts-all__list {
  margin-top: var(--space-16);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  background: var(--color-surface);
  overflow: hidden; /* row border 깔끔하게 */
}

.posts-all__rows {
  display: flex;
  flex-direction: column;
}

/* 한 줄(침하하 행 느낌) */
.post-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--space-12);
  padding: var(--space-12) var(--space-16);
  text-decoration: none;
  color: var(--color-text);
  border-top: 1px solid var(--color-border);
}

.post-row:first-child {
  border-top: none;
}

.post-row:hover {
  background: var(--color-primary-sub);
}

/* 제목 */
.post-row__title {
  font-size: var(--text-body);
  line-height: var(--line-body);
}

/* 메타(날짜/조회수/카테고리) */
.post-row__meta {
  font-size: 12px;
  color: var(--color-text-sub);
  white-space: nowrap;
}

/* 고정글은 살짝 강조 */
.post-row--pinned {
  background: var(--color-primary-sub);
}

/* 고정 배지(옵션) */
.post-row__badge {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 var(--space-8);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  font-size: 12px;
  color: var(--color-text-sub);
  background: var(--color-surface);
  margin-right: var(--space-8);
}

/* 작은 화면에서 메타 줄바꿈 */
@media (max-width: 560px) {
  .post-row {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .post-row__meta {
    justify-self: start;
  }
}

/* =========================
  4) 페이지네이션
  - 주간체크 버튼(weekly-nav__btn) 스타일 재사용
========================= */

.posts-all__pager {
  margin-top: var(--space-16);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-12);
}
