/* ─── Tabs ─────────────────────────────────────────────────────────────────── */

.tabs {
  display: flex;
  align-items: center;
  gap: 2px;
  border-bottom: 1px solid var(--gray-200);
  overflow-x: auto;
  scrollbar-width: none;
}

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

.tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--gray-500);
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--transition), border-color var(--transition);
  text-decoration: none;
}

.tab:hover {
  color: var(--gray-700);
}

.tab.active {
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
  font-weight: 600;
}

/* Count badge inside a tab */
.tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  padding: 1px 7px;
  background: var(--gray-100);
  color: var(--gray-500);
  font-size: 11px;
  font-weight: 700;
  border-radius: var(--r-full);
}

/* Tab content — Bootstrap JS adds/removes .show + .active */
.tab-pane {
  display: none;
}

.tab-pane.active {
  display: block;
}

/* Tab panel — Stimulus tabs_controller (data-tabs-target="panel") */
.tab-panel.hidden {
  display: none;
}
