/* === CARD classic (catálogo) === */
.hn-card-classic{
  display: flex !important;
  flex-direction: column !important;
  background: var(--ui-surface) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius: var(--radius-from-kit) !important;
  overflow: hidden !important;
  box-shadow: var(--ui-shadow) !important;
}

.hn-card-classic .title a{
  color: var(--ui-primary) !important;
  display: block !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.hn-card-classic .thumb{
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
}

.hn-card-classic .thumb img{
  width: 100% !important;
  height: 260px !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .35s ease !important;
  transform-origin: center !important;
  will-change: transform !important;
  backface-visibility: hidden !important;
}

.hn-card-classic .thumb:hover img{
  transform: scale(1.03) !important;
}

.hn-card-classic .thumb .no-image{
  height: 260px !important;
  display: grid !important;
  place-items: center !important;
  color: color-mix(in srgb, var(--ui-text) 55%, #fff) !important;
  background: color-mix(in srgb, var(--ui-text) 6%, #fff) !important;
}

.hn-card-classic .badges{
  position: absolute !important;
  left: 14px !important;
  top: 14px !important;
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

.hn-card-classic .hn-badge{
  background: rgba(0, 0, 0, .55) !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 6px 8px !important;
  font-size: 12px !important;
}

.hn-card-classic .media-counters{
  position: absolute !important;
  right: 14px !important;
  bottom: 14px !important;
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
}

.hn-card-classic .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;
}

.hn-card-classic .location{
  position: absolute !important;
  left: 14px !important;
  bottom: 14px !important;
  background: rgba(0,0,0,.55) !important;
  color: #fff !important;
  display: inline-flex !important;
  gap: 8px !important;
  align-items: center !important;
  border-radius: 10px !important;
  padding: 6px 10px !important;
  font-size: 13px !important;
}

.hn-card-classic .content{
  padding: 18px 18px 10px !important;
}

/* título de card = PRIMARY kit (ya definido en .hn-title del front) */

.hn-card-classic .price-row{
  display: flex !important;
  gap: 14px !important;
  align-items: baseline !important;
  margin: 4px 0 10px !important;
}

.hn-card-classic .price{
  font-weight: 800 !important;
}

.hn-card-classic .price.main{
  color: var(--ui-primary) !important;
}

.hn-card-classic .price .code{
  opacity: .9 !important;
  margin-right: 6px !important;
}

.hn-card-classic .price.sec{
  color: var(--ui-text) !important;
  font-weight: 700 !important;
  opacity: .9 !important;
}

.hn-card-classic .excerpt{
  color: var(--ui-text) !important;
  font-size: 14px !important;
  margin: 6px 0 14px !important;
}

.hn-card-classic .excerpt.line-2{
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.hn-card-classic .facts{
  display: flex !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
  padding: 10px 0 4px !important;
  margin: 0 !important;
  border-top: 1px dashed var(--ui-border) !important;
}

.hn-card-classic .facts li{
  list-style: none !important;
  display: inline-flex !important;
  gap: 8px !important;
  align-items: center !important;
  color: var(--ui-text) !important;
}

.hn-card-classic .facts i{
  font-size: 15px !important;
  color: var(--ui-text) !important;
}

.hn-card-classic .facts .v{
  font-weight: 400 !important;
  color: var(--ui-text) !important;
  font-size: 15px !important;
}

.hn-card-classic .footer{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 12px 18px 16px !important;
  gap: 14px !important;
}

.hn-card-classic .agent{
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  text-decoration: none !important;
  justify-content: center !important;
}

.hn-card-classic .agent img{
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
}

.hn-card-classic .agent .placeholder{
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background: color-mix(in srgb, var(--ui-text) 6%, #fff) !important;
  color: color-mix(in srgb, var(--ui-text) 55%, #fff) !important;
}

.hn-card-classic .agent .name{
  color: var(--ui-primary) !important;
  font-weight: 400 !important;
}

.hn-card-classic .btn-more{
  display: inline-block !important;
  padding: 4px 32px !important;
  border-radius: 10px !important;
  background: var(--ui-primary) !important;
  color: var(--ui-secondary) !important;
  text-decoration: none !important;
  border: 1px solid var(--ui-primary) !important;
}

.hn-card-classic .btn-more:hover{
  filter: brightness(.95) !important;
}


/* === List view (1 col, desktop) === */
@media (min-width:1024px){
  .hn-grid.cols-1 .hn-card-classic{
    display: grid !important;
    grid-template-columns: 360px 1fr 200px !important;
    align-items: center !important;
    gap: 20px !important;
    padding: 14px !important;
    box-shadow: 0 6px 14px rgba(0,0,0,.06) !important;
    border-color: var(--ui-border) !important;
  }

  .hn-grid.cols-1 .hn-card-classic .thumb{
    grid-column: 1 !important;
    margin: 0 !important;
    overflow: hidden !important;
    border-radius: 12px !important;
  }

  .hn-grid.cols-1 .hn-card-classic .thumb img{
    height: 200px !important;
    width: 100% !important;
    object-fit: cover !important;
  }

  .hn-grid.cols-1 .hn-card-classic .content{
    grid-column: 2 !important;
    padding: 0 !important;
  }

  .hn-grid.cols-1 .hn-card-classic .price-row{
    margin-top: 6px !important;
  }

  .hn-grid.cols-1 .hn-card-classic .facts{
    border-top: 1px dashed var(--ui-border) !important;
    padding-top: 10px !important;
    margin-top: 8px !important;
  }

  .hn-grid.cols-1 .hn-card-classic .footer{
    grid-column: 3 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    align-items: center !important;
    justify-content: center !important;
    align-items: stretch !important;
  }

  .hn-grid.cols-1 .hn-card-classic .agent .name{
    white-space: nowrap !important;
  }

  .hn-grid.cols-1 .hn-card-classic .btn-more{
    min-width: 140px !important;
    text-align: center !important;
  }
}


/* LIST view (1 columna) — evita que el agente empuje el botón */
@media (min-width:1024px){
  /* deja que la columna central pueda encoger con ellipsis */
  .hn-grid.cols-1 .hn-card-classic{
    grid-template-columns: 360px minmax(0,1fr) 220px !important; /* minmax(0,1fr) es clave */
  }

  /* el contenedor derecho (agente + botón) */
  .hn-grid.cols-1 .hn-card-classic .footer{
    grid-column: 3 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;      /* que ocupe ancho disponible */
    justify-content: center !important;
    min-width: 0 !important;              /* permite ellipsis internos */
  }

  /* agente: que no rompa línea y recorte con … */
  .hn-grid.cols-1 .hn-card-classic .agent{
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;              /* importante para ellipsis */
  }

  .hn-grid.cols-1 .hn-card-classic .agent .name{
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;   /* … si es largo */
  }

  /* el botón no debe encogerse ni crecer raro */
  .hn-grid.cols-1 .hn-card-classic .btn-more{
    flex: 0 0 auto !important;
    min-width: 140px !important;
    text-align: center !important;
  }
}