/* ═══════════════════════════════════════════════════════════════
   BUBBLING FISH — Premium Booking UI  v2.0
   Matches the MakeMyTrip-quality design mockups exactly
   ═══════════════════════════════════════════════════════════════ */

/* ── Root variables ─────────────────────────────────────────── */
#bfbs-app {
  --blue:   #1a56db;
  --blue2:  #1e429f;
  --teal:   #0694a2;
  --green:  #057a55;
  --purple: #7e3af2;
  --pink:   #e74694;
  --orange: #ff5a1f;
  --ink:    #111928;
  --slate:  #374151;
  --mid:    #6b7280;
  --muted:  #9ca3af;
  --bd:     #e5e7eb;
  --sf:     #f9fafb;
  --w:      #ffffff;
  --sh-sm:  0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
  --sh-md:  0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
  --sh-lg:  0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
  --sh-xl:  0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);
  --r:      12px;
  --r-lg:   20px;
  --r-xl:   28px;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--sf);
  color: var(--slate);
  -webkit-font-smoothing: antialiased;
}

/* ── Sticky stepper bar ─────────────────────────────────────── */
.bf-stepper-wrap {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--w);
  border-bottom: 1px solid var(--bd);
  box-shadow: var(--sh-sm);
  padding: 0 24px;
}
.bf-stepper-progress {
  height: 3px;
  background: var(--bd);
  position: absolute;
  top: 0; left: 0; right: 0;
}
.bf-stepper-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--blue), var(--teal));
  transition: width .4s cubic-bezier(.4,0,.2,1);
  border-radius: 0 2px 2px 0;
}
.bf-stepper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 860px;
  margin: 0 auto;
  padding: 14px 0;
  gap: 0;
}
.bf-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  position: relative;
  flex: 1;
}
.bf-step-num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--sf);
  border: 2px solid var(--bd);
  color: var(--muted);
  font-size: 13px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  transition: all .3s;
  position: relative; z-index: 1;
}
.bf-step.active .bf-step-num {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  box-shadow: 0 0 0 4px rgba(26,86,219,.15);
}
.bf-step.done .bf-step-num {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}
.bf-step.done .bf-step-num::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/14px no-repeat;
}
.bf-step.done .bf-step-num span { display: none; }
.bf-step-lbl {
  font-size: 11px; font-weight: 600;
  color: var(--muted);
  white-space: nowrap;
  transition: color .3s;
}
.bf-step.active .bf-step-lbl { color: var(--blue); font-weight: 700; }
.bf-step.done .bf-step-lbl   { color: var(--slate); }
.bf-step-line {
  flex: 1;
  height: 2px;
  background: var(--bd);
  margin: 0 4px;
  margin-bottom: 18px;
  transition: background .3s;
  min-width: 20px;
}
.bf-step-line.done { background: var(--blue); }
/* Help pill */
.bf-stepper-help {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 100px;
  font-size: 12px; font-weight: 600;
  color: var(--blue) !important;
  -webkit-text-fill-color: var(--blue) !important;
  white-space: nowrap;
  text-decoration: none;
  flex-shrink: 0;
}
.bf-stepper-help:hover { background: #dbeafe; }
@media(max-width:640px) {
  .bf-step-lbl { display: none; }
  .bf-stepper-wrap { padding: 0 16px; }
  .bf-stepper-help span { display: none; }
}

/* ── Canvas & panels ────────────────────────────────────────── */
.bf-canvas { max-width: 1100px; margin: 0 auto; padding: 40px 24px 80px; }
.bf-panel { display: none; }
.bf-panel.active { display: block; animation: slideUp .3s ease both; }
@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Step panel header ──────────────────────────────────────── */
.bf-panel-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 40px;
}
.bf-panel-eyebrow {
  display: inline-block;
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  color: var(--blue) !important; -webkit-text-fill-color: var(--blue) !important;
  background: #eff6ff; border-radius: 100px;
  padding: 4px 14px; margin-bottom: 12px;
}
.bf-panel-title {
  font-size: clamp(26px,4vw,40px);
  font-weight: 800; color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
  letter-spacing: -.5px; line-height: 1.15;
  margin-bottom: 12px;
}
.bf-panel-sub {
  font-size: 16px; color: var(--mid) !important;
  -webkit-text-fill-color: var(--mid) !important;
  line-height: 1.6;
}

/* ══════════════════════════════════════════════════════════════
   STEP 1 — PROGRAMME CARDS (5 horizontal cards)
   ══════════════════════════════════════════════════════════════ */
.bf-programs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  margin-bottom: 40px;
}
@media(max-width:1000px){ .bf-programs { grid-template-columns: repeat(3,1fr); } }
@media(max-width:640px) { .bf-programs { grid-template-columns: repeat(2,1fr); gap: 12px; } }

.bf-pc {
  background: var(--w);
  border: 2px solid var(--bd);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all .25s cubic-bezier(.4,0,.2,1);
  box-shadow: var(--sh-sm);
  display: flex; flex-direction: column;
  position: relative;
}
.bf-pc:hover {
  border-color: var(--blue);
  transform: translateY(-6px);
  box-shadow: var(--sh-xl);
}
.bf-pc.sel {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(26,86,219,.12), var(--sh-lg);
}

