/* =====================================================================
   ФУДОНАВТ · Блок «Свежее в блоге» для лендинга foodonaut.ru.
   Редакторская сетка (лид + строки + обычная). Scoped под .bl-latest,
   без глобальных body/a — чтобы не задеть живой лендинг.
   Все токены — из landing tokens.css. Снято с дизайнерского blog.css.
   ===================================================================== */
.bl-latest { max-width: 1200px; margin: 0 auto; padding: 96px 24px; }
.bl-latest a { text-decoration: none; color: inherit; }
.bl-latest[hidden] { display: none; }

/* ---------- Шапка: eyebrow + h2 слева, кнопка «Все статьи» справа ---------- */
.bl-latest__head { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: end; margin-bottom: 48px; }
.bl-latest__head h2 { font-size: clamp(32px, 4vw, 52px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.04; margin: 0; }
.bl-latest .bl-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--brand-primary); margin-bottom: 18px;
}
.bl-latest .bl-eyebrow::before {
  content: ""; width: 12px; height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 14 L56 44 L86 50 L56 56 L50 86 L44 56 L14 50 L44 44 Z' fill='%233B5BFF'/></svg>") center/contain no-repeat;
}
.bl-latest__link {
  display: inline-flex; align-items: center; gap: 8px; height: 48px; padding: 0 22px; white-space: nowrap;
  border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--bg-secondary);
  color: var(--text-primary); font-weight: 600; transition: all .15s; align-self: start; justify-self: end;
}
.bl-latest__link:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.bl-latest__link svg { width: 18px; height: 18px; }

/* ---------- Сетка: лид (1.4fr) + колонка строк (1fr) + обычная (1fr) ---------- */
.bl-latest__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 24px; align-items: stretch; }
.bl-latest__grid > * { min-width: 0; }
.bl-latest__lead { grid-row: span 1; }
.bl-latest__side { display: flex; flex-direction: column; gap: 16px; }
.bl-latest__side .bl-card--row { flex: 1; }
.bl-latest__side .bl-card--row .bl-card__media { height: 100%; }

/* ---------- Карточка ---------- */
.bl-latest .bl-card {
  display: flex; flex-direction: column; background: var(--bg-primary);
  border: 1px solid var(--border-color); border-radius: var(--radius-lg); overflow: hidden;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}
.bl-latest .bl-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: color-mix(in srgb, var(--brand-primary) 30%, var(--border-color)); }
.bl-latest .bl-card__media { position: relative; aspect-ratio: 16/10; }
.bl-latest .bl-card__cat { position: absolute; top: 12px; left: 12px; }
.bl-latest .bl-card__body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.bl-latest .bl-card__title { font-size: var(--font-size-lg); font-weight: 700; line-height: 1.3; letter-spacing: -0.01em; text-wrap: balance; margin: 0; }
.bl-latest .bl-card:hover .bl-card__title { color: var(--brand-primary); }
.bl-latest .bl-card__excerpt { margin: 10px 0 0; font-size: var(--font-size-base); color: var(--text-secondary); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bl-latest .bl-card__foot { margin-top: auto; padding-top: 16px; }

/* лид: крупный заголовок (дизайнер задавал инлайн font-size:xl) */
.bl-latest__lead .bl-card__title { font-size: var(--font-size-xl); }
.bl-latest__lead .bl-card__media { aspect-ratio: 16/11; }

/* row-карточка: фото слева 132px + текст справа, без эксцерпта */
.bl-latest .bl-card--row { flex-direction: row; }
.bl-latest .bl-card--row .bl-card__media { width: 132px; aspect-ratio: auto; flex: none; }
.bl-latest .bl-card--row .bl-card__body { padding: 16px 18px; }

/* ---------- Бейдж категории ---------- */
.bl-latest .bl-cat {
  display: inline-flex; align-items: center; height: 24px; padding: 0 10px;
  border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: 700;
  letter-spacing: 0.04em; color: var(--brand-primary); background: var(--brand-primary-light);
}
.bl-latest .bl-cat--onimg { background: rgba(255,255,255,0.92); color: var(--brand-primary); backdrop-filter: blur(4px); }

/* ---------- Плейсхолдер изображения (фолбэк, если нет фото) ---------- */
.bl-latest .bl-imgph { position: relative; width: 100%; height: 100%; overflow: hidden; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-end) 100%); }
.bl-latest .bl-imgph::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 120% at 80% 10%, rgba(255,255,255,0.18), transparent 45%); }
.bl-latest .bl-imgph--alt { background: linear-gradient(135deg, #16307a 0%, var(--brand-primary) 100%); }
.bl-latest .bl-imgph--soft { background: linear-gradient(135deg, var(--brand-primary-end) 0%, #6FA6FF 100%); }
.bl-latest .bl-imgph img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .4s ease; }
/* шиммер до загрузки фото */
.bl-latest .bl-imgph.is-loading img { opacity: 0; }
.bl-latest .bl-imgph.is-loading::before {
  content: ""; position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(100deg, transparent 20%, rgba(255,255,255,0.22) 50%, transparent 80%);
  background-size: 200% 100%; animation: bl-shimmer 1.2s linear infinite;
}
@keyframes bl-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .bl-latest .bl-imgph.is-loading::before { animation: none; } }
.bl-latest .bl-imgph svg { position: relative; z-index: 1; width: 30%; max-width: 88px; height: auto; opacity: 0.9; }
.bl-latest .bl-imgph svg .fdnt-fill, .bl-latest .bl-imgph svg .fdnt-helmet { fill: rgba(255,255,255,0.92); }
.bl-latest .bl-imgph svg .fdnt-sparkle { fill: rgba(255,255,255,0.6); }
.bl-latest .bl-imgph svg .fdnt-stroke { stroke: rgba(255,255,255,0.92); fill: none; }

/* ---------- Мета ---------- */
.bl-latest .bl-meta { display: inline-flex; align-items: center; gap: 8px; font-size: var(--font-size-sm); color: var(--text-tertiary); }
.bl-latest .bl-meta__dot { width: 3px; height: 3px; border-radius: var(--radius-full); background: var(--text-tertiary); }

/* ---------- Адаптив ---------- */
@media (max-width: 1023px) {
  .bl-latest__grid { grid-template-columns: 1fr 1fr; align-items: start; }
  .bl-latest__side { flex-direction: row; }
  .bl-latest__side .bl-card--row { flex: 1; }
  .bl-latest__side .bl-card--row .bl-card__media { height: auto; }
  .bl-latest .bl-card--row { flex-direction: column; }
  .bl-latest .bl-card--row .bl-card__media { width: 100%; aspect-ratio: 16/10; }
}
@media (max-width: 767px) {
  .bl-latest { padding: 64px 24px; }
  .bl-latest__grid { grid-template-columns: 1fr; }
  .bl-latest__head { grid-template-columns: 1fr; }
  .bl-latest__link { justify-self: start; }
  .bl-latest__side { flex-direction: column; }
}
