.catalog-page { padding: 32px 0 56px; }
.catalog-page__hero { display: grid; gap: 14px; margin-bottom: 28px; padding: 28px; border-radius: 32px; background: radial-gradient(circle at top right, rgba(230, 52, 42, 0.12), transparent 28%), radial-gradient(circle at bottom left, rgba(35, 38, 51, 0.08), transparent 26%), linear-gradient(180deg, #ffffff 0%, #f7f8fc 100%); border: 1px solid #eceff6; box-shadow: 0 18px 50px rgba(19, 27, 48, 0.06); }
.catalog-page__eyebrow { color: #e6342a; font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.catalog-page__title { margin: 0; color: #232633; font-size: 40px; line-height: 1.05; font-weight: 800; }
.catalog-page__lead { max-width: 720px; margin: 0; color: #7c8498; font-size: 16px; line-height: 1.7; }
.catalog-page__meta { display: inline-flex; align-items: center; gap: 8px; width: fit-content; min-height: 42px; padding: 0 16px; border-radius: 999px; background: #f4f5f8; color: #5b6274; font-size: 14px; font-weight: 600; }
.catalog-page__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.catalog-card { position: relative; display: grid; gap: 18px; min-height: 280px; padding: 22px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,252,0.98) 100%); border: 1px solid #eceff6; box-shadow: 0 14px 34px rgba(19, 27, 48, 0.05); overflow: hidden; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.catalog-card:hover { transform: translateY(-4px); box-shadow: 0 24px 48px rgba(19, 27, 48, 0.1); border-color: rgba(230, 52, 42, 0.18); }
.catalog-card::after { content: ''; position: absolute; right: -28px; top: -28px; width: 120px; height: 120px; border-radius: 50%; background: radial-gradient(circle, rgba(230, 52, 42, 0.12), transparent 68%); pointer-events: none; }
.catalog-card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.catalog-card__icon { width: 64px; height: 64px; border-radius: 20px; background: #f5f6fa; border: 1px solid #eceff6; display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.catalog-card__icon img { width: 100%; height: 100%; object-fit: cover; }
.catalog-card__emoji { font-size: 30px; line-height: 1; }
.catalog-card__arrow { width: 36px; height: 36px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: #232633; color: #fff; font-size: 18px; box-shadow: 0 10px 20px rgba(35, 38, 51, 0.18); flex-shrink: 0; }
.catalog-card__title { margin: 0; color: #232633; font-size: 24px; line-height: 1.15; font-weight: 800; }
.catalog-card__subtitle { margin: 8px 0 0; color: #7c8498; font-size: 14px; line-height: 1.6; }
.catalog-card__children { display: flex; flex-wrap: wrap; gap: 8px; }
.catalog-card__chip { display: inline-flex; align-items: center; min-height: 34px; padding: 0 12px; border-radius: 999px; background: #f5f6fa; color: #555d71; font-size: 13px; font-weight: 600; }
.catalog-card__footer { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 14px; color: #8b92a4; font-size: 13px; font-weight: 600; }
.catalog-card__all { color: #e6342a; font-weight: 700; }
.catalog-empty { padding: 48px 32px; border-radius: 28px; background: linear-gradient(180deg, #fff 0%, #f7f8fc 100%); border: 1px solid #eceff6; text-align: center; box-shadow: 0 14px 34px rgba(19, 27, 48, 0.05); }
.catalog-empty__emoji { font-size: 46px; line-height: 1; margin-bottom: 14px; }
.catalog-empty__title { margin: 0 0 10px; color: #232633; font-size: 24px; font-weight: 800; }
.catalog-empty__text { margin: 0; color: #7c8498; font-size: 15px; line-height: 1.7; }
@media (max-width: 1100px) { .catalog-page__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px) {
  .catalog-page { padding: 20px 0 40px; }
  .catalog-page__hero { margin-bottom: 20px; padding: 22px 18px; border-radius: 24px; }
  .catalog-page__title { font-size: 30px; }
  .catalog-page__lead { font-size: 14px; }
  .catalog-page__grid { grid-template-columns: 1fr; gap: 14px; }
  .catalog-card { min-height: 0; padding: 18px; border-radius: 22px; }
  .catalog-card__title { font-size: 20px; }
}
