.goods {
  --grid-tc: repeat(3, 1fr);
  display: grid;
  grid-gap: 12px;
  grid-template-columns: repeat(3, 1fr);
  grid-row-gap: 1rem;
}
.goods-card {
  height: 100%;
  padding: 1rem 0.65rem 1.25rem 0.65rem;
  border-radius: 0.5rem;
  background-color: var(--color-card);
  display: flex;
  flex-direction: column;
  /* gap: 0.5rem; */
}

.goods-card:hover {
  background-color: var(--color-card-hover);
}

.goods-company {
  color: var(--color-grey);
  margin: 0 0.125rem;
  opacity: .65;
  font-size: .85rem;
  margin-bottom: .125rem;
}

.goods-description {
  font-size: 0.9rem;
  margin: 0 0.125rem;
  color: var(--color-grey);
  margin-top: 0.5rem;
}

.goods-img {
  width: 80% !important;
  margin: 0 auto;
}

.goods-card img {
  transition: transform 0.2s ease-in-out;
  cursor: auto;
}

.goods-card:hover img {
  transform: translateY(-4px);
}

.goods-title {
  font-size: .95rem;
  color: inherit;
  text-underline-offset: 2px;
  width: fit-content;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  border-radius: 4px;
  padding-right: 0.125rem;
  line-height: 24px;
  text-decoration: none !important;
}

.goods-title::before {
  content: "";
  width: calc(100% + 0.625rem);
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, calc(-50% - 2px)) scale(0.95);
  border-radius: 4px;
  background: var(--color-border);
  opacity: 0;
  transition: transform 150ms 0s ease, opacity 150ms 10ms ease;
  z-index: -1;
}
.goods-title:hover {
  transition: transform 150ms 100ms ease, opacity 150ms 0s ease;
  text-decoration: none;
  background-color: var(--color-border);
}
.goods-title a{
  text-decoration: none !important;
}

.stack {
  display: grid;
}

.stack-card {
  height: 100%;
  padding: 0.5rem 1rem 1rem 0;
  border-radius: 0.5rem;
  display: flex;
  flex-direction: row;
  gap: 1rem;
}

.stack-card:hover {
  /* background-color: var(--color-card-hover); */
}

.stack-item-image-container img {
  width: 64px;
  margin-top: unset;
}

.stack-title {
  font-size: inherit;
  color: inherit;
  text-underline-offset: 2px;
  width: fit-content;
  text-decoration: underline;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  border-radius: 4px;
  padding-right: 0.125rem;
  line-height: 24px;
  margin-top: 0.5rem;
}

.stack-title::before {
  content: "";
  width: calc(100% + 0.625rem);
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, calc(-50% - 2px)) scale(0.95);
  border-radius: 4px;
  background: var(--color-border);
  opacity: 0;
  transition: transform 150ms 0s ease, opacity 150ms 10ms ease;
  z-index: -1;
}
.stack-title:hover {
  /* transition: transform 150ms 100ms ease, opacity 150ms 0s ease;
  text-decoration: none;
  background-color: var(--color-border); */
}

p.stack-item-description {
  font-size: 0.9rem;
  color: var(--color-grey);
  margin-top: 0.5rem;
}

.stack-item-tags {
  list-style-type: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  bottom: 1rem;
  margin-top: 0.5rem;
}

span.stack-item-tag {
  font-size: 0.8rem;
  border-radius: 4px;

  line-height: inherit;
  padding: 0.25rem 0.5rem;
  color: var(--color-gray);
  opacity: 0.5;
  background-color: var(--color-border);
}

span.stack-item-discount {
  display: none;
  border-radius: 9999px;
  font-size: 0.8rem;
  line-height: inherit;
  padding: 0.1rem 0.5rem;
  color: var(--color-gray);
  opacity: 0.5;
  background-color: var(--color-border);
}

spacer {
  margin-top: 0.25rem !important;
}

.stack__meta {
  text-align: right;
  align-self: flex-start;
  position: sticky;
  top: calc(var(--navigation-height) + 1.5rem);
}

.main img {
  max-width: unset;
}

.driver {
  height: 0.5px;
  background: var(--color-border);
}

.stack-card:hover + .driver,
.stack-card:hover ~ .driver {
  display: none;
}

/* 定义手机端样式 */
@media screen and (max-width: 768px) {
  r-grid {
    gap: 1rem 1rem;
    padding: 1rem;
  }

  .goods-img {
    width: 50vw !important;
  }

  .goods {
    grid-template-columns: repeat(1, 1fr);
  }

  .stack {
    grid-template-columns: repeat(1, 1fr);
  }

  .stack__meta {
    text-align: left;
  }

  .stack__meta {
    display: block;
    margin-top: 0;
    top: unset;
  }
}
