@layer components {
  .tag {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: var(--radius-md);
    padding: 0.25rem 0.625rem;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
    transition: background-color 150ms ease, color 150ms ease;

    &[data-variant="default"] {
      background-color: var(--primary);
      color: var(--primary-foreground);

      & .tag-dismiss {
        color: var(--primary-foreground);
        opacity: 0.6;

        &:hover {
          opacity: 1;
        }
      }
    }

    &[data-variant="secondary"] {
      background-color: var(--secondary);
      color: var(--secondary-foreground);

      & .tag-dismiss {
        color: var(--secondary-foreground);
        opacity: 0.6;

        &:hover {
          opacity: 1;
        }
      }
    }

    &[data-variant="outline"] {
      border: 1px solid var(--border);
      color: var(--foreground);
      background-color: transparent;

      & .tag-dismiss {
        color: var(--foreground);
        opacity: 0.6;

        &:hover {
          opacity: 1;
        }
      }
    }
  }

  .tag-dismiss {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1rem;
    height: 1rem;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: var(--radius-sm);
    flex-shrink: 0;

    & svg {
      width: 0.75rem;
      height: 0.75rem;
    }

    &:focus-visible {
      outline: 2px solid var(--ring);
      outline-offset: 1px;
    }
  }
}
