/* =========================
   Components CSS
   - Mantém .btn/.badge/.card
   - Adiciona componentes novos
   ========================= */

/* Buttons (compat + upgrade) */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border: 1px solid var(--text);
  background: var(--text);
  color:#fff;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  text-decoration:none;
  font-weight: 900;
  cursor:pointer;
  user-select:none;
  transition: filter .12s ease, transform .06s ease, background .18s ease, border-color .18s ease;
}
.btn:hover{ filter: brightness(.96); text-decoration:none; }
.btn:active{ transform: translateY(1px); }
button.btn{ font: inherit; }

.btn--ghost{
  background: transparent;
  color: var(--text);
}
.btn--primary{
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color:#fff;
}
.btn--outline{
  background: transparent;
  border-color: rgba(0,0,0,.18);
  color: var(--text);
}

/* Badge (compat) */
.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  background: var(--text);
  color:#fff;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  line-height: 1;
}

/* novos tons (não quebram o antigo) */
.badge--danger{ background: rgba(176,0,32,.92); }
.badge--info{ background: rgba(11,95,255,.92); }
.badge--success{ background: rgba(26,127,55,.92); }

/* Cards compat */
.card{
  border:1px solid var(--border);
  border-radius: var(--radius-md);
  overflow:hidden;
  background: var(--card);
  color: var(--text);
  text-decoration:none;
}
.card__img{
  position:relative;
  aspect-ratio: 16/10;
  background: rgba(0,0,0,.04);
}
.card__img img{ width:100%; height:100%; object-fit:cover; display:block; }
.ph{ height:100%; display:flex; align-items:center; justify-content:center; color: rgba(0,0,0,.5); font-weight: 800; }
.card__body{ padding: 12px; }
.card__title{ font-weight: 900; margin-bottom: 6px; }
.card__meta{ color: rgba(0,0,0,.62); font-size: 13px; }
.card__cta{ margin-top:10px; font-weight: 900; color: var(--brand-primary); }

/* Novo componente: vehicle card (para usar com vehicle_card.php) */
.vehicle-card{
  border:1px solid rgba(15,23,42,.08);
  border-radius: var(--radius-md);
  overflow:hidden;
  background: var(--card);
  color: var(--text);
  text-decoration:none;
  box-shadow: var(--shadow);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.vehicle-card:hover{
  transform: translateY(-2px);
  border-color: rgba(11,95,255,.22);
  box-shadow: 0 18px 40px rgba(2,6,23,.10);
}
.vehicle-card__media{
  position: relative;
  display:block;
  aspect-ratio: 16/10;
  background: rgba(0,0,0,.04);
}
.vehicle-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.vehicle-card__placeholder{
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(0,0,0,.5);
  font-weight: 800;
}
.vehicle-card__badges{
  position:absolute;
  top:10px;
  left:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.vehicle-card__body{ padding: 12px; }
.vehicle-card__title{ font-weight: 900; margin: 0 0 6px; }
.vehicle-card__meta{ color: rgba(0,0,0,.62); font-size: 13px; display:flex; gap:10px; flex-wrap: wrap; }
.vehicle-card__footer{
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.vehicle-card__price{ font-weight: 900; }