/* public/css/fm/chip.css
 *
 * fm-chip (DS #2) — consolida a família .label (primary/inverse/muted/filter).
 * Autocontido (skin coexiste): box-sizing, fonte, cor, reset de <button>.
 * Consome tokens fm. Estado is-active = teal (cor de ação/seleção da marca —
 * unifica o navy do blog e o teal do hub).
 */
.fm-chip {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  gap: var(--fm-space-1);
  margin: 0;
  padding: 0.32rem 0.7rem; /* esbelto: menos altura que o .label do skin */
  border: 1px solid transparent;
  border-radius: var(--fm-radius-pill);
  font-family: var(--fm-font-body);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--fm-navy);
  background: transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
/* quando clicável (filtro) */
button.fm-chip {
  cursor: pointer;
}
button.fm-chip:focus-visible {
  outline: none;
  box-shadow: var(--fm-shadow-focus);
}

/* —— variantes —— */
.fm-chip--outline {
  border-color: var(--fm-gray-100);
}
.fm-chip--outline:is(button):hover {
  border-color: var(--fm-navy);
}
.fm-chip--solid {
  background: var(--fm-navy);
  color: var(--fm-white);
}
.fm-chip--muted {
  background: var(--fm-gray-100);
  color: var(--fm-navy);
}
.fm-chip--muted:is(button):hover {
  background: var(--fm-gray-300);
}

/* —— estado ATIVO (filtro selecionado): teal —— */
.fm-chip.is-active {
  background: var(--fm-teal);
  border-color: var(--fm-teal);
  color: var(--fm-white);
}
