/* ============================================
   VECINOS — Proyectos Grid (Masonry)
   ============================================ */

.proyectos-page #site-footer { border-top: var(--border-thick); }

/* ── INTRO ── */
.pgrid-intro {
  padding: 30px 30px 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.pgrid-intro h1 {
  font-family: var(--font-heading);
  font-size: clamp(40px, 5vw, 72px);
  text-transform: uppercase;
  line-height: 1;
}

.pgrid-intro p {
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--grey);
  max-width: 420px;
}

/* ── FILTROS ── */
.pgrid-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 30px 24px;
}

.pgrid-filter {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 8px 18px;
  border: var(--border);
  background: transparent;
  color: var(--grey);
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.pgrid-filter:hover {
  border-color: var(--black);
  color: var(--black);
}

.pgrid-filter.is-active {
  background: var(--black);
  border-color: var(--black);
  color: var(--white);
}

/* ── MASONRY CONTAINER ── */
.pgrid-wrap {
  padding: 30px;
}

.pgrid {
  columns: 3;
  column-gap: 12px;
}

/* ── ITEM ── */
.pgrid__item {
  break-inside: avoid;
  margin-bottom: 12px;
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: var(--white);
  cursor: pointer;
}

.pgrid__item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.5s ease;
}

.pgrid__item:hover img {
  transform: scale(1.03);
}

.pgrid__item--soon {
  cursor: default;
  background: var(--grey-light);
  aspect-ratio: 4/3;
}

.pgrid__item--soon img { display: none; }

/* ── OVERLAY ── */
.pgrid__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 50%);
  opacity: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px 24px;
  gap: 4px;
  transition: opacity 0.3s ease;
}

.pgrid__item:hover .pgrid__overlay { opacity: 1; }

.pgrid__item--soon .pgrid__overlay {
  opacity: 1;
  background: none;
  justify-content: center;
  align-items: center;
}

.pgrid__num {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 4px;
}

.pgrid__title {
  font-family: var(--font-heading);
  font-size: clamp(16px, 1.8vw, 24px);
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1;
  margin: 0;
}

.pgrid__tags {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.65);
  margin: 6px 0 0;
}

.pgrid__item--soon .pgrid__title { color: var(--grey); }
.pgrid__item--soon .pgrid__tags  { color: var(--grey-light); }

/* ── MÓVIL ── */
@media (max-width: 640px) {
  .pgrid { columns: 1; }
  .pgrid-intro { padding: 48px var(--px) 32px; }
  .pgrid-wrap { padding-bottom: 64px; }

  .pgrid__overlay {
    opacity: 1;
    background: linear-gradient(to top, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 60%);
  }
}