/* Programme image */
.bf-pc-img-wrap {
  height: 160px;
  background: linear-gradient(135deg,#ebf5ff,#e0e7ff);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.bf-pc-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bf-pc-img-fallback {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.bf-pc-fallback-emoji { font-size: 80px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.15)); }

/* Selected checkmark */
.bf-pc-sel-badge {
  position: absolute; top: 10px; right: 10px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--blue);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(.5);
  transition: all .2s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 2px 8px rgba(26,86,219,.4);
}
.bf-pc.sel .bf-pc-sel-badge { opacity: 1; transform: scale(1); }

/* Body */
.bf-pc-body { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.bf-pc-name {
  font-size: 18px; font-weight: 800;
  text-align: center; line-height: 1.2;
}
/* Each program gets its own colour */
.bf-pc[data-slug="baby-fish"]  .bf-pc-name { color: var(--blue)   !important; -webkit-text-fill-color: var(--blue)   !important; }
.bf-pc[data-slug="jelly-fish"] .bf-pc-name { color: var(--purple) !important; -webkit-text-fill-color: var(--purple) !important; }
.bf-pc[data-slug="star-fish"]  .bf-pc-name { color: var(--pink)   !important; -webkit-text-fill-color: var(--pink)   !important; }
.bf-pc[data-slug="baby-shark"] .bf-pc-name { color: var(--blue2)  !important; -webkit-text-fill-color: var(--blue2)  !important; }
.bf-pc[data-slug="manta-squad"].bf-pc-name { color: var(--teal)   !important; -webkit-text-fill-color: var(--teal)   !important; }

/* Age badge */
.bf-pc-age-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 100px;
  font-size: 12px; font-weight: 700;
  text-align: center;
  margin: 0 auto;
}
.bf-pc[data-slug="baby-fish"]  .bf-pc-age-badge { background: #eff6ff; color: var(--blue)   !important; -webkit-text-fill-color: var(--blue)   !important; }
.bf-pc[data-slug="jelly-fish"] .bf-pc-age-badge { background: #f5f3ff; color: var(--purple) !important; -webkit-text-fill-color: var(--purple) !important; }
.bf-pc[data-slug="star-fish"]  .bf-pc-age-badge { background: #fdf2f8; color: var(--pink)   !important; -webkit-text-fill-color: var(--pink)   !important; }
.bf-pc[data-slug="baby-shark"] .bf-pc-age-badge { background: #eff6ff; color: var(--blue2)  !important; -webkit-text-fill-color: var(--blue2)  !important; }
.bf-pc[data-slug="manta-squad"].bf-pc-age-badge { background: #ecfdf5; color: var(--teal)   !important; -webkit-text-fill-color: var(--teal)   !important; }

.bf-pc-focus {
  font-size: 12.5px; color: var(--mid) !important;
  -webkit-text-fill-color: var(--mid) !important;
  text-align: center; line-height: 1.5;
}

/* CTA */
.bf-pc-foot { padding: 0 16px 16px; }
.bf-pc-cta {
  width: 100%; height: 44px;
  border: 2px solid var(--bd);
  border-radius: var(--r);
  background: transparent;
  font-size: 14px; font-weight: 700;
  cursor: pointer; transition: all .22s;
  display: flex; align-items: center; justify-content: center;
  color: var(--slate) !important; -webkit-text-fill-color: var(--slate) !important;
}
.bf-pc[data-slug="baby-fish"]  .bf-pc-cta { border-color: var(--blue);   color: var(--blue)   !important; -webkit-text-fill-color: var(--blue)   !important; }
.bf-pc[data-slug="jelly-fish"] .bf-pc-cta { border-color: var(--purple); color: var(--purple) !important; -webkit-text-fill-color: var(--purple) !important; }
.bf-pc[data-slug="star-fish"]  .bf-pc-cta { border-color: var(--pink);   color: var(--pink)   !important; -webkit-text-fill-color: var(--pink)   !important; }
.bf-pc[data-slug="baby-shark"] .bf-pc-cta { border-color: var(--blue2);  color: var(--blue2)  !important; -webkit-text-fill-color: var(--blue2)  !important; }
.bf-pc[data-slug="manta-squad"].bf-pc-cta { border-color: var(--teal);   color: var(--teal)   !important; -webkit-text-fill-color: var(--teal)   !important; }

.bf-pc.sel .bf-pc-cta,
.bf-pc:hover .bf-pc-cta {
  background: var(--blue) !important; border-color: var(--blue) !important;
  color: #fff !important; -webkit-text-fill-color: #fff !important;
  box-shadow: 0 4px 14px rgba(26,86,219,.35);
}
.bf-pc[data-slug="jelly-fish"].sel .bf-pc-cta,
.bf-pc[data-slug="jelly-fish"]:hover .bf-pc-cta { background: var(--purple) !important; border-color: var(--purple) !important; box-shadow: 0 4px 14px rgba(126,58,242,.35); }
.bf-pc[data-slug="star-fish"].sel .bf-pc-cta,
.bf-pc[data-slug="star-fish"]:hover .bf-pc-cta   { background: var(--pink) !important; border-color: var(--pink) !important; box-shadow: 0 4px 14px rgba(231,70,148,.35); }
.bf-pc[data-slug="baby-shark"].sel .bf-pc-cta,
.bf-pc[data-slug="baby-shark"]:hover .bf-pc-cta  { background: var(--blue2) !important; border-color: var(--blue2) !important; }
.bf-pc[data-slug="manta-squad"].sel .bf-pc-cta,
.bf-pc[data-slug="manta-squad"]:hover .bf-pc-cta { background: var(--teal) !important; border-color: var(--teal) !important; box-shadow: 0 4px 14px rgba(6,148,162,.35); }

/* ══════════════════════════════════════════════════════════════
   STEP 2 — LOCATION CARDS with filter bar
   ══════════════════════════════════════════════════════════════ */
.bf-loc-filter-bar {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 28px; flex-wrap: wrap;
}
.bf-loc-search {
  flex: 1; min-width: 240px;
  height: 48px; padding: 0 16px 0 46px;
  border: 1.5px solid var(--bd); border-radius: var(--r);
  font-size: 14px; background: var(--w);
  position: relative;
  outline: none; transition: border-color .18s;
  color: var(--ink) !important; -webkit-text-fill-color: var(--ink) !important;
}
.bf-loc-search:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(26,86,219,.08); }
.bf-loc-search-wrap { position: relative; flex: 1; min-width: 240px; }
.bf-loc-search-icon {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: var(--muted); pointer-events: none;
}
.bf-loc-filter-select {
  height: 48px; padding: 0 36px 0 14px;
  border: 1.5px solid var(--bd); border-radius: var(--r);
  font-size: 14px; font-weight: 500; background: var(--w);
  outline: none; cursor: pointer; transition: border-color .18s;
  color: var(--ink) !important; -webkit-text-fill-color: var(--ink) !important;
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.bf-loc-filter-select:focus { border-color: var(--blue); }

/* Location grid — 3 columns */
.bf-locs-grid-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}
@media(max-width:900px) { .bf-locs-grid-wrap { grid-template-columns: repeat(2,1fr); } }
@media(max-width:580px) { .bf-locs-grid-wrap { grid-template-columns: 1fr; } }

.bf-lc {
  background: var(--w);
  border: 2px solid var(--bd);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all .25s cubic-bezier(.4,0,.2,1);
  box-shadow: var(--sh-sm);
  display: flex; flex-direction: column;
  position: relative;
}
.bf-lc:hover {
  border-color: var(--blue);
  transform: translateY(-5px);
  box-shadow: var(--sh-xl);
}
.bf-lc.sel {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(26,86,219,.12), var(--sh-lg);
}
.bf-lc-vis {
  height: 180px; position: relative; overflow: hidden;
  background: linear-gradient(135deg,#1e40af,#1d4ed8);
}
.bf-lc-img { width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease; }
.bf-lc:hover .bf-lc-img { transform: scale(1.07); }
.bf-lc-img-fb { width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px; }
.bf-lc-overlay { position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,0) 55%); }
/* Number badge */
.bf-lc-num {
  position:absolute;top:12px;left:12px;z-index:2;
  width:34px;height:34px;border-radius:var(--r);
  background:var(--blue);color:#fff!important;-webkit-text-fill-color:#fff!important;
  font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
/* Seats pill */
.bf-lc-seats-pill {
  position:absolute;bottom:12px;right:12px;z-index:2;
  padding:4px 12px;border-radius:100px;
  font-size:11.5px;font-weight:700;
  background:rgba(5,122,85,.9);color:#fff!important;-webkit-text-fill-color:#fff!important;
  backdrop-filter:blur(4px);
}
.bf-lc-seats-pill.low { background:rgba(255,90,31,.9); }
.bf-lc-seats-pill.full{ background:rgba(229,57,53,.9); }
/* Favourite heart */
.bf-lc-fav {
  position:absolute;top:12px;right:12px;z-index:2;
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.9);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;transition:all .18s;color:var(--muted);
}
.bf-lc-fav:hover { background:#fff; color:var(--pink)!important; -webkit-text-fill-color:var(--pink)!important; }

/* Location body */
.bf-lc-body { padding:16px 18px; flex:1; display:flex; flex-direction:column; }
.bf-lc-name {
  font-size:16px;font-weight:800;
  color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;
  margin-bottom:6px;
}
.bf-lc-addr {
  display:flex;align-items:center;gap:5px;
  font-size:12.5px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;
  margin-bottom:4px;
}
.bf-lc-days-row {
  display:flex;align-items:center;gap:5px;
  font-size:12.5px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;
  margin-bottom:12px;
}
/* Price + select row */
.bf-lc-footer {
  display:flex;align-items:center;justify-content:space-between;
  padding-top:12px;border-top:1px solid var(--bd);
  margin-top:auto;gap:10px;
}
.bf-lc-price-wrap { display:flex;flex-direction:column; }
.bf-lc-price {
  font-size:20px;font-weight:800;line-height:1;
  color:var(--orange)!important;-webkit-text-fill-color:var(--orange)!important;
}
.bf-lc-price-label {
  font-size:11px;font-weight:600;
  color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;
  margin-top:2px;
}
.bf-lc-price-label.members { color:var(--orange)!important;-webkit-text-fill-color:var(--orange)!important; font-weight:700; }
.bf-lc-select-btn {
  height:40px;padding:0 20px;
  border-radius:100px;
  font-size:13px;font-weight:700;
  cursor:pointer;transition:all .22s;
  display:flex;align-items:center;gap:6px;
  white-space:nowrap;border:none;flex-shrink:0;
  background:var(--blue);
  color:#fff!important;-webkit-text-fill-color:#fff!important;
  box-shadow:0 3px 10px rgba(26,86,219,.3);
}
.bf-lc-select-btn:hover { background:var(--blue2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(26,86,219,.4); }
.bf-lc.sel .bf-lc-select-btn { background:var(--green);box-shadow:0 3px 10px rgba(5,122,85,.3); }
/* BGC — orange */
.bf-lc[data-slug="bgc"] .bf-lc-select-btn { background:var(--orange); box-shadow:0 3px 10px rgba(255,90,31,.3); }
/* Ekya — purple */
.bf-lc[data-slug="ekya-byrathi"] .bf-lc-select-btn { background:var(--purple); box-shadow:0 3px 10px rgba(126,58,242,.3); }
/* Radisson — pink */
.bf-lc[data-slug="radisson-blu"] .bf-lc-select-btn { background:var(--pink); box-shadow:0 3px 10px rgba(231,70,148,.3); }
.bf-lc-view-btn {
  height:40px;padding:0 16px;
  border-radius:100px;border:1.5px solid var(--bd);
  background:transparent;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .18s;
  color:var(--slate)!important;-webkit-text-fill-color:var(--slate)!important;
}
.bf-lc-view-btn:hover { border-color:var(--blue);color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important; }

/* ── Trust strip (below grids) ────────────────────────────── */
.bf-trust-strip {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  background:var(--w);border:1px solid var(--bd);
  border-radius:var(--r-lg);padding:24px 28px;
  margin:8px 0 32px;
}
@media(max-width:640px){ .bf-trust-strip{grid-template-columns:repeat(2,1fr);} }
.bf-trust-item { display:flex;align-items:flex-start;gap:14px; }
.bf-trust-icon {
  width:44px;height:44px;border-radius:var(--r);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.bf-trust-icon.blue   { background:#eff6ff; }
.bf-trust-icon.green  { background:#f0fdf4; }
.bf-trust-icon.orange { background:#fff7ed; }
.bf-trust-icon.purple { background:#f5f3ff; }
.bf-trust-title {
  font-size:13.5px;font-weight:700;
  color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;
  margin-bottom:3px;
}
.bf-trust-desc {
  font-size:12px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;
  line-height:1.5;
}

/* ══════════════════════════════════════════════════════════════
   NAVIGATION BUTTONS
   ══════════════════════════════════════════════════════════════ */
.bf-nav-row {
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding-top:28px;
  border-top:1px solid var(--bd);margin-top:8px;
}
.bf-btn-back {
  display:flex;align-items:center;gap:7px;
  height:52px;padding:0 24px;
  background:var(--w);border:1.5px solid var(--bd);
  border-radius:14px;font-size:14px;font-weight:700;
  cursor:pointer;transition:all .2s;
  color:var(--slate)!important;-webkit-text-fill-color:var(--slate)!important;
}
.bf-btn-back:hover { border-color:var(--blue);color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important; }
.bf-btn-next {
  display:flex;align-items:center;justify-content:center;gap:8px;
  height:52px;padding:0 32px;min-width:200px;
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff!important;-webkit-text-fill-color:#fff!important;
  border:none;border-radius:14px;font-size:15px;font-weight:700;
  cursor:pointer;transition:all .25s;
  box-shadow:0 6px 20px rgba(26,86,219,.3);
}
.bf-btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px rgba(26,86,219,.4);}
.bf-btn-next:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.bf-btn-pay {
  width:100%;height:58px;
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff!important;-webkit-text-fill-color:#fff!important;
  border:none;border-radius:16px;font-size:17px;font-weight:800;
  cursor:pointer;transition:all .25s;
  box-shadow:0 8px 24px rgba(26,86,219,.32);
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-bottom:14px;
}
.bf-btn-pay:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 36px rgba(26,86,219,.42);}
.bf-btn-pay:disabled{opacity:.4;cursor:not-allowed;}
.bf-btn-request {
  background:linear-gradient(135deg,#f59e0b,#d97706)!important;
  box-shadow:0 8px 24px rgba(245,158,11,.3)!important;
}
.bf-btn-future {
  background:linear-gradient(135deg,#7e3af2,#6c2bd9)!important;
  box-shadow:0 8px 24px rgba(126,58,242,.3)!important;
}

/* ══════════════════════════════════════════════════════════════
   BATCH CARDS + CALENDAR
   ══════════════════════════════════════════════════════════════ */
.bf-batch-group { margin-bottom:24px; }
.bf-batch-group-hd {
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:12px;margin-bottom:12px;
  font-size:13px;font-weight:800;
}
.bf-bgh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.bf-bgh-label{flex:1;color:inherit!important;-webkit-text-fill-color:inherit!important;}
.bf-bgh-count{font-size:11px;font-weight:600;opacity:.7;}
.bf-bgh-ongoing{background:rgba(5,122,85,.08);color:#057a55!important;border:1px solid rgba(5,122,85,.2);}
.bf-bgh-ongoing .bf-bgh-dot{background:#057a55;}
.bf-bgh-upcoming{background:rgba(26,86,219,.07);color:var(--blue)!important;border:1px solid rgba(26,86,219,.18);}
.bf-bgh-upcoming .bf-bgh-dot{background:var(--blue);}
.bf-bgh-future{background:rgba(126,58,242,.07);color:var(--purple)!important;border:1px solid rgba(126,58,242,.18);}
.bf-bgh-future .bf-bgh-dot{background:var(--purple);}

.bf-batches{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.bf-batch {
  display:flex;align-items:stretch;
  background:var(--w);border:2px solid var(--bd);border-radius:16px;
  overflow:hidden;cursor:pointer;transition:all .22s;box-shadow:var(--sh-sm);
}
.bf-batch:hover:not(.full){border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--sh-lg);}
.bf-batch.sel{border-color:var(--blue);background:#f0f7ff;box-shadow:0 0 0 3px rgba(26,86,219,.1),var(--sh-md);}
.bf-batch.full{opacity:.55;cursor:not-allowed;}
.bf-batch-time{
  flex-shrink:0;width:96px;padding:18px 12px;
  background:var(--sf);border-right:1px solid var(--bd);
  text-align:center;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:3px;
}
.bf-batch.sel .bf-batch-time{background:rgba(26,86,219,.05);border-right-color:rgba(26,86,219,.15);}
.bf-batch-t1{font-family:'Inter',sans-serif;font-size:18px;font-weight:900;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;line-height:1;}
.bf-batch-t2{font-size:10.5px;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;font-weight:600;}
.bf-batch-info{flex:1;padding:14px 18px;}
.bf-batch-name{font-size:15px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:5px;}
.bf-batch-dateline{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--teal)!important;-webkit-text-fill-color:var(--teal)!important;margin-bottom:5px;}
.bf-batch-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px;}
.bf-tag{display:inline-flex;align-items:center;gap:4px;background:var(--sf);border:1px solid var(--bd);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;}
.bf-batch-price{flex-shrink:0;padding:14px 18px;text-align:right;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:6px;}
.bf-batch-price-val{font-size:18px;font-weight:900;color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;white-space:nowrap;}
.bf-price-club{font-size:13px;font-weight:700;color:#d97706!important;-webkit-text-fill-color:#d97706!important;}
.bf-batch-seats{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--green)!important;-webkit-text-fill-color:var(--green)!important;padding:3px 10px;border-radius:100px;background:rgba(5,122,85,.08);}
.bf-batch-seats.full{color:#e53935!important;-webkit-text-fill-color:#e53935!important;background:rgba(229,57,53,.08);}
.bf-batch-seats.low{color:#d97706!important;-webkit-text-fill-color:#d97706!important;background:rgba(217,119,6,.1);}

/* Calendar pills */
.bf-cal-intro{font-size:13px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;margin:8px 0 14px;font-weight:600;}
.bf-cal-pills{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;margin-bottom:18px;scrollbar-width:none;}
.bf-cal-pills::-webkit-scrollbar{display:none;}
.bf-cal-pill{flex-shrink:0;min-width:110px;background:var(--w);border:2px solid var(--bd);border-radius:14px;padding:12px 14px;cursor:pointer;text-align:center;display:flex;flex-direction:column;gap:4px;transition:all .22s;}
.bf-cal-pill:hover{border-color:rgba(126,58,242,.4);transform:translateY(-2px);}
.bf-cal-pill-active{border-color:var(--purple)!important;background:rgba(126,58,242,.05)!important;box-shadow:0 0 0 3px rgba(126,58,242,.12),var(--sh-md);}
.bf-cal-pill-month{font-size:13px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;}
.bf-cal-pill-active .bf-cal-pill-month{color:var(--purple)!important;-webkit-text-fill-color:var(--purple)!important;}
.bf-cal-pill-cnt{font-size:10.5px;font-weight:600;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;}
.bf-cal-pill-seats{font-size:10px;font-weight:700;color:var(--green)!important;-webkit-text-fill-color:var(--green)!important;background:rgba(5,122,85,.08);border-radius:100px;padding:1px 8px;}
.bf-cal-pill-full{font-size:10px;font-weight:700;color:#e53935!important;-webkit-text-fill-color:#e53935!important;background:rgba(229,57,53,.08);border-radius:100px;padding:1px 8px;}
.bf-cal-month-label{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;background:rgba(126,58,242,.07);border:1px solid rgba(126,58,242,.2);border-radius:10px;padding:7px 14px;margin-bottom:12px;}
.bf-cal-batches .bf-batch{animation:slideIn .2s ease;}
@keyframes slideIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ══════════════════════════════════════════════════════════════
   FORM FIELDS, RECEIPT, TERMS
   ══════════════════════════════════════════════════════════════ */
.bf-form-card{background:var(--w);border:1px solid var(--bd);border-radius:20px;padding:24px 26px;margin-bottom:20px;box-shadow:var(--sh-sm);}
.bf-form-title{font-size:15px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--bd);}
.bf-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:600px){.bf-form-grid{grid-template-columns:1fr;}}
.bf-form-grid .bf-field.full{grid-column:1/-1;}
.bf-field{display:flex;flex-direction:column;gap:6px;}
.bf-label{font-size:11px;font-weight:700;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;text-transform:uppercase;letter-spacing:.5px;}
.bf-input{height:48px;padding:0 14px;border:1.5px solid var(--bd);border-radius:var(--r);font-size:14px;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;background:var(--w);transition:border-color .18s,box-shadow .18s;outline:none;width:100%;}
.bf-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,219,.08);}
.bf-input::placeholder{color:var(--muted);}
textarea.bf-input{height:80px;padding:12px 14px;resize:vertical;}
.bf-select-wrap{position:relative;}
.bf-select-wrap::after{content:'▾';position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--muted);font-size:12px;}
.bf-select-wrap select{-webkit-appearance:none;appearance:none;}
.bf-age-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;font-size:12px;font-weight:700;margin-top:4px;border:1.5px solid transparent;transition:all .22s;}
.bf-age-chip.ok{background:rgba(5,122,85,.08);color:var(--green)!important;-webkit-text-fill-color:var(--green)!important;border-color:rgba(5,122,85,.25);}
.bf-age-chip.bad{background:rgba(229,57,53,.07);color:#e53935!important;-webkit-text-fill-color:#e53935!important;border-color:rgba(229,57,53,.2);}
.bf-age-chip:not(.ok):not(.bad){background:rgba(26,86,219,.07);color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;border-color:rgba(26,86,219,.18);}
/* Accessories */
.bf-addons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;}
@media(max-width:700px){.bf-addons-grid{grid-template-columns:repeat(2,1fr);}}
.bf-addon{background:var(--w);border:2px solid var(--bd);border-radius:16px;overflow:hidden;transition:all .2s;}
.bf-addon.picked{border-color:var(--teal);}
.bf-addon-vis{height:90px;background:var(--sf);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.bf-addon-vis img{width:100%;height:100%;object-fit:cover;}
.bf-addon-emoji{font-size:36px;}
.bf-addon-body{padding:10px 12px;}
.bf-addon-name{font-size:12.5px;font-weight:700;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:2px;}
.bf-addon-price{font-size:16px;font-weight:900;color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;margin-bottom:8px;}
.bf-addon-qty{display:flex;align-items:center;justify-content:space-between;}
.bf-qty-btn{width:28px;height:28px;border-radius:50%;background:var(--sf);border:1px solid var(--bd);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;transition:all .15s;}
.bf-qty-btn:hover:not(:disabled){background:var(--blue);color:#fff!important;-webkit-text-fill-color:#fff!important;border-color:var(--blue);}
.bf-qty-btn:disabled{opacity:.35;}
.bf-qty-val{font-size:16px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;}
/* Receipt */
.bf-coupon-row{margin-bottom:16px;}
.bf-coupon-group{display:flex;gap:8px;}
.bf-coupon-input{flex:1;text-transform:uppercase;letter-spacing:1px;font-weight:700;}
.bf-coupon-apply-btn{flex-shrink:0;padding:0 20px;height:48px;border-radius:var(--r);background:transparent;border:1.5px solid var(--bd);color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap;transition:all .2s;}
.bf-coupon-apply-btn:hover{border-color:var(--blue);color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;}
.bf-receipt{background:var(--w);border:1px solid var(--bd);border-radius:20px;overflow:hidden;margin-bottom:20px;box-shadow:var(--sh-sm);}
.bf-receipt-head{background:linear-gradient(135deg,var(--ink),#1f2937);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;}
.bf-receipt-head-t{font-size:14px;font-weight:700;color:#fff!important;-webkit-text-fill-color:#fff!important;}
.bf-receipt-head-b{font-size:10px;font-weight:700;letter-spacing:1.5px;color:rgba(255,255,255,.35)!important;-webkit-text-fill-color:rgba(255,255,255,.35)!important;}
.bf-receipt-row{display:flex;justify-content:space-between;align-items:center;padding:11px 20px;border-bottom:1px solid var(--bd);}
.bf-receipt-row:last-child{border-bottom:none;}
.bf-receipt-k{font-size:13px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;}
.bf-receipt-v{font-size:13px;font-weight:700;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;text-align:right;max-width:60%;}
.bf-receipt-total{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--sf);}
.bf-receipt-total-l{font-size:15px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;}
.bf-receipt-total-v{font-size:28px;font-weight:900;color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;}
/* Terms */
.bf-terms-wrap{background:var(--sf);border:1.5px solid var(--bd);border-radius:16px;overflow:hidden;margin-bottom:18px;}
.bf-terms-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;}
.bf-terms-head-t{font-size:13px;font-weight:700;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;}
.bf-terms-arrow{font-size:12px;color:var(--muted);transition:transform .2s;}
.bf-terms-body{padding:0 18px 14px;font-size:12px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;line-height:1.7;display:none;border-top:1px solid var(--bd);}
.bf-terms-agreed{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--w);}
.bf-terms-agreed input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--blue);margin-top:1px;cursor:pointer;}
.bf-terms-agreed label{font-size:13px;font-weight:500;color:var(--slate)!important;-webkit-text-fill-color:var(--slate)!important;cursor:pointer;line-height:1.55;}
.bf-secure{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;margin-bottom:12px;}
/* Payment notices */
.bf-offline-notice{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #f59e0b;border-radius:18px;padding:24px;text-align:center;margin-bottom:20px;}
.bf-offline-icon{font-size:44px;margin-bottom:10px;}
.bf-offline-title{font-size:20px;font-weight:900;color:#92400e!important;-webkit-text-fill-color:#92400e!important;margin-bottom:8px;}
.bf-offline-desc{font-size:13.5px;color:#78350f!important;-webkit-text-fill-color:#78350f!important;line-height:1.6;margin-bottom:14px;}
.bf-offline-points{display:flex;flex-direction:column;gap:7px;text-align:left;max-width:320px;margin:0 auto;}
.bf-offline-point{font-size:13px;font-weight:600;color:#78350f!important;-webkit-text-fill-color:#78350f!important;}
.bf-future-notice{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:2px solid rgba(126,58,242,.25);border-radius:18px;padding:24px;text-align:center;margin-bottom:20px;}
.bf-future-notice-icon{font-size:44px;margin-bottom:10px;}
.bf-future-notice-title{font-size:20px;font-weight:900;color:#5b21b6!important;-webkit-text-fill-color:#5b21b6!important;margin-bottom:8px;}
.bf-future-notice-desc{font-size:13.5px;color:#6d28d9!important;-webkit-text-fill-color:#6d28d9!important;line-height:1.6;margin-bottom:14px;}
.bf-future-step{font-size:13px;font-weight:600;color:#7c3aed!important;-webkit-text-fill-color:#7c3aed!important;}
/* Alerts */
.bf-alert{border-radius:12px;padding:12px 16px;font-size:13.5px;font-weight:600;margin-bottom:14px;}
.bf-alert-err{background:rgba(229,57,53,.07);border:1px solid rgba(229,57,53,.18);color:#e53935!important;-webkit-text-fill-color:#e53935!important;}
.bf-alert-ok{background:rgba(5,122,85,.07);border:1px solid rgba(5,122,85,.2);color:var(--green)!important;-webkit-text-fill-color:var(--green)!important;}
/* Loading / empty */
.bf-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px 20px;color:var(--muted);font-size:14px;}
.bf-spin{width:24px;height:24px;border-radius:50%;border:3px solid var(--bd);border-top-color:var(--blue);animation:spin .7s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg);}}
.bf-empty{text-align:center;padding:56px 20px;}
.bf-empty-icon{font-size:44px;margin-bottom:14px;}
.bf-empty-title{font-size:18px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:6px;}
.bf-empty-desc{font-size:13.5px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;}

/* ── SVG icons ──────────────────────────────────────────────── */
.bfi{display:inline-block;width:14px;height:14px;vertical-align:middle;flex-shrink:0;margin-right:4px;position:relative;top:-1px;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.bfi-cal{color:var(--teal);width:13px;height:13px;}
.bf-tag .bfi{width:12px;height:12px;margin-right:3px;}
.bf-batch-seats .bfi{width:13px;height:13px;margin-right:3px;}
.bf-batch-seats.full .bfi{color:#e53935;}
.bf-batch-seats.low .bfi{color:#d97706;}

/* ── Thank you page ─────────────────────────────────────────── */
.bf-thankyou-wrap{max-width:560px;margin:0 auto;padding:48px 24px 60px;text-align:center;}
.bf-confirm-anim{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(5,122,85,.12),rgba(26,86,219,.1));border:3px solid var(--green);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:confirmPop .5s cubic-bezier(.4,0,.2,1) both;}
@keyframes confirmPop{0%{transform:scale(.5);opacity:0;}70%{transform:scale(1.12);}100%{transform:scale(1);opacity:1;}}
.bf-confirm-title{font-size:clamp(26px,4vw,38px);font-weight:900;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;letter-spacing:-.5px;margin-bottom:12px;}
.bf-confirm-desc{font-size:15px;color:var(--mid)!important;-webkit-text-fill-color:var(--mid)!important;line-height:1.7;margin-bottom:24px;}
.bf-confirm-ref-wrap{display:inline-block;background:var(--sf);border:1.5px solid var(--bd);border-radius:16px;padding:14px 28px;margin-bottom:24px;}
.bf-confirm-ref-lbl{font-size:11px;font-weight:700;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;}
.bf-confirm-ref-code code{font-size:22px;font-weight:900;color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;letter-spacing:2px;background:none;border:none;padding:0;}
.bf-confirm-qr-card{background:var(--w);border:1.5px solid var(--bd);border-radius:20px;padding:20px;margin:0 auto 24px;display:inline-block;box-shadow:var(--sh-md);}
.bf-confirm-qr-title{font-size:14px;font-weight:700;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:14px;}
.bf-confirm-hint{font-size:12px;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;margin-top:10px;}
.bf-confirm-next-steps{background:var(--sf);border:1px solid var(--bd);border-radius:18px;padding:20px 22px;margin:0 auto 28px;text-align:left;max-width:420px;}
.bf-confirm-steps-title{font-size:14px;font-weight:800;color:var(--ink)!important;-webkit-text-fill-color:var(--ink)!important;margin-bottom:16px;}
.bf-confirm-step-item{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.bf-confirm-step-item:last-child{margin-bottom:0;}
.bf-confirm-step-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.bf-confirm-step-text{font-size:13px;font-weight:600;color:var(--slate)!important;-webkit-text-fill-color:var(--slate)!important;}
.bf-confirm-btns{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;}
.bf-confirm-dash-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff!important;-webkit-text-fill-color:#fff!important;border-radius:14px;font-size:15px;font-weight:800;text-decoration:none;box-shadow:0 6px 20px rgba(26,86,219,.28);transition:all .22s;}
.bf-confirm-dash-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(26,86,219,.38);}
.bf-confirm-again-btn{padding:13px 24px;background:transparent;border:1.5px solid var(--bd);border-radius:14px;font-size:14px;font-weight:700;color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important;cursor:pointer;transition:all .2s;}
.bf-confirm-again-btn:hover{border-color:var(--blue);color:var(--blue)!important;-webkit-text-fill-color:var(--blue)!important;}
.bf-offline-confirm-note{background:#fffbeb;border:1.5px solid #f59e0b;border-radius:14px;padding:14px 18px;font-size:13px;font-weight:600;color:#92400e!important;-webkit-text-fill-color:#92400e!important;margin:0 auto 20px;max-width:420px;text-align:left;line-height:1.6;}

/* ════════════════════════════════════════════════════════
   PROGRAMME CARD — v2 fixes (image bigger, proper order)
   ════════════════════════════════════════════════════════ */

/* Taller image area */
#bf-programs-grid .bf-pc-img-wrap {
  height: 200px !important;
  border-radius: 16px 16px 0 0;
  overflow: hidden;
  background: #e0f2fe;
}
#bf-programs-grid .bf-pc-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}
#bf-programs-grid .bf-pc-img-fallback {
  height: 200px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#bf-programs-grid .bf-pc-fallback-emoji {
  font-size: 90px !important;
}

/* Body layout */
#bf-programs-grid .bf-pc-body {
  padding: 14px 16px 8px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: center !important;
  text-align: center !important;
}
#bf-programs-grid .bf-pc-name {
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  margin-bottom: 0 !important;
  order: 1 !important;
}

/* Age badge — sits directly below name */
#bf-programs-grid .bf-pc-age {
  order: 2 !important;
  display: flex !important;
  justify-content: center !important;
}
.bf-pc-age-badge {
  display: inline-block;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .4px !important;
  padding: 3px 12px !important;
  border-radius: 100px !important;
  background: rgba(0,0,0,.07) !important;
  color: inherit !important;
  -webkit-text-fill-color: inherit !important;
}

/* Focus description */
#bf-programs-grid .bf-pc-focus {
  order: 3 !important;
  font-size: 13px !important;
  color: var(--mid) !important;
  -webkit-text-fill-color: var(--mid) !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

/* Chips — wrap and center */
#bf-programs-grid .bf-pc-chips {
  order: 4 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: center !important;
  padding: 4px 0 !important;
}
#bf-programs-grid .bf-pc-chip {
  font-size: 11px !important;
  padding: 4px 12px !important;
  border-radius: 100px !important;
  background: rgba(0,0,0,.06) !important;
  border: 1px solid rgba(0,0,0,.09) !important;
  font-weight: 600 !important;
  color: var(--slate) !important;
  -webkit-text-fill-color: var(--slate) !important;
}

/* CTA button */
#bf-programs-grid .bf-pc-foot {
  padding: 0 14px 14px !important;
}
#bf-programs-grid .bf-pc-cta {
  height: 48px !important;
  font-size: 15px !important;
  border-radius: 14px !important;
  font-weight: 800 !important;
}

/* ════════════════════════════════════════════════════════
   LOCATION CARD — v2 fixes (full image, no white gap)
   ════════════════════════════════════════════════════════ */

/* Card: column layout, image fills top */
#bf-locs-grid .bf-lc {
  flex-direction: column !important;
}

/* Image: FULL height, no white space */
#bf-locs-grid .bf-lc-vis {
  height: 200px !important;
  width: 100% !important;
  flex-shrink: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  border-radius: 16px 16px 0 0 !important;
}
#bf-locs-grid .bf-lc-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}
#bf-locs-grid .bf-lc-img-fb {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 52px !important;
}

/* Body: clean stacked layout */
#bf-locs-grid .bf-lc-body {
  padding: 14px 16px 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  flex: 1 !important;
}
#bf-locs-grid .bf-lc-name {
  font-size: 15px !important;
  font-weight: 800 !important;
  color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
  line-height: 1.3 !important;
}
#bf-locs-grid .bf-lc-addr {
  font-size: 12px !important;
  color: var(--mid) !important;
  -webkit-text-fill-color: var(--mid) !important;
  line-height: 1.45 !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 4px !important;
}

/* Days chip — pill style */
.bf-lc-days-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 100px;
  padding: 3px 10px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--blue) !important;
  -webkit-text-fill-color: var(--blue) !important;
  width: fit-content;
}

/* Club note */
.bf-lc-club-note {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 100px;
  padding: 3px 10px;
  font-size: 11.5px;
  font-weight: 700;
  color: #c2410c !important;
  -webkit-text-fill-color: #c2410c !important;
  width: fit-content;
}

/* Footer row — map button sits at bottom */
.bf-lc-footer-row {
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--bd);
  display: flex;
  align-items: center;
}

/* Map button */
#bf-locs-grid .bf-lc-map-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--blue) !important;
  -webkit-text-fill-color: var(--blue) !important;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 100px;
  padding: 5px 14px;
  text-decoration: none;
  transition: all .18s;
}
#bf-locs-grid .bf-lc-map-btn:hover {
  background: var(--blue);
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  border-color: var(--blue);
}
