:root {
  --card-background: var(--surface-card, var(--color-surface, #fff));
  --card-border: color-mix(in srgb, var(--color-border, #e5e7eb) 65%, transparent);
  --card-radius: 18px;
}

.cards-grid {
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.75rem);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  align-items: stretch;
}

.card {
  --card-accent: var(--section-accent, var(--theme-accent, #9b87f5));
  background: var(--card-background);
  border-radius: var(--card-radius);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow-soft, 0 15px 30px rgba(15, 23, 42, 0.08));
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  color: var(--color-text, #0f172a);
  transition: transform var(--transition-base, 180ms ease), box-shadow var(--transition-base, 180ms ease);
}

.card:hover,
.card:focus-visible,
.card:focus-within {
  transform: translateY(-3px);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--card-accent) 12%, rgba(15, 23, 42, 0.16));
}

.card:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--card-accent) 60%, transparent);
  outline-offset: 3px;
}

.card--muted {
  background: color-mix(in srgb, var(--card-background) 85%, var(--color-surface-muted, #f7f8fb));
  border-color: color-mix(in srgb, var(--card-border) 75%, transparent);
}

.card--subtle {
  box-shadow: none;
  border-color: color-mix(in srgb, var(--card-border) 70%, transparent);
}

.card--legal {
  --card-accent: #c9852c;
}

.card__icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: var(--card-accent);
  background: color-mix(in srgb, var(--card-accent) 15%, #ffffff);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--card-accent) 35%, transparent);
}

.card__icon svg {
  width: 32px;
  height: 32px;
  stroke: currentColor;
  fill: none;
}

.card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: calc(var(--card-radius) - 6px);
  overflow: hidden;
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.05), rgba(15, 23, 42, 0.03));
}

.card__media img,
.card__media picture,
.card__media video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.card__title {
  margin: 0;
  font-family: var(--font-display, "Inter", system-ui, -apple-system, sans-serif);
  font-size: clamp(1.2rem, 2vw, 1.35rem);
  line-height: 1.25;
  font-weight: 700;
  color: color-mix(in srgb, var(--color-text, #0f172a) 88%, var(--card-accent) 12%);
}

.card__text,
.card p {
  margin: 0;
  color: color-mix(in srgb, var(--color-text, #0f172a) 82%, var(--color-text-muted, #64748b));
  line-height: 1.6;
  font-size: 0.98rem;
}

.card__list {
  margin: 0;
  padding-left: 1.1rem;
  color: color-mix(in srgb, var(--color-text, #0f172a) 82%, var(--color-text-muted, #64748b));
  display: grid;
  gap: 0.4rem;
}

.card__footer {
  margin-top: auto;
  display: inline-flex;
  gap: 0.4rem;
  align-items: center;
  font-weight: 600;
  color: color-mix(in srgb, var(--card-accent) 70%, var(--color-text, #0f172a));
}

@media (max-width: 600px) {
  .card {
    padding: 1.2rem;
  }
}
