/* BFS Booking Availability — Popup styles v1.8.6
   - Wider modal (680px desktop)
   - Larger calendar cells with bigger date numbers
   - Higher density without feeling cramped
   - Better readability across all sections
*/

/* Trigger button: gold bg, red hover, NO border */
.bfs-ba-trigger {
  display: inline-block !important;
  background: #C49047 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 12px 24px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  font-family: inherit;
  transition: background .2s;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none;
  text-decoration: none !important;
}
.bfs-ba-trigger:hover { background: #8D0400 !important; color: #fff !important; }
.bfs-ba-trigger:focus { outline: none !important; box-shadow: none !important; border: none !important; }
.bfs-ba-trigger-group { display: flex; flex-wrap: wrap; gap: 10px; }

.bfs-ba-overlay {
  display: none; position: fixed; inset: 0; background: var(--bfs-ba-overlay-bg, rgba(0,0,0,.55));
  z-index: 999999; align-items: center; justify-content: center;
  padding: 16px; box-sizing: border-box;
}
.bfs-ba-overlay.active { display: flex !important; }

.bfs-ba-popup {
  background: var(--bfs-ba-popup-bg, #fff) !important;
  border-radius: var(--bfs-ba-popup-radius, 16px);
  width: 100%;
  max-width: 680px;          /* ↑ from 480px */
  max-height: 92vh;
  overflow-y: auto;
  padding: 32px 36px;        /* ↑ from 24px */
  box-sizing: border-box;
  position: relative;
  font-family: var(--bfs-ba-font-family, inherit);
  color: var(--bfs-ba-popup-text, #111);
  box-shadow: 0 24px 64px rgba(0,0,0,.18);
}
.bfs-ba-close {
  position: absolute; top: 18px; right: 20px;
  background: none; border: none;
  font-size: 28px; cursor: pointer;
  color: #999; line-height: 1; padding: 4px 10px;
  border-radius: 8px;
  transition: all .15s;
}
.bfs-ba-close:hover { color: #111; background: #f3f4f6; }

.bfs-ba-loading, .bfs-ba-error {
  padding: 48px 20px; text-align: center; color: #888; font-size: 15px;
}
.bfs-ba-error { color: #dc2626; }

.bfs-ba-step { display: none; }
.bfs-ba-step.active { display: block; }

.bfs-ba-step-label {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #888;
  font-weight: 600;
  margin: 0 0 8px;
}
.bfs-ba-step-title {
  font-size: 26px;            /* ↑ from 22-28px range — settled at 26 */
  font-weight: 700;
  color: var(--bfs-ba-popup-text, #111);
  margin: 0 0 18px;
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.bfs-ba-sub {
  font-size: 14px; color: var(--bfs-ba-muted-text, #6b7280); margin: 0 0 16px;
}

.bfs-ba-progress { display: flex; gap: 7px; margin-bottom: 22px; }
.bfs-ba-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #e5e5e5;
  display: inline-block;
  transition: background .2s;
}
.bfs-ba-dot.active { background: var(--bfs-ba-accent, #25D366); }

.bfs-ba-back {
  background: none; border: none;
  font-size: 13px; color: #6b7280;
  cursor: pointer; margin-bottom: 16px; padding: 4px 0;
  font-family: inherit;
}
.bfs-ba-back:hover { color: #111; }


/* Step 0 package picker — only used by special hash triggers such as #pilih-paket */
.bfs-ba-package-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:18px 0 6px;
}
.bfs-ba-package-card{
  appearance:none;
  -webkit-appearance:none;
  text-align:left;
  background:#fff;
  border:1px solid var(--bfs-ba-border,#e5e7eb);
  border-radius:16px;
  padding:16px 18px;
  cursor:pointer;
  color:var(--bfs-ba-popup-text,#111);
  font-family:inherit;
  box-shadow:0 8px 20px rgba(17,24,39,.06);
  transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.bfs-ba-package-card:hover{
  transform:translateY(-1px);
  border-color:var(--bfs-ba-accent,#25D366);
  box-shadow:0 14px 28px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 18%, transparent);
}
.bfs-ba-package-card .bfs-ba-package-type{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  background:var(--bfs-ba-hover-bg,#f0fdf4);
  color:var(--bfs-ba-available,#128C4A);
  font-size:11px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:4px 8px;
  margin-bottom:10px;
}
.bfs-ba-package-card strong{
  display:block;
  font-size:18px;
  line-height:1.25;
  margin:0 0 5px;
}
.bfs-ba-package-card em{
  display:block;
  font-style:normal;
  color:var(--bfs-ba-muted-text,#6b7280);
  font-size:13px;
  margin-bottom:8px;
}
.bfs-ba-package-card small{
  display:block;
  color:var(--bfs-ba-muted-text,#6b7280);
  font-size:13px;
  line-height:1.35;
  min-height:18px;
  margin-bottom:10px;
}
.bfs-ba-package-card b{
  display:block;
  color:var(--bfs-ba-available,#047857);
  font-size:16px;
  margin-top:4px;
}
@media (max-width:900px){
  .bfs-ba-package-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:600px){
  .bfs-ba-package-grid{grid-template-columns:1fr;}
}



/* Step 2 makeup choice — visually matched to duration add-on cards */
.bfs-ba-makeup-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:10px;
  margin-bottom:18px;
}
.bfs-ba-makeup-choice{
  appearance:none;
  -webkit-appearance:none;
  border:1.5px solid #e5e5e5;
  border-radius:12px;
  background:#fff;
  color:var(--bfs-ba-popup-text,#111827);
  padding:14px 10px;
  min-height:82px;
  font-family:inherit;
  text-align:center;
  cursor:pointer;
  box-sizing:border-box;
  transition:all .15s;
}
.bfs-ba-makeup-choice:hover{
  background:#f9f9f9;
  border-color:var(--bfs-ba-notopen,#d1d5db);
}
.bfs-ba-makeup-choice.sel{
  border:2px solid var(--bfs-ba-accent,#9c27b0);
  background:var(--bfs-ba-selected-bg,#f0fdf4);
  box-shadow:none;
}
.bfs-ba-makeup-choice-title{
  display:block;
  font-size:14px;
  font-weight:600;
  color:#111;
  margin:0 0 4px;
}
.bfs-ba-makeup-choice-sub{
  display:block;
  font-size:12px;
  font-weight:600;
  line-height:1.35;
  color:#aaa;
  margin:0;
}
.bfs-ba-makeup-choice.sel .bfs-ba-makeup-choice-title{color:#111;}
.bfs-ba-makeup-choice.sel .bfs-ba-makeup-choice-sub{color:var(--bfs-ba-available,#25D366);}
@media (max-width:600px){
  .bfs-ba-makeup-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

/* ── Calendar — bigger and denser ──────────────────────────── */
.bfs-ba-cal-wrap {
  border: 1px solid var(--bfs-ba-border, #e5e5e5);
  border-radius: 14px;
  padding: 18px 20px;        /* ↑ from 14px */
  margin-bottom: 14px;
  box-sizing: border-box;
  background: #fff;
}
.bfs-ba-cal-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;        /* ↑ from 10px */
}
.bfs-ba-cal-nav button {
  background: #f5f5f5; border: 1px solid #e0e0e0; border-radius: 10px;
  padding: 8px 16px; cursor: pointer;
  font-size: 18px; font-weight: 700;
  color: #444; min-width: 40px; min-height: 40px;
  transition: all .15s;
}
.bfs-ba-cal-nav button:hover { background: #e8e8e8; color: #111; }
.bfs-ba-cal-nav button:disabled { opacity: 0.3; cursor: not-allowed; }
.bfs-ba-cal-month {
  font-size: 16px;            /* ↑ from 13px */
  font-weight: 700;
  color: #111;
  letter-spacing: -0.01em;
}

.bfs-ba-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.bfs-ba-cal-label {
  font-size: 11px;            /* small but readable */
  font-weight: 600;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  text-align: center;
  padding: 8px 0 6px;
}
.bfs-ba-cal-day {
  font-size: 16px;            /* ↑ from 12px — major bump for readability */
  font-weight: 500;
  text-align: center;
  padding: 12px 0;            /* taller cells */
  border-radius: 10px;
  color: #111;
  position: relative;
  line-height: 1.2;
  border: none;
  background: transparent;
  cursor: default;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .12s;
}
.bfs-ba-cal-day.avail {
  cursor: pointer;
  font-weight: 600;
  color: var(--bfs-ba-available, #166534);
}
.bfs-ba-cal-day.avail:hover {
  background: var(--bfs-ba-hover-bg,#dcfce7);
  transform: scale(1.04);
}
.bfs-ba-cal-day.sel {
  background: var(--bfs-ba-accent, #25D366) !important;
  color: var(--bfs-ba-accent-text, #fff) !important;
  font-weight: 700;
  box-shadow: 0 2px 8px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 35%, transparent);
}
/* Belum dibuka (past dates / out of booking window) — light grey, faded */
.bfs-ba-cal-day.empty,
.bfs-ba-cal-day.past { color: var(--bfs-ba-notopen, #d1d5db); }

/* Penuh (open day but all slots booked) — darker grey, more visible */
.bfs-ba-cal-day.noSlot {
  color: var(--bfs-ba-full, #6b7280);
  font-weight: 500;
  text-decoration: line-through;
  text-decoration-color: #9ca3af;
  text-decoration-thickness: 1.5px;
}

/* Tutup (Monday or holiday) — red */
.bfs-ba-cal-day.closed {
  color: var(--bfs-ba-closed, #ef4444);
  text-decoration: line-through;
  opacity: 0.65;
  font-weight: 600;
}
.bfs-ba-cal-day.mon-ex::after {
  content: '';
  position: absolute;
  bottom: 5px; left: 50%;
  transform: translateX(-50%);
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--bfs-ba-accent, #25D366);
}

/* ── Legend — more prominent ────────────────────────────── */
.bfs-ba-legend {
  display: flex;
  gap: 14px;
  margin-bottom: 14px;
  font-size: 12px;            /* ↑ from 11px */
  color: #4b5563;
  font-weight: 500;
  align-items: center;
  flex-wrap: wrap;
}
.bfs-ba-ldot {
  width: 9px; height: 9px;    /* ↑ from 7px */
  border-radius: 50%;
  display: inline-block;
  margin-right: 6px;
}

.bfs-ba-info {
  font-size: 13px;            /* ↑ from 11px */
  color: #4b5563;
  margin: 0 0 14px;
  padding: 10px 14px;
  background: #f9fafb;
  border-radius: 10px;
  border-left: 3px solid #d1d5db;
  line-height: 1.55;
}

/* ── Upsell ─────────────────────────────────────────── */
.bfs-ba-upsell-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.bfs-ba-upsell {
  border: 1.5px solid #e5e5e5;
  border-radius: 12px;
  padding: 14px 10px;         /* ↑ from 12px 8px */
  text-align: center;
  cursor: pointer;
  box-sizing: border-box;
  background: #fff;
  transition: all .15s;
}
.bfs-ba-upsell:hover {
  background: #f9f9f9;
  border-color: var(--bfs-ba-notopen, #d1d5db);
}
.bfs-ba-upsell.sel {
  border: 2px solid var(--bfs-ba-accent,#25D366);
  background: var(--bfs-ba-selected-bg,#f0fdf4);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 20%, transparent);
}
.bfs-ba-upsell.skip { border-style: dashed; }
.bfs-ba-upsell-label {
  font-size: 14px;             /* ↑ from 13px */
  font-weight: 600;
  color: #111; margin: 0 0 4px;
}
.bfs-ba-upsell-price {
  font-size: 12px;             /* ↑ from 11px */
  color: var(--bfs-ba-available,#25D366); font-weight: 600; margin: 0;
}
.bfs-ba-upsell-price.muted { color: #aaa; }

/* ── Slots — bigger touch targets ───────────────────── */
.bfs-ba-slot-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;                    /* ↑ from 6px */
  margin-bottom: 18px;
}
.bfs-ba-slot {
  border: 1.5px solid #e5e5e5;
  border-radius: 10px;
  padding: 10px 4px;           /* ↑ from 6px 3px */
  text-align: center;
  cursor: pointer;
  box-sizing: border-box;
  background: #fff;
  transition: all .12s;
}
.bfs-ba-slot.avail:hover {
  background: var(--bfs-ba-hover-bg,#f0fdf4);
  border-color: var(--bfs-ba-accent,#25D366);
}
.bfs-ba-slot.hov {
  background: var(--bfs-ba-hover-bg,#dcfce7);
  border-color: var(--bfs-ba-accent,#25D366);
}
.bfs-ba-slot.sel {
  border: 2px solid var(--bfs-ba-accent,#25D366);
  background: var(--bfs-ba-selected-bg,#f0fdf4);
  font-weight: 600;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 20%, transparent);
}
.bfs-ba-slot.terisi { background: #f5f5f5; cursor: not-allowed; }
.bfs-ba-slot.duration-blocked { background: #f9fafb; cursor: not-allowed; opacity: .72; }
.bfs-ba-slot.unavail { opacity: 0.35; cursor: default; }
.bfs-ba-slot-time {
  font-size: 13px;             /* ↑ from 11px */
  font-weight: 600;
  color: #111;
  display: block;
}
.bfs-ba-slot.terisi .bfs-ba-slot-time {
  color: #ccc; text-decoration: line-through;
}
.bfs-ba-slot.duration-blocked .bfs-ba-slot-time {
  color: #9ca3af; text-decoration: none;
}
.bfs-ba-slot-note {
  font-size: 10px;             /* ↑ from 9px */
  color: #9ca3af;
  line-height: 1.2;
  margin-top: 2px;
}

.bfs-ba-ot-banner {
  background: #fef3c7;
  color: #92400e;
  font-size: 13px;             /* ↑ from 11px */
  padding: 10px 14px;          /* ↑ from 6px 10px */
  border-radius: 10px;
  border-left: 3px solid #f59e0b;
  margin-bottom: 14px;
  font-weight: 500;
}

.bfs-ba-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}
.bfs-ba-pill {
  display: inline-block;
  background: var(--bfs-ba-hover-bg,#f0fdf4);
  border: 1px solid color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 28%, var(--bfs-ba-border,#e5e7eb));
  border-radius: 999px;
  padding: 5px 14px;            /* ↑ from 3px 10px */
  font-size: 13px;              /* ↑ from 11px */
  color: var(--bfs-ba-available, #166534);
  font-weight: 500;
}

/* ── Primary CTA — stronger presence ─────────────── */
.bfs-ba-btn {
  display: block;
  width: 100%;
  background: var(--bfs-ba-button-bg,#25D366);
  color: var(--bfs-ba-button-text,#fff);
  border: none;
  border-radius: 999px;
  padding: 16px;               /* ↑ from 12px */
  font-size: 14px;              /* ↑ from 13px */
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  box-sizing: border-box;
  margin-top: 8px;
  font-family: inherit;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 30%, transparent);
  transition: all .18s;
}
.bfs-ba-btn:hover {
  background: color-mix(in srgb, var(--bfs-ba-button-bg,#25D366) 86%, #000);
  color: var(--bfs-ba-button-text,#fff);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 40%, transparent);
}
.bfs-ba-btn:disabled {
  background: #e5e5e5;
  color: #aaa;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

/* ── Peserta field ─────────────────────────────── */
.bfs-ba-peserta-field {
  margin-bottom: 16px;
  padding: 14px 16px;           /* ↑ from 10px 12px */
  background: #f9fafb;
  border: 1px solid var(--bfs-ba-border, #e5e5e5);
  border-radius: 10px;
}
.bfs-ba-peserta-field label {
  font-size: 13px;              /* ↑ from 12px */
  font-weight: 600;
  color: #374151;
  display: block; margin-bottom: 8px;
}
.bfs-ba-optional { color: #9ca3af; font-weight: 400; }
.bfs-ba-peserta-field input {
  width: 100%; box-sizing: border-box;
  border: 1.5px solid #e5e5e5;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 15px;              /* ↑ from 14px */
  font-family: inherit;
  outline: none;
  transition: border-color .15s;
}
.bfs-ba-peserta-field input:focus {
  border-color: var(--bfs-ba-accent,#25D366);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 12%, transparent);
}
.bfs-ba-peserta-tip {
  font-size: 12px;              /* ↑ from 11px */
  color: #6b7280;
  margin: 6px 0 0;
}

/* ── Mobile responsive ──────────────────────────── */
@media (max-width: 700px) {
  .bfs-ba-popup {
    padding: 22px 20px;
    border-radius: 14px;
    max-width: 100%;
    max-height: 95vh;
  }
  .bfs-ba-step-title { font-size: 22px; }
  .bfs-ba-cal-wrap { padding: 14px 12px; }
  .bfs-ba-cal-day {
    font-size: 14px;
    padding: 10px 0;
    min-height: 38px;
  }
  .bfs-ba-cal-month { font-size: 15px; }
  .bfs-ba-slot-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .bfs-ba-upsell-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .bfs-ba-upsell { padding: 10px 6px; }
  .bfs-ba-info { font-size: 12px; padding: 8px 12px; }
  .bfs-ba-btn { padding: 14px; font-size: 13px; }
}


/* v1.8.6 Popup style variables */
.bfs-ba-ldot-available { background: var(--bfs-ba-available, #25D366); }
.bfs-ba-ldot-full { background: var(--bfs-ba-full, #6b7280); }
.bfs-ba-ldot-closed { background: var(--bfs-ba-closed, #ef4444); }
.bfs-ba-ldot-notopen { background: var(--bfs-ba-notopen, #e5e5e5); }
.bfs-ba-popup h4,
.bfs-ba-popup label,
.bfs-ba-cal-month,
.bfs-ba-slot-time { color: var(--bfs-ba-popup-text, #111); }
.bfs-ba-info,
.bfs-ba-step-label,
.bfs-ba-back,
.bfs-ba-peserta-tip,
.bfs-ba-optional { color: var(--bfs-ba-muted-text, #6b7280); }
.bfs-ba-btn {
  background: var(--bfs-ba-button-bg, #25D366) !important;
  color: var(--bfs-ba-button-text, #fff) !important;
}
.bfs-ba-btn:disabled {
  background: #d1d5db !important;
  color: #ffffff !important;
}
.bfs-ba-slot.avail,
.bfs-ba-upsell.sel,
.bfs-ba-makeup-choice.sel,
.bfs-ba-slot.sel,
.bfs-ba-slot.hov { border-color: var(--bfs-ba-accent, #25D366); }

/* v1.9.9 — Overtime request gate in Step 3 */
.bfs-ba-late-card {
  margin: -4px 0 18px;
  padding: 14px;
  border: 1.5px solid #f59e0b;
  border-radius: 14px;
  background: #fffbeb;
  color: #78350f;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, 30%);
  gap: 14px;
  align-items: center;
}
.bfs-ba-late-copy strong {
  display:block;
  font-size: 14px;
  color: #78350f;
  margin-bottom: 4px;
}
.bfs-ba-late-copy p {
  margin: 0 0 8px;
  font-size: 13px;
  line-height: 1.5;
  color: #92400e;
}
.bfs-ba-late-copy small {
  display:block;
  font-size: 12px;
  color: #92400e;
  margin-bottom: 0;
  line-height: 1.45;
}
.bfs-ba-late-btn {
  width: 100%;
  border: 0;
  border-radius: 999px;
  background: #92400e;
  color: #fff;
  padding: 12px 14px;
  font-weight: 800;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: .03em;
  white-space: nowrap;
}
.bfs-ba-late-btn:hover { background:#78350f; color:#fff; }
@media(max-width:640px){
  .bfs-ba-late-card{grid-template-columns:1fr;}
  .bfs-ba-late-btn{white-space:normal;}
}
.bfs-ba-slot.overtime {
  border-color: #f59e0b;
  background: #fff7ed;
}
.bfs-ba-slot.overtime:hover,
.bfs-ba-slot.overtime.hov,
.bfs-ba-slot.overtime.sel {
  border-color: #f59e0b;
  background: #ffedd5;
  box-shadow: 0 2px 8px rgba(245,158,11,.22);
}
.bfs-ba-slot.overtime .bfs-ba-slot-time { color:#9a3412; }
.bfs-ba-slot-note.overtime-note { color:#b45309; font-weight:700; }

.bfs-ba-slot.late-locked {
  background:#f9fafb;
  border-color:var(--bfs-ba-slot-border,var(--bfs-ba-border,#e5e7eb));
  color:#9ca3af;
  cursor:not-allowed;
}
.bfs-ba-slot.late-locked .bfs-ba-slot-time {
  color:#9ca3af;
}
.bfs-ba-slot-note.late-locked-note {
  color:#9ca3af;
  font-weight:600;
}
.bfs-ba-slot-section-label,
.bfs-ba-slot-empty-note {
  grid-column: 1 / -1;
  border: 1px dashed #f59e0b;
  border-radius: 12px;
  background: #fffbeb;
  color: #92400e;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}
.bfs-ba-slot-empty-note {
  border-color:#e5e7eb;
  background:#f9fafb;
  color:#4b5563;
  font-weight:600;
}

/* v2.2.5 client qualification popup */
.bfs-ba-qualification-card{border:1px solid var(--bfs-ba-border,#e5e7eb);border-radius:14px;padding:12px 14px;margin:0 0 12px;background:#fff}
.bfs-ba-qualification-card.is-locked{background:#f3f4f6;color:#6b7280}
.bfs-ba-field-label,.bfs-ba-client-contact label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin:0 0 6px;color:var(--bfs-ba-muted,#6b7280)}
.bfs-ba-select,.bfs-ba-qualification-card input,.bfs-ba-client-contact input{width:100%;border:1px solid var(--bfs-ba-border,#e5e7eb);border-radius:10px;padding:10px 12px;background:#fff;color:var(--bfs-ba-text,#111);box-sizing:border-box}
.bfs-ba-locked-note,.bfs-ba-mini-note{font-size:12px;line-height:1.4;color:var(--bfs-ba-muted,#6b7280);margin:7px 0 0}
.bfs-ba-step-title-small{font-size:16px!important;margin-top:16px!important}
.bfs-ba-client-contact{border:1px dashed var(--bfs-ba-border,#e5e7eb);border-radius:14px;padding:12px;margin:14px 0;background:#fafafa}
.bfs-ba-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bfs-ba-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.bfs-ba-btn-secondary{background:#fff!important;color:var(--bfs-ba-button-bg,#25D366)!important;border:1px solid var(--bfs-ba-button-bg,#25D366)!important}
@media(max-width:640px){.bfs-ba-contact-grid,.bfs-ba-cta-grid{grid-template-columns:1fr}}


/* v2.2.29 — Hard override makeup cards so theme/button CSS cannot turn them red.
   Matches duration add-on cards: neutral by default, accent border only when selected. */
#bfs-ba-popup #bfs-ba-makeup-options.bfs-ba-makeup-choice-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:12px !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice:hover,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice:focus,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice:active{
  appearance:none !important;
  -webkit-appearance:none !important;
  display:block !important;
  width:100% !important;
  min-height:80px !important;
  padding:14px 10px !important;
  border:1.5px solid #e5e5e5 !important;
  border-radius:12px !important;
  background:#ffffff !important;
  background-color:#ffffff !important;
  color:var(--bfs-ba-popup-text,#111827) !important;
  font-family:inherit !important;
  text-align:center !important;
  box-shadow:none !important;
  outline:none !important;
  text-transform:none !important;
  letter-spacing:normal !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice:hover{
  background:var(--bfs-ba-hover-bg,#fafafa) !important;
  background-color:var(--bfs-ba-hover-bg,#fafafa) !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice.sel,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice.sel:hover,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice.sel:focus,
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice.sel:active{
  border:2px solid var(--bfs-ba-accent,#9c27b0) !important;
  background:var(--bfs-ba-selected-bg,#f0fdf4) !important;
  background-color:var(--bfs-ba-selected-bg,#f0fdf4) !important;
  box-shadow:none !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice-title{
  display:block !important;
  margin:0 0 4px !important;
  color:#111827 !important;
  font-size:14px !important;
  font-weight:700 !important;
  line-height:1.25 !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice-sub{
  display:block !important;
  margin:0 !important;
  color:#9ca3af !important;
  font-size:12px !important;
  font-weight:600 !important;
  line-height:1.35 !important;
}
#bfs-ba-popup #bfs-ba-makeup-options .bfs-ba-makeup-choice.sel .bfs-ba-makeup-choice-sub{
  color:var(--bfs-ba-available,#22c55e) !important;
}
@media (max-width:600px){
  #bfs-ba-popup #bfs-ba-makeup-options.bfs-ba-makeup-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}


/* v2.2.31 — Step 2 cleaner single-card layout + configurable default time-slot border */
#bfs-ba-popup .bfs-ba-session-card{
  padding:14px 16px !important;
}
#bfs-ba-popup .bfs-ba-session-soft-area{
  border:1px solid var(--bfs-ba-border,#e5e7eb);
  background:var(--bfs-ba-hover-bg,#f8fafc);
  border-radius:12px;
  padding:12px;
}
#bfs-ba-popup #bfs-ba-session-select.bfs-ba-select{
  background:#fff !important;
  border-color:var(--bfs-ba-border,#e5e7eb) !important;
  margin:0 !important;
}
#bfs-ba-popup .bfs-ba-people-inline{
  margin-top:12px;
  padding-top:12px;
  border-top:1px dashed color-mix(in srgb, var(--bfs-ba-border,#e5e7eb) 80%, transparent);
}
#bfs-ba-popup .bfs-ba-people-inline .bfs-ba-field-label{
  margin-bottom:6px !important;
}
#bfs-ba-popup .bfs-ba-people-inline input{
  background:#fff !important;
  border-color:var(--bfs-ba-border,#e5e7eb) !important;
}
#bfs-ba-popup .bfs-ba-slot,
#bfs-ba-popup .bfs-ba-slot.avail{
  border-color:var(--bfs-ba-slot-border,var(--bfs-ba-border,#e5e7eb)) !important;
}
#bfs-ba-popup .bfs-ba-slot.avail:hover,
#bfs-ba-popup .bfs-ba-slot.hov{
  border-color:var(--bfs-ba-accent,#25D366) !important;
  background:var(--bfs-ba-hover-bg,#f0fdf4) !important;
}
#bfs-ba-popup .bfs-ba-slot.sel{
  border-color:var(--bfs-ba-accent,#25D366) !important;
  background:var(--bfs-ba-selected-bg,#f0fdf4) !important;
}

/* v2.2.37 — duration-blocked slots stay grey without false Terisi label */
#bfs-ba-popup .bfs-ba-slot.duration-blocked{
  background:#f9fafb !important;
  border-color:var(--bfs-ba-slot-border,var(--bfs-ba-border,#e5e7eb)) !important;
  cursor:not-allowed !important;
  opacity:.78;
}
#bfs-ba-popup .bfs-ba-slot.duration-blocked .bfs-ba-slot-time{
  color:#9ca3af !important;
  text-decoration:none !important;
}
#bfs-ba-popup .bfs-ba-slot.duration-blocked.hov,
#bfs-ba-popup .bfs-ba-slot.duration-blocked.sel,
#bfs-ba-popup .bfs-ba-slot.terisi.hov,
#bfs-ba-popup .bfs-ba-slot.terisi.sel{
  opacity:1;
  border-color:var(--bfs-ba-accent,#25D366) !important;
  background:var(--bfs-ba-selected-bg,#f0fdf4) !important;
  box-shadow:0 2px 8px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 20%, transparent) !important;
}
#bfs-ba-popup .bfs-ba-slot.duration-blocked.hov .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.duration-blocked.sel .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.terisi.hov .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.terisi.sel .bfs-ba-slot-time{
  color:var(--bfs-ba-popup-text,#111) !important;
  text-decoration:none !important;
}
#bfs-ba-popup .bfs-ba-slot.terisi.hov .bfs-ba-slot-note,
#bfs-ba-popup .bfs-ba-slot.terisi.sel .bfs-ba-slot-note{
  display:none !important;
}


/* v2.2.33 — regular clock visibility + compact late-session gate */
#bfs-ba-popup .bfs-ba-late-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(150px,30%);
  gap:14px;
  align-items:center;
}
#bfs-ba-popup .bfs-ba-late-copy small{margin-bottom:0;line-height:1.45;}
#bfs-ba-popup .bfs-ba-late-btn{width:100%;white-space:nowrap;}
#bfs-ba-popup .bfs-ba-slot.late-locked{
  background:#f9fafb !important;
  border-color:var(--bfs-ba-slot-border,var(--bfs-ba-border,#e5e7eb)) !important;
  cursor:not-allowed !important;
}
#bfs-ba-popup .bfs-ba-slot.late-locked .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot-note.late-locked-note{color:#9ca3af !important;}
#bfs-ba-popup .bfs-ba-slot.overtime{
  border-color:#f59e0b !important;
  background:#fff7ed !important;
}
#bfs-ba-popup .bfs-ba-slot.overtime:hover,
#bfs-ba-popup .bfs-ba-slot.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.overtime.sel{
  border-color:#f59e0b !important;
  background:#ffedd5 !important;
  box-shadow:0 2px 8px rgba(245,158,11,.22) !important;
}
@media(max-width:640px){
  #bfs-ba-popup .bfs-ba-late-card{grid-template-columns:1fr;}
  #bfs-ba-popup .bfs-ba-late-btn{white-space:normal;}
}


/* v2.2.34 — overtime edge slots: no label before approval; selectable after approval */
#bfs-ba-popup .bfs-ba-slot.late-locked .bfs-ba-slot-note.late-locked-note{display:none!important;}
#bfs-ba-popup .bfs-ba-slot.late-locked{min-height:48px!important;}
#bfs-ba-popup .bfs-ba-slot.overtime{cursor:pointer!important;}

/* v2.2.35 — one-row chronological overtime grid + bottom-only overtime fee note */
#bfs-ba-popup .bfs-ba-slot-overtime-note-bottom{
  grid-column:1 / -1;
  margin-top:4px;
  border:1px solid #d97706;
  border-radius:12px;
  background:#fde68a;
  color:#78350f;
  padding:10px 12px;
  font-size:12px;
  font-weight:800;
  text-align:center;
}

/* v2.2.36 — rounded block-preview markers + compact popup buttons */
#bfs-ba-popup .bfs-ba-slot.preview-marker{
  background:#ffffff !important;
  border-color:var(--bfs-ba-slot-border,var(--bfs-ba-border,#e5e7eb)) !important;
  opacity:.72;
  cursor:default !important;
}
#bfs-ba-popup .bfs-ba-slot.preview-marker .bfs-ba-slot-time{
  color:var(--bfs-ba-muted-text,#6b7280) !important;
}
#bfs-ba-popup .bfs-ba-slot.preview-marker.hov,
#bfs-ba-popup .bfs-ba-slot.preview-marker.sel{
  opacity:1;
  border-color:var(--bfs-ba-accent,#25D366) !important;
  background:var(--bfs-ba-selected-bg,#f0fdf4) !important;
  box-shadow:0 2px 8px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 20%, transparent) !important;
}
#bfs-ba-popup .bfs-ba-slot.preview-marker.hov .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.preview-marker.sel .bfs-ba-slot-time{
  color:var(--bfs-ba-popup-text,#111) !important;
}

#bfs-ba-popup .bfs-ba-slot.late-locked.hov,
#bfs-ba-popup .bfs-ba-slot.late-locked.sel{
  opacity:1;
  border-color:var(--bfs-ba-accent,#25D366) !important;
  background:var(--bfs-ba-selected-bg,#f0fdf4) !important;
  box-shadow:0 2px 8px color-mix(in srgb, var(--bfs-ba-shadow-color,#25D366) 20%, transparent) !important;
}
#bfs-ba-popup .bfs-ba-slot.late-locked.hov .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.late-locked.sel .bfs-ba-slot-time{
  color:var(--bfs-ba-popup-text,#111) !important;
}

#bfs-ba-popup .bfs-ba-slot.preview-marker.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.preview-marker.overtime.sel{
  border-color:#f59e0b !important;
  background:#ffedd5 !important;
  box-shadow:0 2px 8px rgba(245,158,11,.22) !important;
}

#bfs-ba-popup .bfs-ba-btn,
#bfs-ba-popup .bfs-ba-late-btn{
  border-radius:15px !important;
  font-size:12px !important;
  padding:12px 14px !important;
  letter-spacing:.08em !important;
  line-height:1.25 !important;
}
#bfs-ba-popup .bfs-ba-cta-grid .bfs-ba-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  min-height:44px !important;
}
#bfs-ba-popup #bfs-ba-btn3:not(:disabled){
  background:#25D366 !important;
  color:#ffffff !important;
  border:0 !important;
  box-shadow:0 4px 12px rgba(37,211,102,.30) !important;
}
#bfs-ba-popup #bfs-ba-btn3:not(:disabled):hover{
  background:#1ebe5d !important;
  color:#ffffff !important;
  box-shadow:0 6px 16px rgba(37,211,102,.38) !important;
}
#bfs-ba-popup #bfs-ba-btn3:not(:disabled)::before{
  content:"";
  display:inline-block;
  width:16px;
  height:16px;
  flex:0 0 16px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath fill='%23fff' d='M16.04 4C9.4 4 4 9.36 4 15.95c0 2.1.56 4.16 1.62 5.97L4 28l6.25-1.6a12.1 12.1 0 0 0 5.78 1.47h.01C22.68 27.87 28 22.5 28 15.91 28 9.34 22.68 4 16.04 4Zm.01 21.84h-.01a10.03 10.03 0 0 1-5.1-1.39l-.37-.22-3.7.95.99-3.58-.24-.37a9.83 9.83 0 0 1-1.53-5.28c0-5.46 4.47-9.9 9.96-9.9 2.66 0 5.16 1.03 7.04 2.9A9.82 9.82 0 0 1 26 15.91c0 5.48-4.46 9.93-9.95 9.93Zm5.46-7.43c-.3-.15-1.77-.87-2.04-.97-.27-.1-.47-.15-.67.15-.2.29-.77.96-.94 1.15-.17.2-.35.22-.64.08-.3-.15-1.25-.46-2.38-1.46a8.9 8.9 0 0 1-1.65-2.04c-.17-.3-.02-.46.13-.6.13-.13.3-.34.45-.51.15-.17.2-.29.3-.49.1-.2.05-.37-.03-.52-.07-.15-.67-1.6-.91-2.2-.24-.58-.49-.5-.67-.51h-.57c-.2 0-.52.07-.79.37-.27.29-1.04 1-1.04 2.46 0 1.45 1.07 2.85 1.22 3.05.15.2 2.1 3.18 5.08 4.46.71.3 1.26.48 1.7.62.71.22 1.36.19 1.87.12.57-.09 1.77-.72 2.02-1.41.25-.7.25-1.3.17-1.42-.07-.12-.27-.2-.57-.35Z'/%3E%3C/svg%3E") !important;
}

/* v2.2.38 — overtime UI markers + compact Step 2 */
#bfs-ba-popup .bfs-ba-slot.overtime{
  border-color:#f59e0b !important;
  background:#fff7ed !important;
}
#bfs-ba-popup .bfs-ba-slot.overtime .bfs-ba-slot-time{
  color:#9a3412 !important;
}
#bfs-ba-popup .bfs-ba-slot.overtime:hover,
#bfs-ba-popup .bfs-ba-slot.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.overtime.sel,
#bfs-ba-popup .bfs-ba-slot.preview-marker.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.preview-marker.overtime.sel,
#bfs-ba-popup .bfs-ba-slot.duration-blocked.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.duration-blocked.overtime.sel,
#bfs-ba-popup .bfs-ba-slot.terisi.overtime.hov,
#bfs-ba-popup .bfs-ba-slot.terisi.overtime.sel{
  border-color:#d97706 !important;
  background:#fde68a !important;
  box-shadow:0 2px 9px rgba(217,119,6,.26) !important;
}
#bfs-ba-popup .bfs-ba-slot.overtime:hover .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.overtime.hov .bfs-ba-slot-time,
#bfs-ba-popup .bfs-ba-slot.overtime.sel .bfs-ba-slot-time{
  color:#78350f !important;
  text-decoration:none !important;
}
#bfs-ba-popup .bfs-ba-slot.terisi.overtime .bfs-ba-slot-note{
  color:#92400e !important;
}
#bfs-ba-popup .bfs-ba-slot.terisi.overtime:not(.hov):not(.sel) .bfs-ba-slot-time{
  text-decoration:line-through !important;
}
#bfs-ba-popup .bfs-ba-step2-compact-grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:10px;
  margin:0 0 10px;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-step-title{
  margin-bottom:10px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-qualification-card{
  margin:0 !important;
  padding:10px 12px !important;
  border-radius:12px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-session-soft-area{
  border:0 !important;
  background:transparent !important;
  padding:0 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-mini-note{
  display:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-field-label{
  margin-bottom:6px !important;
  font-size:11px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-session-select.bfs-ba-select{
  padding:9px 10px !important;
  border-radius:10px !important;
  min-height:40px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-makeup-choice-grid{
  gap:7px !important;
  margin:0 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-makeup-choice{
  padding:9px 8px !important;
  border-radius:11px !important;
  min-height:0 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-makeup-choice-title{
  font-size:13px !important;
  margin-bottom:2px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-makeup-choice-sub{
  font-size:11px !important;
  line-height:1.25 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-step-title-small{
  margin-top:8px !important;
  margin-bottom:5px !important;
  font-size:15px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-upsell-sub{
  margin:0 0 8px !important;
  font-size:12px !important;
  line-height:1.35 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-upsell-grid{
  gap:7px !important;
  margin-bottom:12px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-upsell{
  padding:9px 7px !important;
  border-radius:11px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-upsell-label{
  font-size:13px !important;
  margin-bottom:2px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] .bfs-ba-upsell-price{
  font-size:11px !important;
}
@media(max-width:640px){
  #bfs-ba-popup .bfs-ba-step2-compact-grid{
    grid-template-columns:1fr;
  }
}


/* v2.2.39 — compact and friendlier Step 3 */
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-back{
  margin-bottom:8px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-step-label{
  margin-bottom:4px !important;
  font-size:10px !important;
  letter-spacing:.12em !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-step-title{
  font-size:22px !important;
  line-height:1.18 !important;
  margin:0 0 5px !important;
}
#bfs-ba-popup .bfs-ba-step3-sub{
  margin:0 0 9px !important;
  font-size:12px !important;
  line-height:1.35 !important;
  color:var(--bfs-ba-muted-text,#6b7280) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-pills{
  gap:6px !important;
  margin-bottom:10px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-pill{
  padding:4px 10px !important;
  font-size:12px !important;
  line-height:1.25 !important;
}
/* v2.2.40 — Step 3 grid: keep time bubbles visually balanced at 5 columns */
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-grid{
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:6px !important;
  margin-bottom:10px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot{
  min-height:42px !important;
  padding:7px 3px !important;
  border-radius:9px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-time{
  font-size:12px !important;
  line-height:1.15 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-note{
  font-size:9px !important;
  line-height:1.1 !important;
  margin-top:1px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-overtime-note-bottom{
  padding:8px 10px !important;
  font-size:11px !important;
  line-height:1.3 !important;
  margin-top:0 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-late-card{
  margin:0 0 10px !important;
  padding:10px 12px !important;
  border-radius:12px !important;
  gap:10px !important;
  grid-template-columns:minmax(0,1fr) minmax(128px,auto) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-late-copy strong{
  font-size:13px !important;
  margin-bottom:2px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-late-copy small{
  font-size:11px !important;
  line-height:1.3 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-late-btn{
  padding:10px 12px !important;
  font-size:12px !important;
  border-radius:15px !important;
  letter-spacing:.02em !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-cta-grid{
  gap:8px !important;
  margin-top:8px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-cta-grid .bfs-ba-btn{
  margin-top:0 !important;
  padding:12px 10px !important;
  font-size:11px !important;
  letter-spacing:.06em !important;
}
@media(max-width:700px){
  #bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-late-card{
    grid-template-columns:1fr !important;
  }
}
@media(max-width:380px){
  #bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}


/* v2.2.41 — overtime fee note follows active yellow overtime color */
#bfs-ba-popup .bfs-ba-step[data-step="3"] .bfs-ba-slot-overtime-note-bottom{
  border-color:#d97706 !important;
  background:#fde68a !important;
  color:#78350f !important;
  box-shadow:0 2px 9px rgba(217,119,6,.18) !important;
}


/* v2.2.42 — Step 2 purpose dropdown gets a soft red answer cue only on the dropdown */
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-session-select.bfs-ba-select{
  background-color:#fff1f2 !important;
  border-color:#fecdd3 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-session-select.bfs-ba-select:hover,
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-session-select.bfs-ba-select:focus{
  background-color:#ffe4e6 !important;
  border-color:var(--bfs-ba-accent,#dc3239) !important;
  outline:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="2"] #bfs-ba-session-select.bfs-ba-select option{
  background-color:#fff1f2;
  color:var(--bfs-ba-popup-text,#111827);
}


/* v2.2.44 — Step 4 contact form: one-column, eye-catching, client-friendly */
#bfs-ba-popup .bfs-ba-client-contact{
  border:1px solid rgba(220,50,57,.24);
  border-radius:18px;
  padding:14px;
  margin:14px 0 16px;
  background:linear-gradient(180deg,rgba(255,241,242,.95),rgba(255,255,255,.98));
  box-shadow:0 10px 26px rgba(17,24,39,.07);
}
#bfs-ba-popup .bfs-ba-contact-intro{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin:0 0 12px;
  padding:10px 12px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(220,50,57,.14);
}
#bfs-ba-popup .bfs-ba-contact-intro strong{
  font-size:14px;
  line-height:1.25;
  color:var(--bfs-ba-text,#111827);
}
#bfs-ba-popup .bfs-ba-contact-intro span{
  font-size:12px;
  line-height:1.45;
  color:var(--bfs-ba-muted,#6b7280);
}
#bfs-ba-popup .bfs-ba-contact-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:11px !important;
}
#bfs-ba-popup .bfs-ba-client-contact label{
  color:#991b1b;
  font-size:11px;
  letter-spacing:.055em;
}
#bfs-ba-popup .bfs-ba-client-contact input,
#bfs-ba-popup .bfs-ba-client-contact textarea{
  width:100%;
  border:1px solid rgba(220,50,57,.18);
  border-radius:13px;
  padding:11px 13px;
  background:#fff;
  color:var(--bfs-ba-text,#111827);
  box-sizing:border-box;
  outline:none;
  font-size:14px;
}
#bfs-ba-popup .bfs-ba-client-contact textarea{
  min-height:118px;
  resize:vertical;
  line-height:1.45;
}
#bfs-ba-popup .bfs-ba-client-contact input:focus,
#bfs-ba-popup .bfs-ba-client-contact textarea:focus{
  border-color:rgba(220,50,57,.75);
  box-shadow:0 0 0 3px rgba(220,50,57,.12);
}
#bfs-ba-popup .bfs-ba-client-contact input::placeholder,
#bfs-ba-popup .bfs-ba-client-contact textarea::placeholder{
  color:#9ca3af;
}


/* v2.2.45 — livelier client calendar + cleaner final lead button */
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-step-title{
  margin-bottom:16px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-legend{
  gap:8px !important;
  margin-bottom:12px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-legend span{
  display:inline-flex !important;
  align-items:center !important;
  padding:6px 10px !important;
  border-radius:999px !important;
  background:#ffffff !important;
  border:1px solid rgba(148,163,184,.18) !important;
  box-shadow:0 4px 12px rgba(15,23,42,.045) !important;
  color:#374151 !important;
  line-height:1 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-wrap{
  position:relative !important;
  overflow:hidden !important;
  border:1px solid rgba(220,50,57,.16) !important;
  border-radius:20px !important;
  padding:18px 20px 20px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(220,50,57,.10), transparent 30%),
    radial-gradient(circle at 95% 18%, rgba(196,144,71,.14), transparent 34%),
    linear-gradient(180deg,#ffffff 0%,#fff7f7 100%) !important;
  box-shadow:0 16px 36px rgba(15,23,42,.08) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav{
  position:relative !important;
  z-index:1 !important;
  margin-bottom:16px !important;
  padding:8px !important;
  border-radius:17px !important;
  background:rgba(255,255,255,.78) !important;
  border:1px solid rgba(255,255,255,.84) !important;
  box-shadow:0 8px 22px rgba(15,23,42,.055) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav button{
  width:40px !important;
  min-width:40px !important;
  height:40px !important;
  min-height:40px !important;
  padding:0 !important;
  border-radius:14px !important;
  border:1px solid rgba(148,163,184,.20) !important;
  background:#ffffff !important;
  color:#111827 !important;
  box-shadow:0 4px 10px rgba(15,23,42,.06) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav button:hover:not(:disabled){
  background:var(--bfs-ba-accent,#dc3239) !important;
  border-color:var(--bfs-ba-accent,#dc3239) !important;
  color:#ffffff !important;
  transform:translateY(-1px) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav button:disabled{
  background:#f3f4f6 !important;
  color:#cbd5e1 !important;
  box-shadow:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-month{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:40px !important;
  padding:0 18px !important;
  border-radius:999px !important;
  background:#fff1f2 !important;
  color:#111827 !important;
  border:1px solid rgba(220,50,57,.12) !important;
  font-size:16px !important;
  letter-spacing:.01em !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-grid{
  position:relative !important;
  z-index:1 !important;
  gap:5px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-label{
  color:#9ca3af !important;
  font-size:10px !important;
  font-weight:800 !important;
  letter-spacing:.08em !important;
  padding:7px 0 6px !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day{
  min-height:43px !important;
  padding:8px 0 !important;
  border-radius:13px !important;
  border:1px solid rgba(148,163,184,.14) !important;
  background:rgba(255,255,255,.82) !important;
  box-shadow:0 3px 10px rgba(15,23,42,.035) !important;
  font-weight:750 !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.empty{
  background:transparent !important;
  border-color:transparent !important;
  box-shadow:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.past{
  background:rgba(255,255,255,.35) !important;
  border-color:transparent !important;
  box-shadow:none !important;
  color:#d1d5db !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.avail{
  background:#f0fdf4 !important;
  border-color:#bbf7d0 !important;
  color:#14532d !important;
  cursor:pointer !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.avail::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:6px;
  transform:translateX(-50%);
  width:5px;
  height:5px;
  border-radius:999px;
  background:#22c55e;
  opacity:.88;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.avail:hover{
  background:#dcfce7 !important;
  border-color:#22c55e !important;
  transform:translateY(-1px) scale(1.02) !important;
  box-shadow:0 8px 18px rgba(34,197,94,.16) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.sel,
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.sel:hover{
  background:var(--bfs-ba-accent,#dc3239) !important;
  border-color:var(--bfs-ba-accent,#dc3239) !important;
  color:#ffffff !important;
  transform:none !important;
  box-shadow:0 10px 22px rgba(220,50,57,.24) !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.sel::after{
  background:#ffffff !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.noSlot{
  background:#f3f4f6 !important;
  border-color:#e5e7eb !important;
  color:#6b7280 !important;
  text-decoration:line-through !important;
  text-decoration-color:#9ca3af !important;
  box-shadow:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day.closed{
  background:#fff1f2 !important;
  border-color:#fecdd3 !important;
  color:#ef4444 !important;
  opacity:1 !important;
  box-shadow:none !important;
}
#bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-info{
  border:1px solid rgba(148,163,184,.16) !important;
  border-left:0 !important;
  border-radius:14px !important;
  background:linear-gradient(180deg,#ffffff,#f9fafb) !important;
  color:#374151 !important;
  box-shadow:0 6px 18px rgba(15,23,42,.045) !important;
}
@media(max-width:700px){
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-wrap{
    padding:14px 12px 16px !important;
    border-radius:17px !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav{
    padding:6px !important;
    border-radius:15px !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-month{
    min-height:36px !important;
    padding:0 12px !important;
    font-size:14px !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-nav button{
    width:36px !important;
    min-width:36px !important;
    height:36px !important;
    min-height:36px !important;
    border-radius:12px !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-cal-day{
    min-height:38px !important;
    border-radius:11px !important;
    font-size:14px !important;
  }
  #bfs-ba-popup .bfs-ba-step[data-step="1"] .bfs-ba-legend span{
    padding:5px 8px !important;
    font-size:11px !important;
  }
}
