/* ============================================================
   REE Property Cards — Editorial Refinement (v1)
   Override layer for components/real-estate-eg/cards/unit.blade.php
   Brand: navy #0F1B2C · cream #E8E2D5 · paper #F8F4EB · mist #7DD3FC
   No gold. Loaded after unit_style_1.css.
   ============================================================ */

:root {
  --pc-ink:        #0F1B2C;
  --pc-ink-soft:   #2A3A55;
  --pc-mute:       #5B6B85;
  --pc-paper:      #F8F4EB;
  --pc-cream:      #E8E2D5;
  --pc-mist:       #7DD3FC;
  --pc-rule:       rgba(15, 27, 44, .10);
  --pc-rule-soft:  rgba(15, 27, 44, .06);
  --pc-rule-strong:rgba(15, 27, 44, .18);
  --pc-wa:         #15A348;
}

/* ---------- Grid ---------- */
.project-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 22px;
}
@media (max-width: 768px) {
  .project-cards-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
  }
}
@media (max-width: 480px) {
  .project-cards-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* ---------- Card shell — vertical, no horizontal legacy ---------- */
.property-card {
  display: flex !important;
  flex-direction: column !important;
  background: #ffffff !important;
  border: 1px solid var(--pc-rule-soft) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  box-shadow: 0 1px 0 rgba(15,27,44,.04) !important;
  transition: transform .35s cubic-bezier(.4,0,.2,1),
              box-shadow .35s cubic-bezier(.4,0,.2,1),
              border-color .35s ease !important;
  position: relative;
  width: 100% !important;
  height: auto !important;
}
.property-card:hover {
  transform: translateY(-3px) !important;
  border-color: var(--pc-rule-strong) !important;
  box-shadow: 0 16px 38px rgba(15,27,44,.10) !important;
}

/* ---------- Image block ---------- */
.property-card .property-card-image {
  position: relative !important;
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  min-height: 0 !important;
  background: var(--pc-cream) !important;
  overflow: hidden !important;
  border-bottom: 1px solid var(--pc-rule-soft) !important;
}
.property-card .property-card-image > a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
.property-card .property-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .8s cubic-bezier(.4,0,.2,1) !important;
}
.property-card:hover .property-card-image img {
  transform: scale(1.04) !important;
}
/* Subtle image vignette so badge stays legible */
.property-card .property-card-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,27,44,.22) 0%, rgba(15,27,44,0) 28%, rgba(15,27,44,0) 70%, rgba(15,27,44,.18) 100%);
  pointer-events: none;
  z-index: 1;
}

/* ---------- Editorial badge — hairline, not solid ---------- */
.property-card .property-badge {
  position: absolute !important;
  top: 12px !important;
  inset-inline-start: 12px !important;
  z-index: 2 !important;
  background: rgba(255,255,255,.92) !important;
  color: var(--pc-ink) !important;
  font-family: "Plus Jakarta Sans", "Cairo", system-ui, sans-serif !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(15,27,44,.12) !important;
  backdrop-filter: blur(8px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(8px) saturate(1.2) !important;
  box-shadow: 0 4px 12px rgba(15,27,44,.10) !important;
  line-height: 1 !important;
}

/* ---------- Content ---------- */
.property-card .property-card-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  padding: 16px 16px 14px !important;
  width: 100% !important;
  flex: 1 1 auto !important;
}

/* Title — strong navy, tighter tracking */
.property-card .property-card-title {
  margin: 0 0 2px !important;
  font-family: Cairo, "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-size: 15.5px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  letter-spacing: -.1px !important;
  color: var(--pc-ink) !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 2.7em !important;
}
.property-card .property-card-title a {
  color: inherit !important;
  text-decoration: none !important;
  background: none !important;
  -webkit-text-fill-color: var(--pc-ink) !important;
}
.property-card .property-card-title a:hover {
  color: var(--pc-ink-soft) !important;
}

/* Subtitle (compound) — full wrap, two-line clamp on inner span only */
.property-card .property-card-subtitle {
  display: flex !important;
  align-items: flex-start !important;
  gap: 7px !important;
  font-family: "Plus Jakarta Sans", "Cairo", sans-serif !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--pc-mute) !important;
  letter-spacing: .15px !important;
  -webkit-line-clamp: initial !important;
  overflow: visible !important;
  white-space: normal !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}
.property-card .property-card-subtitle i {
  flex-shrink: 0 !important;
  margin-top: 3px !important;
  font-size: 11px !important;
  color: var(--pc-mute) !important;
  opacity: .75 !important;
}
.property-card .property-card-subtitle span {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  white-space: normal !important;
  line-height: 1.4 !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  word-break: break-word !important;
}
.property-card .property-card-subtitle span a {
  color: var(--pc-mute) !important;
  text-decoration: none !important;
  border-bottom: 1px solid transparent !important;
  transition: color .2s ease, border-color .2s ease !important;
}
.property-card .property-card-subtitle span a:hover {
  color: var(--pc-ink) !important;
  border-bottom-color: var(--pc-rule-strong) !important;
}

