/* Booking Widget Styles – ballowlynde.com */

/* Container */
.booking-widget{max-width:640px;margin:0 auto}

/* Step indicator */
.booking-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px}
.booking-step{display:flex;align-items:center;gap:0}
.booking-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:'DM Sans',sans-serif;border:2px solid var(--border);color:var(--text-light);background:var(--white);transition:all .3s}
.booking-step-dot.active{border-color:var(--gold);background:var(--gold);color:var(--navy)}
.booking-step-dot.done{border-color:var(--navy);background:var(--navy);color:var(--cream)}
.booking-step-line{width:40px;height:2px;background:var(--border);transition:background .3s}
.booking-step-line.done{background:var(--navy)}
.booking-step-label{display:none}

/* Panels */
.booking-panel{display:none;animation:bookingFadeIn .25s ease-out}
.booking-panel.active{display:block}
@keyframes bookingFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Form fields */
.bf-group{margin-bottom:16px}
.bf-label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:4px}
.bf-required{color:#c45a3a}
.bf-input,.bf-select,.bf-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.9rem;background:var(--cream);color:var(--text);box-sizing:border-box;transition:border-color .2s}
.bf-input:focus,.bf-select:focus,.bf-textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px rgba(197,152,94,.15)}
.bf-textarea{resize:vertical;min-height:80px}
.bf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bf-error{font-size:12px;color:#c45a3a;margin-top:4px;display:none}
.bf-error.visible{display:block}

/* Date selector */
.booking-dates{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.booking-date-btn{padding:10px 16px;background:var(--white);border:1px solid var(--border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:500;color:var(--navy);cursor:pointer;transition:all .2s;text-align:center;min-width:90px}
.booking-date-btn:hover{border-color:var(--gold);background:rgba(197,152,94,.05)}
.booking-date-btn.selected{border-color:var(--gold);background:var(--gold);color:var(--navy);font-weight:700;box-shadow:0 0 0 2px var(--gold)}
.booking-date-btn .date-day{font-size:11px;color:var(--text-light);display:block;margin-bottom:2px}
.booking-date-btn.selected .date-day{color:var(--navy)}

/* Time slots */
.booking-time-section{margin-top:16px}
.booking-time-label{font-family:'Source Serif 4',serif;font-size:15px;font-weight:600;color:var(--navy);margin-bottom:10px}
.booking-times{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-bottom:16px}
.booking-time-btn{padding:10px 12px;background:var(--white);border:1px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:500;color:var(--navy);cursor:pointer;transition:all .2s;text-align:center}
.booking-time-btn:hover{border-color:var(--gold);background:rgba(197,152,94,.05)}
.booking-time-btn.selected{border-color:var(--gold);background:var(--gold);color:var(--navy);font-weight:700}

/* Review panel */
.booking-review{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:24px;margin-bottom:20px}
.booking-review-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.booking-review-row:last-child{border-bottom:none}
.booking-review-label{color:var(--text-light);font-weight:500}
.booking-review-value{color:var(--navy);font-weight:600;text-align:right;max-width:60%}
.booking-edit-link{font-size:12px;color:var(--gold);cursor:pointer;text-decoration:underline;margin-left:8px}
.booking-edit-link:hover{color:var(--navy)}

/* Confirmation */
.booking-confirmation{text-align:center;padding:32px 20px}
.booking-confirmation .check-icon{font-size:3rem;margin-bottom:16px}
.booking-confirmation h3{font-family:'Source Serif 4',serif;color:var(--navy);font-size:22px;margin:0 0 8px}
.booking-confirmation p{color:var(--text-light);margin:0 0 24px}
.booking-confirm-details{background:var(--cream);border-radius:8px;padding:20px;margin:20px auto;max-width:380px;text-align:left}
.booking-confirm-details .bcd-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem}
.booking-confirm-details .bcd-label{color:var(--text-light)}
.booking-confirm-details .bcd-value{color:var(--navy);font-weight:600}

/* Buttons */
.booking-btn{display:inline-block;padding:12px 32px;background:var(--gold);color:var(--navy);border:none;border-radius:6px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:1rem;cursor:pointer;transition:background .2s}
.booking-btn:hover{background:#b38a52}
.booking-btn:disabled{opacity:.5;cursor:not-allowed}
.booking-btn-outline{display:inline-block;padding:10px 24px;background:transparent;color:var(--navy);border:1.5px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}
.booking-btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.booking-nav{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:24px}

/* Loading state */
.booking-loading{text-align:center;padding:40px 20px}
.booking-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:bookingSpin .8s linear infinite;margin:0 auto 16px}
@keyframes bookingSpin{to{transform:rotate(360deg)}}
.booking-loading p{color:var(--text-light);font-size:.9rem}

/* Error state */
.booking-error{text-align:center;padding:32px 20px;background:rgba(192,57,43,.05);border:1px solid rgba(192,57,43,.2);border-radius:8px;margin:16px 0}
.booking-error p{color:#c0392b;margin:0 0 16px;font-size:.95rem}

/* No slots message */
.booking-no-slots{text-align:center;padding:24px;color:var(--text-light);font-size:.92rem}

/* Responsive */
@media(max-width:600px){
  .bf-row{grid-template-columns:1fr}
  .booking-dates{justify-content:center}
  .booking-times{grid-template-columns:repeat(2,1fr)}
  .booking-review-row{flex-direction:column;gap:4px}
  .booking-review-value{text-align:left;max-width:100%}
  .booking-nav{flex-direction:column}
  .booking-step-line{width:24px}
}

/* Schedule CTA button (used on other pages) */
.schedule-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--gold);color:var(--navy);border-radius:6px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.95rem;text-decoration:none;transition:background .2s}
.schedule-cta:hover{background:#b38a52;color:var(--navy);text-decoration:none}
.schedule-cta-icon{font-size:1.1rem}

/* Attorney notice */
.booking-notice{font-size:.82rem;color:var(--text-light);line-height:1.5;padding:12px 14px;border-left:2px solid var(--gold);margin-top:16px;background:rgba(197,152,94,.03)}
