/* ═══════════════════════════════════════════════════════
   BENCHI PROPERTIES — components.css v3.0
   2025-03-24 | Cards, badges
═══════════════════════════════════════════════════════ */

/* ─── PROPERTY CARD ───────────────────────────────────── */
.property-card {
  background: #fff;
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
  overflow: hidden; cursor: pointer;
  transition: transform 0.35s var(--ease), box-shadow 0.35s, border-color 0.35s;
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease),
              box-shadow 0.35s, border-color 0.35s;
}
.property-card.visible {
  opacity: 1; transform: translateY(0);
}
.property-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(184,146,74,0.4);
  box-shadow: 0 16px 48px rgba(0,0,0,0.1);
}
.property-card:nth-child(2) { transition-delay: 0.08s; }
.property-card:nth-child(3) { transition-delay: 0.16s; }
.property-card:nth-child(4) { transition-delay: 0.24s; }
.property-card:nth-child(5) { transition-delay: 0.32s; }
.property-card:nth-child(6) { transition-delay: 0.40s; }

/* Imagen */
.property-img {
  position: relative; aspect-ratio: 4/3;
  overflow: hidden; background: var(--bg-soft);
}
.property-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.property-card:hover .property-img img { transform: scale(1.06); }

.property-img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #F0EDE6, #E8E3DB);
  font-family: var(--font-serif); font-size: 3rem;
  color: rgba(184,146,74,0.25);
}

/* Overlay precio sobre foto */
.prop-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.75rem 1.25rem 1rem;
  background: linear-gradient(to top, rgba(10,8,6,0.85) 0%, transparent 100%);
}
.prop-overlay-price {
  font-family: var(--font-serif); font-size: 1.5rem;
  font-weight: 300; color: #fff; display: block; margin-bottom: 0.15rem;
}
.prop-overlay-loc {
  font-size: 0.68rem; font-weight: 400;
  letter-spacing: 0.04em; color: rgba(255,255,255,0.75);
}

/* Badges */
.prop-badge {
  position: absolute; top: 0.75rem; left: 0.75rem;
  font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.28rem 0.7rem; border-radius: 2px;
  background: var(--gold); color: #fff; z-index: 2;
}
.prop-badge.alquiler {
  background: rgba(10,8,6,0.65); color: var(--gold-light);
  border: 1px solid rgba(184,146,74,0.4); backdrop-filter: blur(4px);
}
.prop-badge.obra-nueva {
  background: rgba(10,8,6,0.65); color: #8FD48F;
  border: 1px solid rgba(100,180,100,0.4); backdrop-filter: blur(4px);
}
.prop-ref {
  position: absolute; top: 0.75rem; right: 0.75rem;
  font-size: 0.56rem; font-weight: 500; letter-spacing: 0.06em;
  color: rgba(255,255,255,0.6);
  background: rgba(10,8,6,0.5); padding: 0.18rem 0.5rem;
  border-radius: 2px; backdrop-filter: blur(4px); z-index: 2;
}

/* Cuerpo card */
.property-body { padding: 1rem 1.25rem 1.25rem; }
.prop-meta {
  display: flex; align-items: center; gap: 0.35rem; margin-bottom: 0.4rem;
}
.prop-type {
  font-size: 0.6rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold);
}
.prop-sep { color: #ccc; font-size: 0.55rem; }
.prop-loc { font-size: 0.7rem; color: var(--txt-3); }

.prop-title {
  font-family: var(--font-serif); font-size: 1.1rem;
  font-weight: 400; color: var(--txt-1); line-height: 1.35;
  margin-bottom: 0.85rem;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}

.prop-specs {
  display: flex; gap: 1.25rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--bg-border);
}
.spec { display: flex; align-items: center; gap: 0.25rem; }
.spec-icon { font-size: 0.68rem; color: var(--txt-3); }
.spec-val { font-size: 0.75rem; font-weight: 500; color: var(--txt-1); }
.spec-unit { font-size: 0.62rem; color: var(--txt-3); }

/* ─── NEWS CARD ───────────────────────────────────────── */
.news-card {
  background: #fff; border: 1px solid var(--bg-border);
  border-radius: var(--r-md); padding: 2rem;
  display: flex; flex-direction: column; gap: 0.85rem;
  transition: border-color 0.3s, transform 0.3s var(--ease), box-shadow 0.3s;
}
.news-card:hover {
  border-color: rgba(184,146,74,0.4);
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(0,0,0,0.07);
}
.news-tag {
  font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold);
}
.news-title {
  font-family: var(--font-serif); font-size: 1.25rem;
  font-weight: 300; color: var(--txt-1); line-height: 1.35;
}
.news-excerpt { font-size: 0.8rem; color: var(--txt-3); line-height: 1.75; flex: 1; }
.news-link {
  font-size: 0.65rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); transition: color 0.2s; margin-top: auto;
}
.news-link:hover { color: var(--gold-dark); }