/* Location — quieter than subtitle */
.property-card .property-card-location {
  display: flex !important;
  align-items: flex-start !important;
  gap: 7px !important;
  font-family: "Plus Jakarta Sans", "Cairo", sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--pc-mute) !important;
  margin: 0 !important;
  line-height: 1.35 !important;
}
.property-card .property-card-location i {
  flex-shrink: 0 !important;
  margin-top: 3px !important;
  font-size: 11px !important;
  opacity: .7 !important;
}
.property-card .property-card-location span {
  flex: 1 1 auto;
  min-width: 0;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.property-card .property-card-location a {
  color: inherit !important;
  text-decoration: none !important;
}

/* ---------- Specs row — hairline pills ---------- */
.property-card .property-card-specs {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 4px 0 0 !important;
  padding: 10px 0 0 !important;
  border-top: 1px solid var(--pc-rule-soft) !important;
}
.property-card .property-spec {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-family: "Plus Jakarta Sans", "Cairo", sans-serif !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: var(--pc-ink-soft) !important;
  background: var(--pc-paper) !important;
  border: 1px solid var(--pc-rule-soft) !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
  letter-spacing: .15px !important;
  line-height: 1 !important;
}
.property-card .property-spec i {
  font-size: 10.5px !important;
  color: var(--pc-mute) !important;
  opacity: .85 !important;
}

/* ---------- Action cluster — three hairline circles ---------- */
.property-card .property-card-actions,
.property-card .property-card-actions--icons {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 8px !important;
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px solid var(--pc-rule-soft) !important;
}
.property-card .pca-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  height: 38px !important;
  padding: 0 6px !important;
  border-radius: 10px !important;
  font-family: Cairo, "Plus Jakarta Sans", sans-serif !important;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: .25px !important;
  text-decoration: none !important;
  border: 1px solid var(--pc-rule) !important;
  background: #fff !important;
  color: var(--pc-ink) !important;
  transition: background-color .2s ease, color .2s ease, border-color .2s ease, transform .2s ease !important;
  cursor: pointer !important;
  line-height: 1 !important;
}
.property-card .pca-btn i {
  font-size: 12px !important;
  line-height: 1 !important;
}
.property-card .pca-btn:hover {
  transform: translateY(-1px) !important;
}

.property-card .pca-btn--wa {
  color: var(--pc-wa) !important;
  border-color: rgba(21,163,72,.30) !important;
  background: rgba(21,163,72,.05) !important;
}
.property-card .pca-btn--wa:hover {
  background: var(--pc-wa) !important;
  color: #fff !important;
  border-color: var(--pc-wa) !important;
}
.property-card .pca-btn--call {
  color: var(--pc-ink) !important;
  border-color: var(--pc-rule) !important;
  background: #fff !important;
}
.property-card .pca-btn--call:hover {
  background: var(--pc-ink) !important;
  color: #fff !important;
  border-color: var(--pc-ink) !important;
}
.property-card .pca-btn--view {
  color: #fff !important;
  background: var(--pc-ink) !important;
  border-color: var(--pc-ink) !important;
}
.property-card .pca-btn--view:hover {
  background: var(--pc-ink-soft) !important;
  border-color: var(--pc-ink-soft) !important;
}
.property-card .pca-btn--view i {
  transition: transform .25s ease;
}
.property-card .pca-btn--view:hover i {
  transform: translateX(-3px);
}
[dir="ltr"] .property-card .pca-btn--view:hover i {
  transform: translateX(3px);
}

/* ---------- Responsive tuning ---------- */
@media (max-width: 991px) {
  .property-card .property-card-image { aspect-ratio: 4/3 !important; }
  .property-card .property-card-content { padding: 14px 14px 12px !important; }
  .property-card .property-card-title { font-size: 15px !important; }
}

@media (max-width: 768px) {
  .property-card .property-card-content { padding: 14px !important; gap: 7px !important; }
  .property-card .pca-btn { height: 36px !important; font-size: 11px !important; }
}

@media (max-width: 540px) {
  .property-card { border-radius: 12px !important; }
  .property-card .property-card-image { aspect-ratio: 16/11 !important; }
  .property-card .property-card-content { padding: 12px 13px 12px !important; }
  .property-card .property-card-title { font-size: 14.5px !important; min-height: 2.6em !important; }
  .property-card .property-card-specs { gap: 5px !important; }
  .property-card .property-spec { font-size: 11px !important; padding: 4px 8px !important; }
  .property-card .pca-btn { height: 36px !important; padding: 0 4px !important; gap: 5px !important; }
  .property-card .pca-btn span { font-size: 10.5px !important; }
}

@media (max-width: 380px) {
  /* Hide labels on smallest phones, keep icons; preserves tap targets */
  .property-card .pca-btn span { display: none !important; }
  .property-card .pca-btn { padding: 0 !important; }
  .property-card .pca-btn i { font-size: 14px !important; }
}

/* ---------- Listings page chrome (filter bar + grid wrap) ---------- */
.listings-page, .units-listing-wrap {
  background: var(--pc-paper);
}
