.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* Row 1: full width */
.catalog-card--full {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: 24px;
  padding: 32px;
}

.catalog-card--full .catalog-card__icon {
  font-size: 3rem;
  flex-shrink: 0;
}

.catalog-card--full .catalog-card__title {
  font-size: 1.4rem;
}

/* Row 2: wide (2/3) */
.catalog-card--wide {
  grid-column: span 2;
}

/* Row 3: narrow (1/3) */
.catalog-card--narrow {
  grid-column: span 1;
}

/* Row 4-5: equal thirds */
.catalog-card--third {
  grid-column: span 1;
}

/* Base card */
.catalog-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px;
  border-radius: var(--radius, 12px);
  border: 1px solid var(--line, rgba(255,255,255,0.08));
  background: rgba(255,255,255,0.03);
  transition: border-color 200ms ease, background 200ms ease;
}

.catalog-card:hover {
  border-color: var(--line-2, rgba(255,255,255,0.15));
  background: rgba(255,255,255,0.05);
}

.catalog-card__icon {
  font-size: 1.8rem;
  line-height: 1;
}

.catalog-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text, #e8eaf0);
  margin: 0;
}

.catalog-card__pain {
  font-size: 0.85rem;
  color: var(--text-muted, #9aa0b2);
  margin: 0;
  line-height: 1.4;
}

.catalog-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.78rem;
  padding: 3px 8px;
  border-radius: 20px;
  width: fit-content;
}

.catalog-badge--active  { background: rgba(76,175,80,0.15);  color: #4caf7d; }
.catalog-badge--soon    { background: rgba(255,193,7,0.12);  color: #ffc107; }
.catalog-badge--planned { background: rgba(255,255,255,0.06); color: var(--text-muted, #9aa0b2); }

.catalog-card__result {
  font-size: 0.85rem;
  color: var(--text, #e8eaf0);
  margin: 0;
  line-height: 1.4;
  opacity: 0.85;
}

.catalog-card__footer {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.catalog-card__badge--live {
  font-size: 0.75rem;
  color: #4caf7d;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.catalog-card__btn {
  margin-top: auto;
  font-size: 0.85rem;
  min-height: 36px;
  padding: 0 14px;
  align-self: flex-start;
}

.catalog-card__btn--disabled {
  opacity: 0.4;
  cursor: default;
  pointer-events: none;
}

@media (max-width: 760px) {
  .catalog-grid {
    grid-template-columns: 1fr;
  }

  .catalog-card--full,
  .catalog-card--wide,
  .catalog-card--narrow,
  .catalog-card--third {
    grid-column: 1 / -1;
  }
}
