/* City-Funk Bookings – Public Styles */

/* ── Vehicle cards (step 2) ──────────────────────────────── */
.cfb-vehicle-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  margin-bottom: .25rem;
}
.cfb-vehicle-card {
  cursor: pointer;
  display: block;
}
.cfb-vehicle-card input { display: none; }
.cfb-vehicle-card__inner {
  border: 2px solid var(--cf-border, #e2dedd);
  border-radius: .75rem;
  padding: .75rem .55rem;
  text-align: center;
  background: var(--cf-bg-soft, #f6f5f3);
  transition: all .18s;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.cfb-vehicle-card__name {
  font-weight: 700;
  font-size: 1rem;
  color: var(--cf-text-muted, #7a7470);
  margin-bottom: .15rem;
}
.cfb-vehicle-card__models {
  font-size: .75rem;
  font-weight: 600;
  color: var(--cf-text-muted, #7a7470);
  margin-bottom: .6rem;
  line-height: 1.3;
}
.cfb-vehicle-card__specs {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  font-size: .7rem;
  color: var(--cf-text-muted, #7a7470);
  margin-bottom: .6rem;
  padding: .4rem 0;
  border-top: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.cfb-vehicle-card__specs span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .3rem;
}
.cfb-vehicle-card__specs svg {
  opacity: .7;
}
.cfb-vehicle-card__price {
  font-family: 'Raleway', sans-serif;
  font-weight: 900;
  font-size: .95rem;
  color: var(--cf-text, #1a1714);
  line-height: 1.1;
}
.cfb-vehicle-card.is-selected .cfb-vehicle-card__inner,
.cfb-vehicle-card input:checked ~ .cfb-vehicle-card__inner {
  border-color: var(--cf-red, #a50021);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(165,0,33,.12);
}
.cfb-vehicle-card.is-selected .cfb-vehicle-card__name,
.cfb-vehicle-card.is-selected .cfb-vehicle-card__models {
  color: var(--cf-red, #a50021);
}
.cfb-vehicle-card:hover .cfb-vehicle-card__inner {
  border-color: var(--cf-red, #a50021);
}

/* ── Route summary pill ──────────────────────────────────── */
.cfb-route-pill {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .35rem;
  background: var(--cf-bg-soft, #f6f5f3);
  border: 1.5px solid var(--cf-border, #e2dedd);
  border-radius: .65rem;
  padding: .55rem .75rem;
  font-size: .82rem;
}
.cfb-route-from, .cfb-route-to {
  font-weight: 600;
  color: var(--cf-text, #1a1714);
  max-width: 130px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cfb-route-arrow { color: var(--cf-red, #a50021); font-weight: 700; }
.cfb-route-stops {
  background: var(--cf-red, #a50021);
  color: #fff;
  border-radius: 999px;
  padding: .05rem .45rem;
  font-size: .75rem;
  font-weight: 700;
}
.cfb-route-km {
  margin-left: auto;
  font-style: italic;
  color: var(--cf-text-muted, #7a7470);
}

/* ── pac-container z-index ───────────────────────────────── */
.pac-container { z-index: 99999 !important; }
