/* Страница «Портфолио» (список объектов) */
.objects-hero { padding-top: 76px; padding-bottom: 44px; }
.objects-hero h1 { margin: 0; font-weight: 300; font-size: clamp(46px, 8vw, 124px); line-height: .95; letter-spacing: -.04em; }
.objects-hero p { margin: 28px 0 0; max-width: 56ch; font-size: 20px; line-height: 1.65; color: var(--muted-2); }
.objects-filters { position: sticky; top: 101px; z-index: 35; background: var(--paper); }
.objects-filter-row { display: flex; flex-wrap: wrap; gap: 10px; padding: 18px 0 20px; }
.objects-filter { border: 1px solid #d7d2c6; background: transparent; color: var(--muted-2); padding: 12px 18px; font: inherit; font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; transition: .2s ease; }
.objects-filter.is-active { background: var(--ink); border-color: var(--ink); color: var(--paper); }
.objects-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 34px 28px; padding-top: 44px; padding-bottom: 110px; }
.object-card { display: block; text-decoration: none; color: inherit; }
.object-media { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--media); }
.object-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .45s ease; }
.object-card:hover .object-media img { transform: scale(1.04); }
.object-badge { position: absolute; left: 14px; top: 14px; z-index: 2; display: inline-flex; align-items: center; padding: 6px 10px; background: rgba(246, 245, 241, .94); font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.object-body { padding-top: 18px; }
.object-title { margin: 0; font-size: 24px; line-height: 1.16; letter-spacing: -.02em; }
.object-text { margin: 10px 0 0; font-size: 15px; line-height: 1.55; color: #6c685b; }
.objects-cta { background: var(--ink); color: var(--paper); padding: 88px 56px; }
.objects-cta-inner { max-width: var(--maxw); margin: 0 auto; display: flex; justify-content: space-between; align-items: flex-end; gap: 28px; flex-wrap: wrap; }
.objects-cta h2 { margin: 0; font-weight: 300; font-size: clamp(34px, 5vw, 76px); line-height: 1; letter-spacing: -.04em; }
.objects-cta a { display: inline-flex; align-items: center; padding: 18px 30px; background: var(--paper); color: var(--ink); text-decoration: none; font-weight: 600; }
.objects-empty { display: none; padding: 28px 0 60px; color: #6c685b; }

@media (max-width: 1100px) {
  .objects-cta { padding-left: 32px; padding-right: 32px; }
  .objects-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 820px) {
  .objects-cta { padding: 60px 20px; }
  .objects-hero { padding-top: 42px; padding-bottom: 28px; }
  .objects-hero p { font-size: 16px; }
  .objects-filters { top: 104px; }
  .objects-filter-row { padding: 14px 0 16px; }
  .objects-grid { grid-template-columns: 1fr; gap: 28px; padding-top: 28px; padding-bottom: 72px; }
}
@media (max-width: 560px) {
  .objects-filters { position: static; }
  .objects-filter-row { padding: 12px 0 14px; gap: 8px; }
  .objects-filter { padding: 10px 14px; font-size: 12px; }
  .object-title { font-size: 21px; }
  .object-text { font-size: 14px; }
}
