/* Circle Button Component Styles */

.circle-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--circle-button-size, 40px);
  height: var(--circle-button-size, 40px);
  min-width: var(--circle-button-size, 40px);
  min-height: var(--circle-button-size, 40px);
  border-radius: 50%;
  background-color: var(--color-6);
  color: white;
  border: none;
  cursor: pointer;
  transition: background-color 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
}

/* Tamaños predefinidos */
.circle-button.small {
  --circle-button-size: 30px;
}

.circle-button.medium {
  --circle-button-size: 40px;
}

.circle-button.large {
  --circle-button-size: 50px;
}

.circle-button:hover {
  background-color: var(--color-5);
}

.circle-button:active {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.circle-button.disabled {
  background-color: var(--color-2);
  cursor: not-allowed;
  transform: none;
}

.circle-button.pink {
  background-color: var(--color-6);
}

.circle-button.pink:hover {
  background-color: var(--color-5);
}

.circle-button.purple {
  background-color: var(--color-4);
}

.circle-button.purple:hover {
  background-color: var(--color-2);
}

.circle-button .icon {
  width: 40%;
  height: 40%;
  fill: currentColor;
}

.circle-button:hover .icon {
  animation: tremble 0.3s ease-in-out 3;
}

@keyframes tremble {
  0%, 100% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(-10deg);
  }
  75% {
    transform: rotate(10deg);
  }
}