.p-goods {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 56px 20px;
  @media not all and (min-width: 1024px) {
    gap: 35px 16px;
  }
}

.p-goods__child {
  display: block;

  @media all and (min-width: 1024px) {
    width: calc((100% - 60px) / 4);
  }
  @media not all and (min-width: 1024px) {
    width: calc((100% - 16px) / 2);
  }
}

.p-goods__link {
  @media (any-hover: hover) {
    &:hover img {
      transform: scale(1.1);
    }
  }
}

.p-goods__figure {
  display: block;
  border-radius: 24px;
  overflow: hidden;
  margin: 0 0 12px;
  aspect-ratio: 3 / 2;
  position: relative;
  & img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  @media (any-hover: hover) {
    & img {
      transition: transform 0.2s;
    }
  }

  @media not all and (min-width: 1024px) {
    border-radius: 16px;
  }
}

.p-goods__category {
  margin-bottom: 10px;
}

.p-goods__name {
  margin: 0 0 8px;
  font-size: 20px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.5;
  @media all and (min-width: 1024px) {
    font-size: 24px;
  }
  @media not all and (min-width: 1024px) {
    font-size: 18px;
  }
}

.p-goods__text {
  font-size: 16px;
  @media not all and (min-width: 1024px) {
    font-size: 14px;
  }
}

.p-goods__none {
  @media not all and (min-width: 1024px) {
    text-align: center;
    width: 100%;
  }
}

.p-goods__loading {
  margin: 40px 0;
  @media all and (min-width: 1024px) {
    width: 100%;
    text-align: center;
  }
}

.p-goods__error {
  margin: 40px 0;
  @media all and (min-width: 1024px) {
    width: 100%;
    text-align: center;
  }
}
