/* Cards — Standard Bearer Co.
   Restraint: subtle shadow, no scale on hover, quiet lift only. */

.card {
  background: var(--c-white);
  border: 1px solid var(--c-rule);
  border-radius: var(--radius-sm);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), border-color var(--transition);
}
.card:hover {
  box-shadow: var(--shadow-md);
  border-color: transparent;
}

.card--flush { padding: 0; overflow: hidden; }
.card--cream { background: var(--c-cream-soft); }

.card__media {
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--c-cream-soft);
}
.card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 400ms ease;
}
.card:hover .card__media img { transform: scale(1.02); }

.card__body {
  padding: var(--sp-4) var(--sp-5);
}

.card__eyebrow {
  font-family: var(--ff-ui);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-ui);
  text-transform: uppercase;
  color: var(--c-bronze);
  margin-bottom: var(--sp-2);
  display: block;
}

.card__title {
  font-family: var(--ff-headline);
  font-size: var(--fs-h4);
  font-weight: 700;
  color: var(--c-navy);
  margin: 0 0 var(--sp-2);
  line-height: 1.3;
}

.card__title a {
  text-decoration: none;
  color: inherit;
}
.card__title a:hover { color: var(--c-red); }

.card__price {
  font-family: var(--ff-ui);
  font-weight: 600;
  color: var(--c-charcoal);
}

.card__price del {
  color: var(--c-field-gray);
  font-weight: 400;
  margin-right: var(--sp-2);
}

.card__price ins {
  text-decoration: none;
  color: var(--c-red);
}

/* product card grid */
.product-grid {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

@media (min-width: 768px) {
  .product-grid--3 { grid-template-columns: repeat(3, 1fr); }
  .product-grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* feature card with rule on top — heritage feel */
.card--ruled {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--c-navy);
}
.card--ruled:hover { box-shadow: none; }
