/* ===================== CARD ELEGANT ===================== */
.hn-card.elegant,
.hn-card-elegant{
  display: flex !important;
  flex-direction: column !important;
  background: linear-gradient(270deg, #fff, color-mix(in srgb, #fff 95%, var(--ui-primary))) !important;
  border: 1px solid color-mix(in srgb, var(--ui-primary) 12%, #ddd) !important;
  border-radius: clamp(12px, var(--radius-from-kit), 16px) !important;
  overflow: hidden !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.06) !important;
}

/* Imagen con borde fino y radio heredado */
.hn-card-elegant .thumb{
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
}
.hn-card-elegant .thumb img{
  width: 100% !important;
  height: 260px !important;
  object-fit: cover !important;
  display: block !important;
  transform: scale(1.01) !important;
  transition: transform .35s ease, filter .35s ease !important;
  filter: saturate(1.02) !important;
  transform-origin: center !important;
  will-change: transform, filter !important;
  backface-visibility: hidden !important;
}
.hn-card-elegant .thumb:hover img{
  transform: scale(1.04) !important;
  filter: saturate(1.08) !important;
}

/* Badges como pildoritas finas */
.hn-card-elegant .badges{
  position: absolute !important;
  left: 14px !important;
  top: 14px !important;
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  z-index: 3 !important;
}
.hn-card-elegant .hn-badge{
  background: rgba(0, 0, 0, .55) !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 6px 8px !important;
  font-size: 12px !important;
}

/* Contador de media */
.hn-card-elegant .media-counters{
  position: absolute !important;
  right: 14px !important;
  bottom: 14px !important;
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  z-index: 3 !important;
}
.hn-card-elegant .media-counters .m-item{
  display: inline-flex !important;
  gap: 6px !important;
  align-items: center !important;
  background: rgba(0,0,0,.55) !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 6px 8px !important;
  font-size: 12px !important;
}

/* Contenido */
.hn-card-elegant .content{
  padding: 18px 18px 12px !important;
}
.hn-card-elegant .title{
  margin: 0 0 6px !important;
  letter-spacing: .2px !important;
}
.hn-card-elegant .title a{
  text-decoration: none !important;
  color: var(--ui-primary) !important;
  display: block !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.hn-card-elegant .title a:hover{
  color: color-mix(in srgb, var(--ui-primary) 85%, black) !important;
}

/* Precios con pill principal */
.hn-card-elegant .price-row{
  display: flex !important;
  gap: 12px !important;
  align-items: center !important;
  margin: 6px 0 10px !important;
}
.hn-card-elegant .price.main{
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: var(--ui-primary) !important;
  color: var(--ui-secondary) !important;
  border: 1px solid var(--ui-primary) !important;
  border-radius: 10px !important;
  padding: 0 12px !important;
  font-weight: 800 !important;
}
.hn-card-elegant .price .code{
  opacity: .95 !important;
}
.hn-card-elegant .price.sec{
  color: var(--ui-text) !important;
  font-weight: 700 !important;
  opacity: .95 !important;
}

/* Excerpt fino */
.hn-card-elegant .excerpt{
  color: var(--ui-text) !important;
  font-size: 14px !important;
  margin: 4px 0 14px !important;
}
.hn-card-elegant .excerpt.line-2{
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

/* Facts con divisoria */
.hn-card-elegant .facts{
  display: flex !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  padding: 10px 0 6px !important;
  margin: 0 !important;
  border-top: 1px dashed color-mix(in srgb, var(--ui-primary) 15%, var(--ui-border)) !important;
}
.hn-card-elegant .facts li{
  list-style: none !important;
  display: inline-flex !important;
  gap: 8px !important;
  align-items: center !important;
}
.hn-card-elegant .facts i{
  font-size: 18px !important;
  color: var(--ui-primary) !important;
}
.hn-card-elegant .facts .v{
  font-weight: 700 !important;
}

/* Footer minimalista */
.hn-card-elegant .footer{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 12px 18px 18px !important;
}
.hn-card-elegant .agent{
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  text-decoration: none !important;
  color: var(--ui-primary) !important;
  justify-content: center !important;
}
.hn-card-elegant .agent img{
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
}
.hn-card-elegant .btn-more{
  display: inline-block !important;
  padding: 6px 22px !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: var(--ui-primary) !important;
  border: 1px solid var(--ui-primary) !important;
  text-decoration: none !important;
  text-align: center !important;
}
.hn-card-elegant .btn-more:hover{
  background: var(--ui-primary) !important;
  color: var(--ui-secondary) !important;
}

/* List view */
@media (min-width:1024px){
  .hn-grid.cols-1 .hn-card-elegant{
    display: grid !important;
    grid-template-columns: 400px 1fr 220px !important;
    gap: 24px !important;
    padding: 16px !important;
  }
  .hn-grid.cols-1 .hn-card-elegant .thumb{
    height: 230px !important;
    border-radius: 12px !important;
  }
  .hn-grid.cols-1 .hn-card-elegant .content{
    padding: 0 !important;
  }
  .hn-grid.cols-1 .hn-card-elegant .footer{
    padding: 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }
}

/* LIST view (1 columna) — Elegant */
@media (min-width:1024px){
  /* columnas: imagen | contenido | acciones */
  .hn-grid.cols-1 .hn-card-elegant{
    display: grid !important;
    grid-template-columns: 400px minmax(0,1fr) 220px !important; /* minmax(0,1fr) evita que empuje */
    gap: 24px !important;
    padding: 16px !important;
  }

  /* imagen fija y con radio */
  .hn-grid.cols-1 .hn-card-elegant .thumb{
    height: 230px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
  }
  .hn-grid.cols-1 .hn-card-elegant .thumb img{
    height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
  }

  /* contenido en el centro */
  .hn-grid.cols-1 .hn-card-elegant .content{
    padding: 0 !important;
    min-width: 0 !important; /* habilita ellipsis internos */
  }

  /* facts y separadores coherentes */
  .hn-grid.cols-1 .hn-card-elegant .facts{
    border-top: 1px dashed color-mix(in srgb, var(--ui-primary) 15%, var(--ui-border)) !important;
    padding-top: 10px !important;
    margin-top: 8px !important;
  }

  /* columna derecha: agente + botón */
  .hn-grid.cols-1 .hn-card-elegant .footer{
    grid-column: 3 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
    justify-content: center !important;
    min-width: 0 !important;
  }

  /* agente: evita salto y recorta con … */
  .hn-grid.cols-1 .hn-card-elegant .agent{
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    text-decoration: none !important;
  }
  .hn-grid.cols-1 .hn-card-elegant .agent .name{
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important; /* … si es largo */
  }

  /* botón estable */
  .hn-grid.cols-1 .hn-card-elegant .btn-more{
    flex: 0 0 auto !important;
    min-width: 140px !important;
    text-align: center !important;
  }
}