/* ============================================================
   Shared catalog UI — toolbar / category chips / pagination
   exam · course · store 공통. (tests-catalog.css 에서 이관)
   ============================================================ */

/* ---- Toolbar + category chips ---- */
.catalog-toolbar {
  display: flex;
  align-items: center;
  gap: var(--gio-space-3);
  flex-wrap: wrap;
  padding: var(--gio-space-4) 0;
  border-bottom: 1px solid var(--gio-color-divider);
  margin-bottom: var(--gio-space-7);
}
.catalog-toolbar__chips {
  display: flex; gap: var(--gio-space-2); flex-wrap: wrap;
}
.catalog-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: var(--gio-color-surface);
  border: 1px solid var(--gio-color-border);
  border-radius: var(--gio-radius-pill);
  font-size: var(--gio-text-sm);
  font-weight: var(--gio-w-semibold);
  color: var(--gio-color-text-muted);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--gio-dur-fast) var(--gio-ease-out);
}
.catalog-chip:hover { color: var(--gio-color-text-strong); border-color: var(--gio-color-border-strong); }
.catalog-chip--active {
  background: var(--gio-color-text-strong);
  border-color: var(--gio-color-text-strong);
  color: var(--gio-color-bg);
}
.catalog-chip__count {
  font-size: 11px;
  font-weight: var(--gio-w-semibold);
  padding: 2px 6px;
  background: var(--gio-color-bg-subtle);
  color: var(--gio-color-text-muted);
  border-radius: var(--gio-radius-pill);
}
.catalog-chip--active .catalog-chip__count {
  background: rgba(255,255,255,0.2);
  color: var(--gio-color-bg);
}
.catalog-toolbar__search {
  margin-left: auto;
  position: relative;
  width: 280px;
  max-width: 100%;
}
.catalog-toolbar__search .input {
  padding-left: 36px;
}
.catalog-toolbar__search::before {
  content: '';
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  width: 14px; height: 14px;
  background: var(--gio-color-text-muted);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><path d='M11 11l3.5 3.5' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><path d='M11 11l3.5 3.5' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat;
}

/* ---- Result bar ---- */
.catalog-resultbar {
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text-muted);
  font-weight: var(--gio-w-semibold);
  margin-bottom: var(--gio-space-4);
}

/* ---- Pagination (pagination.gio markup) ---- */
.catalog-pagination {
  display: flex;
  justify-content: center;
  margin-top: var(--gio-space-7);
}
.catalog-pagination .pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.catalog-pagination .page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  border: 1px solid var(--gio-color-border);
  border-radius: var(--gio-radius-md);
  background: var(--gio-color-surface);
  color: var(--gio-color-text);
  font-size: var(--gio-text-sm);
  font-weight: var(--gio-w-semibold);
  text-decoration: none;
}
.catalog-pagination .page-link:hover {
  border-color: var(--gio-color-border-strong);
  color: var(--gio-color-text-strong);
}
.catalog-pagination .page-item.active .page-link {
  background: var(--gio-color-action);
  border-color: var(--gio-color-action);
  color: var(--gio-color-text-on-action, #fff);
}
.catalog-pagination .page-item.disabled .page-link {
  opacity: .45;
  pointer-events: none;
}
