/* Button — .btn, .btn--primary, .btn--ghost, .btn--danger
 * States: default, hover, focus, active, disabled.
 * Semantic variants pair only with their meaning's token (see semantic-color.md).
 */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: inherit;
  font-size: var(--size-1);
  font-weight: var(--weight-medium);
  line-height: 1;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--line-1);
  border-radius: var(--radius-3);
  background: var(--bg-1);
  color: var(--fg-0);
  cursor: pointer;
  text-decoration: none;
  transition:
    background var(--duration-fast) var(--ease-standard),
    border-color var(--duration-fast) var(--ease-standard),
    color var(--duration-fast) var(--ease-standard);
}
.btn:hover { background: var(--bg-2); border-color: var(--fg-2); }
.btn:active { background: var(--bg-0); }
.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.55;
  cursor: not-allowed;
}

/* Primary — informational/affirmative action */
.btn--primary {
  background: var(--info-bg);
  border-color: var(--info);
  color: var(--fg-0);
}
.btn--primary:hover { background: var(--info); color: var(--bg-0); }

/* Ghost — secondary action, no fill */
.btn--ghost {
  background: transparent;
  border-color: var(--line-0);
}
.btn--ghost:hover { background: var(--bg-1); }

/* Danger — destructive action; pairs with --danger only */
.btn--danger {
  background: var(--danger-bg);
  border-color: var(--danger);
  color: var(--fg-0);
}
.btn--danger:hover { background: var(--danger); color: var(--bg-0); }

/* Sizes */
.btn--sm { padding: var(--space-2) var(--space-3); font-size: var(--size-0); }
.btn--lg { padding: var(--space-4) var(--space-5); font-size: var(--size-2); }
