.ratings-grid {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.ratings-grid--compact {
  grid-template-columns: 1fr;
}

.rating-card {
  position: relative;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--theme-accent, #2f3fa9) 12%, var(--surface-border, #d8deea));
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--surface-card, #fff) 95%, #ffffff) 0%,
    var(--surface-card, #fff) 100%
  );
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.rating-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    color-mix(in srgb, var(--theme-accent, #2f3fa9) 12%, transparent) 0%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity 180ms ease;
  pointer-events: none;
}

.rating-card:hover,
.rating-card:focus-within {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--theme-accent, #2f3fa9) 28%, var(--surface-border, #d8deea));
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.12);
}

.rating-card:hover::after,
.rating-card:focus-within::after {
  opacity: 1;
}

.rating-card__image {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  aspect-ratio: 4 / 3;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--theme-accent, #2f3fa9) 10%, var(--surface-muted, #f2ede5)) 0%,
    color-mix(in srgb, var(--theme-accent, #2f3fa9) 6%, var(--surface-card, #fff)) 100%
  );
  overflow: hidden;
  padding: 0.75rem;
}

.ratings-grid--compact .rating-card__image {
  aspect-ratio: 3 / 2;
}

.rating-card__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  transition: transform 220ms ease;
}

.rating-card:hover .rating-card__image img,
.rating-card:focus-within .rating-card__image img {
  transform: scale(1.04);
}

.rating-card__body {
  padding: 0.95rem 1.05rem 1.05rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1 1 auto;
}

.rating-card__title {
  margin: 0;
  font-size: 1rem;
  line-height: 1.25;
}

.rating-card__title a {
  color: inherit;
  text-decoration: none;
}

.rating-card__title a:hover {
  text-decoration: underline;
}

.rating-card__brand {
  margin: 0;
  color: var(--color-text-muted, #47516b);
  font-size: 0.9rem;
}

.rating-card__scores {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.1rem;
}

.rating-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--theme-accent, #2f3fa9) 26%, transparent);
  background: color-mix(in srgb, var(--theme-accent, #2f3fa9) 12%, #ffffff);
  color: color-mix(in srgb, var(--theme-accent, #2f3fa9) 65%, var(--color-text, #161a2a));
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.rating-chip__value {
  font-weight: 800;
  color: var(--color-text, #161a2a);
}

.rating-chip--sillage {
  border-color: color-mix(in srgb, var(--color-botanical, #2f8a6d) 26%, transparent);
  background: color-mix(in srgb, var(--color-botanical, #2f8a6d) 12%, #ffffff);
  color: color-mix(in srgb, var(--color-botanical-dark, #1f5f49) 70%, var(--color-text, #161a2a));
}

.rating-chip--longevity {
  border-color: color-mix(in srgb, var(--color-amber, #c97232) 26%, transparent);
  background: color-mix(in srgb, var(--color-amber, #c97232) 12%, #ffffff);
  color: color-mix(in srgb, var(--color-amber-dark, #a5531c) 70%, var(--color-text, #161a2a));
}

.ratings-empty {
  margin: 0;
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px dashed color-mix(in srgb, var(--theme-accent, #2f3fa9) 28%, var(--surface-border, #d8deea));
  background: color-mix(in srgb, var(--surface-muted, #f2ede5) 70%, transparent);
  color: var(--color-text-muted, #47516b);
  text-align: center;
}
