.ptm-cms-localities__intro {
  margin-bottom: 1.5rem;
  color: #593e16;
}

.ptm-cms-localities__grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
}

.ptm-cms-localities__card {
  position: relative;
  display: block;
  min-height: 260px;
  overflow: hidden;
  border-radius: 18px;
  text-decoration: none !important;
  background: #d7d0c3;
  box-shadow: 0 12px 24px rgba(47, 47, 47, 0.08);
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.ptm-cms-localities__card:hover,
.ptm-cms-localities__card:focus {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(47, 47, 47, 0.12);
}

.ptm-cms-localities__card-media,
.ptm-cms-localities__card-overlay,
.ptm-cms-localities__card-title {
  position: absolute;
  inset: 0;
}

.ptm-cms-localities__card-media {
  background-size: cover;
  background-position: center center;
  transform: scale(1.01);
  transition: transform 0.28s ease, filter 0.28s ease;
}

.ptm-cms-localities__card.is-no-cover .ptm-cms-localities__card-media {
  background: linear-gradient(180deg, #d9e7c7 0%, #9db88b 100%);
}

.ptm-cms-localities__card-overlay {
  background: linear-gradient(180deg, rgba(37, 29, 18, 0.08) 0%, rgba(37, 29, 18, 0.52) 68%, rgba(37, 29, 18, 0.78) 100%);
  transition: background 0.28s ease, opacity 0.28s ease;
}

.ptm-cms-localities__card-title {
  inset: auto 0 0 0;
  padding: 1rem 1rem 1.05rem;
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.2;
  z-index: 1;
  transition: transform 0.24s ease, text-shadow 0.24s ease;
}

.ptm-cms-localities__card:hover .ptm-cms-localities__card-media,
.ptm-cms-localities__card:focus .ptm-cms-localities__card-media {
  transform: scale(1.035);
  filter: saturate(1.08) contrast(1.03);
}

.ptm-cms-localities__card:hover .ptm-cms-localities__card-overlay,
.ptm-cms-localities__card:focus .ptm-cms-localities__card-overlay {
  background: linear-gradient(180deg, rgba(37, 29, 18, 0.03) 0%, rgba(37, 29, 18, 0.22) 70%, rgba(37, 29, 18, 0.46) 100%);
}

.ptm-cms-localities__card:hover .ptm-cms-localities__card-title,
.ptm-cms-localities__card:focus .ptm-cms-localities__card-title {
  transform: translateY(-2px);
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.32);
}

.ptm-cms-localities__empty {
  margin: 0;
  color: #6f6a63;
}

@media (max-width: 1279.98px) {
  .ptm-cms-localities__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .ptm-cms-localities__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .ptm-cms-localities__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
  }

  .ptm-cms-localities__card {
    min-height: 220px;
    border-radius: 16px;
  }
}

@media (max-width: 479.98px) {
  .ptm-cms-localities__grid {
    grid-template-columns: 1fr;
  }
}
