/* ===== 카테고리 페이지 ===== */

.cat {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: calc(var(--header-height) + 20px) var(--page-padding) 80px;
}

/* 카테고리 헤더 */
.cat__header {
  margin-bottom: 20px;
}

.cat__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-bottom: 12px;
}

.cat__breadcrumb a {
  transition: color var(--ease-fast);
}

.cat__breadcrumb a:hover {
  color: var(--text-primary);
}

.cat__breadcrumb span {
  color: var(--text-muted);
}

.cat__title {
  font-family: var(--font-body);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  margin-bottom: 4px;
}

.cat__desc {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.cat__desc strong {
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
}

/* 소카테고리 탭 */
.cat__tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.cat__tabs::-webkit-scrollbar {
  display: none;
}

.cat__tab {
  padding: 8px 20px;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  background: var(--surface-white);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--ease-fast);
  white-space: nowrap;
  flex-shrink: 0;
}

.cat__tab:hover {
  border-color: var(--text-secondary);
}

.cat__tab--active {
  background: var(--brand-primary);
  color: var(--text-inverse);
  border-color: var(--brand-primary);
}

/* 정렬 바 */
.cat__sort {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 24px;
}

.cat__sort-left {
  display: flex;
  gap: 4px;
}

.cat__sort-btn {
  padding: 6px 12px;
  font-size: var(--text-xs);
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--ease-fast);
}

.cat__sort-btn:hover {
  color: var(--text-primary);
}

.cat__sort-btn--active {
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
}

.cat__sort-right {
  display: flex;
  gap: 4px;
}

.cat__view {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: none;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--ease-fast);
}

.cat__view:hover {
  color: var(--text-primary);
  background: var(--surface-light);
}

.cat__view--active {
  color: var(--text-primary);
}

/* 페이지네이션 */
.cat__pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 48px;
}

.cat__page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 8px;
  font-size: var(--text-sm);
  font-family: var(--font-ui);
  color: var(--text-secondary);
  background: none;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--ease-fast);
}

.cat__page:hover:not(:disabled) {
  border-color: var(--border-subtle);
  background: var(--surface-light);
}

.cat__page--active {
  background: var(--brand-primary);
  color: var(--text-inverse);
  border-color: var(--brand-primary);
}

.cat__page--active:hover {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
}

.cat__page:disabled {
  opacity: 0.3;
  cursor: default;
}

.cat__page-dots {
  font-size: var(--text-sm);
  color: var(--text-muted);
  padding: 0 4px;
}

/* ===== 반응형 ===== */
@media (max-width: 768px) {
  .cat {
    padding-left: 16px;
    padding-right: 16px;
  }

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

  .cat__sort-left { overflow-x: auto; scrollbar-width: none; }
  .cat__sort-left::-webkit-scrollbar { display: none; }

  .cat__sort-right { display: none; }
}

@media (max-width: 480px) {
  .cat__title { font-size: var(--text-lg); }
  .cat__tab { padding: 6px 14px; font-size: var(--text-xs); }
}