/* ═══════════════════════════════════════════
   Beauty by Belén — Booking Widget Styles
   Uses site's CSS variables (--teal, --font-display, etc.)
   ═══════════════════════════════════════════ */

/* ── Overlay ── */
.bw-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 10000;
  opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.bw-overlay.bw-visible { opacity: 1; pointer-events: auto; }

/* ── Modal ── */
.bw-modal {
  position: fixed; top: 0; right: -100%; width: 100%; max-width: 520px; height: 100%; height: 100dvh;
  background: var(--warm-white, #FEFCFA); z-index: 10001;
  display: flex; flex-direction: column;
  transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: -8px 0 40px rgba(0,0,0,0.12);
}
.bw-modal.bw-visible { right: 0; }

/* ── Header ── */
.bw-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--border-light, #F0EBE5);
  background: var(--white, #fff); flex-shrink: 0;
}
.bw-title {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.4rem; font-weight: 600; color: var(--charcoal, #2C2C2C); margin: 0;
}
.bw-close {
  width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-size: 1.5rem; color: var(--text-soft, #6B6B6B);
  transition: all 0.2s; cursor: pointer; background: none; border: none;
  font-family: inherit;
}
.bw-close:hover { background: var(--rose-mist, #F9F0ED); color: var(--charcoal, #2C2C2C); }

/* ── Error ── */
.bw-error {
  padding: 0.75rem 1.5rem; background: #FEF2F2; color: #991B1B;
  font-size: 0.85rem; border-bottom: 1px solid #FECACA;
}

/* ── Content (scrollable) ── */
.bw-content {
  flex: 1; overflow-y: auto; padding: 1.5rem;
  -webkit-overflow-scrolling: touch;
}

/* ── Step label ── */
.bw-step-label {
  font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--teal, #218CAC);
  margin-bottom: 1rem;
}

/* ── Loading ── */
.bw-loading { text-align: center; padding: 3rem 1rem; }
.bw-loading p { color: var(--text-muted, #9A9A9A); font-size: 0.88rem; margin-top: 1rem; }

.bw-spinner { display: inline-flex; gap: 4px; align-items: center; justify-content: center; }
.bw-spinner div {
  width: 8px; height: 8px; border-radius: 50%; background: var(--teal, #218CAC);
  animation: bw-bounce 1.2s infinite ease-in-out both;
}
.bw-spinner div:nth-child(1) { animation-delay: -0.32s; }
.bw-spinner div:nth-child(2) { animation-delay: -0.16s; }
@keyframes bw-bounce {
  0%, 80%, 100% { transform: scale(0); opacity: 0.5; }
  40% { transform: scale(1); opacity: 1; }
}

/* ── Search ── */
.bw-search { margin-bottom: 1rem; }
.bw-search-input {
  width: 100%; padding: 0.85rem 1rem; min-height: 44px; border: 1px solid var(--border, #E8E2DB);
  border-radius: var(--radius-lg, 12px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.88rem; background: var(--white, #fff); color: var(--text, #1E1E1E);
  transition: border-color 0.2s;
}
.bw-search-input:focus { outline: none; border-color: var(--teal, #218CAC); }

/* ── Services list ── */
.bw-services-list { display: flex; flex-direction: column; gap: 0.5rem; }
.bw-cat { margin-bottom: 0.75rem; }
.bw-cat-name {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.1rem; font-weight: 600; color: var(--charcoal, #2C2C2C);
  margin-bottom: 0.4rem; padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--border-light, #F0EBE5);
}

.bw-srv-btn {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  gap: 0.75rem; padding: 0.75rem 1rem; min-height: 48px; border: 1px solid var(--border-light, #F0EBE5);
  border-radius: var(--radius, 4px); background: var(--white, #fff);
  cursor: pointer; transition: all 0.2s; text-align: left;
  font-family: var(--font-body, 'Raleway', sans-serif);
}
.bw-srv-btn:hover { border-color: var(--teal, #218CAC); background: var(--teal-soft, rgba(33,140,172,0.06)); }

.bw-srv-info { flex: 1; min-width: 0; }
.bw-srv-name {
  display: block; font-size: 0.88rem; font-weight: 600; color: var(--charcoal, #2C2C2C);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bw-srv-dur { display: block; font-size: 0.75rem; color: var(--text-muted, #9A9A9A); margin-top: 2px; }
.bw-srv-price {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.15rem; font-weight: 700; color: var(--teal, #218CAC); white-space: nowrap;
}

/* ── Selected summary ── */
.bw-selected-summary {
  background: var(--cream, #FDF8F3); border-radius: var(--radius-lg, 12px);
  padding: 1rem; margin-bottom: 1.5rem; border: 1px solid var(--border-light, #F0EBE5);
}
.bw-sel-item {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.3rem 0; font-size: 0.85rem;
}
.bw-sel-item + .bw-sel-item { border-top: 1px solid var(--border-light, #F0EBE5); padding-top: 0.5rem; margin-top: 0.25rem; }
.bw-sel-label { color: var(--text-muted, #9A9A9A); font-size: 0.75rem; min-width: 80px; }
.bw-sel-value { flex: 1; font-weight: 600; color: var(--charcoal, #2C2C2C); }
.bw-change {
  font-size: 0.78rem; color: var(--teal, #218CAC); background: none; border: none;
  cursor: pointer; font-weight: 600; text-decoration: underline; text-underline-offset: 2px;
  font-family: var(--font-body, 'Raleway', sans-serif);
  padding: 0.5rem 0.75rem; min-height: 44px; min-width: 44px;
  display: inline-flex; align-items: center;
}

/* ── Section ── */
.bw-section { margin-bottom: 1.5rem; animation: bw-fadeIn 0.3s ease; }
@keyframes bw-fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* ── Professionals ── */
.bw-pros-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 0.75rem; }
.bw-pro-btn {
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  padding: 1.25rem 0.75rem; border: 1px solid var(--border-light, #F0EBE5);
  border-radius: var(--radius-lg, 12px); background: var(--white, #fff);
  cursor: pointer; transition: all 0.2s; text-align: center;
  font-family: var(--font-body, 'Raleway', sans-serif);
}
.bw-pro-btn:hover { border-color: var(--teal, #218CAC); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }

.bw-pro-avatar {
  width: 52px; height: 52px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.3rem; font-weight: 700; color: #fff;
}
.bw-pro-name { font-size: 0.88rem; font-weight: 600; color: var(--charcoal, #2C2C2C); }
.bw-pro-specialty { font-size: 0.72rem; color: var(--text-muted, #9A9A9A); }

/* ── Date & Time ── */
.bw-date-wrap { margin-bottom: 1rem; }
.bw-date-input {
  width: 100%; padding: 0.7rem 1rem; border: 1px solid var(--border, #E8E2DB);
  border-radius: var(--radius, 4px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.92rem; background: var(--white, #fff); color: var(--text, #1E1E1E);
  cursor: pointer;
}
.bw-date-input:focus { outline: none; border-color: var(--teal, #218CAC); }

.bw-slots-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); gap: 0.5rem;
}
.bw-slot {
  padding: 0.75rem 0.25rem; min-height: 44px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border, #E8E2DB);
  border-radius: var(--radius, 4px); background: var(--white, #fff);
  font-family: var(--font-body, 'Raleway', sans-serif); font-size: 0.85rem;
  font-weight: 500; color: var(--charcoal, #2C2C2C); cursor: pointer;
  transition: all 0.15s; text-align: center;
}
.bw-slot:hover { border-color: var(--teal, #218CAC); background: var(--teal-soft, rgba(33,140,172,0.06)); }
.bw-slot-sel, .bw-slot-sel:hover {
  background: var(--teal, #218CAC) !important; color: #fff !important;
  border-color: var(--teal, #218CAC) !important;
}

.bw-no-slots, .bw-empty {
  text-align: center; color: var(--text-muted, #9A9A9A); font-size: 0.88rem;
  padding: 1.5rem; font-style: italic;
}

/* ── Phone step ── */
.bw-phone-step { animation: bw-fadeIn 0.3s ease; }
.bw-phone-hint { font-size: 0.85rem; color: var(--text-soft, #6B6B6B); margin-bottom: 0.75rem; }
.bw-phone-row { display: flex; gap: 0.5rem; }
.bw-phone-input { flex: 1; }
.bw-phone-btn {
  padding: 0.85rem 1.25rem; min-height: 44px; background: var(--teal, #218CAC); color: #fff;
  border: none; border-radius: var(--radius, 4px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.85rem; font-weight: 600; cursor: pointer; transition: background 0.2s;
  white-space: nowrap;
}
.bw-phone-btn:hover { background: var(--teal-light, #2BA4C8); }

/* ── Welcome back ── */
.bw-welcome-back {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.85rem 1rem; background: rgba(33,140,172,0.08); border-radius: var(--radius, 4px);
  margin-bottom: 1rem; font-size: 0.92rem; color: var(--teal-dark, #1A7290);
  animation: bw-fadeIn 0.3s ease;
}
.bw-wb-icon { font-size: 1.1rem; }

/* ── Form fields ── */
.bw-form { display: flex; flex-direction: column; gap: 0.75rem; }
.bw-field { display: flex; flex-direction: column; gap: 0.25rem; }
.bw-label { font-size: 0.78rem; font-weight: 600; color: var(--text-soft, #6B6B6B); }
.bw-optional { font-weight: 400; color: var(--text-muted, #9A9A9A); }

.bw-input {
  padding: 0.65rem 0.85rem; border: 1px solid var(--border, #E8E2DB);
  border-radius: var(--radius, 4px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.88rem; background: var(--white, #fff); color: var(--text, #1E1E1E);
  transition: border-color 0.2s;
}
.bw-input:focus { outline: none; border-color: var(--teal, #218CAC); }
.bw-input[readonly] { background: var(--cream, #FDF8F3); color: var(--text-soft, #6B6B6B); }
.bw-input-error { border-color: #EF4444 !important; }
.bw-textarea { resize: vertical; min-height: 52px; }

/* ── Booking summary ── */
.bw-booking-summary { margin-top: 0.25rem; }
.bw-summary {
  background: var(--cream, #FDF8F3); border-radius: var(--radius, 4px);
  padding: 0.85rem 1rem; border: 1px solid var(--border-light, #F0EBE5);
}
.bw-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.3rem 0; font-size: 0.82rem; color: var(--text-soft, #6B6B6B);
}
.bw-summary-row strong { color: var(--charcoal, #2C2C2C); font-weight: 600; }
.bw-summary-row + .bw-summary-row { border-top: 1px solid var(--border-light, #F0EBE5); }
.bw-summary-price strong {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.15rem; color: var(--teal, #218CAC);
}

/* ── Submit ── */
.bw-submit-btn {
  width: 100%; padding: 0.9rem; min-height: 48px; background: var(--teal, #218CAC); color: #fff;
  border: none; border-radius: var(--radius, 4px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.92rem; font-weight: 600; cursor: pointer; transition: all 0.2s;
  margin-top: 0.5rem; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
}
.bw-submit-btn:hover { background: var(--teal-light, #2BA4C8); transform: translateY(-1px); }
.bw-submit-btn:disabled { opacity: 0.7; cursor: not-allowed; transform: none; }
.bw-submit-btn .bw-spinner div { background: #fff; }

/* ── Confirmation ── */
.bw-confirmation { text-align: center; padding: 2rem 0; }
.bw-conf-icon {
  width: 64px; height: 64px; background: var(--teal, #218CAC); color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 2rem; margin: 0 auto 1.5rem; animation: bw-pop 0.4s ease;
}
@keyframes bw-pop { 0% { transform: scale(0); } 60% { transform: scale(1.2); } 100% { transform: scale(1); } }

.bw-conf-title {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 1.6rem; font-weight: 600; color: var(--charcoal, #2C2C2C); margin-bottom: 0.75rem;
}
.bw-conf-text { font-size: 0.92rem; color: var(--text-soft, #6B6B6B); margin-bottom: 0.5rem; }

.bw-conf-code {
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: 2.5rem; font-weight: 700; color: var(--teal, #218CAC);
  letter-spacing: 0.15em; padding: 0.5rem 0; margin-bottom: 1rem;
}

.bw-conf-detail {
  font-size: 0.88rem; color: var(--text-soft, #6B6B6B); line-height: 1.6;
  margin-bottom: 0.75rem;
}
.bw-conf-notice {
  font-size: 0.82rem; color: var(--text-muted, #9A9A9A); font-style: italic;
  margin-bottom: 1.5rem;
}

.bw-conf-actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }
.bw-btn-again {
  padding: 0.85rem 1.5rem; min-height: 44px; background: var(--teal, #218CAC); color: #fff;
  border: none; border-radius: var(--radius, 4px); font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.85rem; font-weight: 600; cursor: pointer; transition: all 0.2s;
}
.bw-btn-again:hover { background: var(--teal-light, #2BA4C8); }
.bw-btn-close {
  padding: 0.85rem 1.5rem; min-height: 44px; background: transparent; color: var(--text-soft, #6B6B6B);
  border: 1px solid var(--border, #E8E2DB); border-radius: var(--radius, 4px);
  font-family: var(--font-body, 'Raleway', sans-serif);
  font-size: 0.85rem; font-weight: 500; cursor: pointer; transition: all 0.2s;
}
.bw-btn-close:hover { border-color: var(--text-muted, #9A9A9A); }

/* ── Service card "Reservar" link (injected on servicios.html) ── */
.srv-book-link {
  display: inline-flex; align-items: center; margin-top: 0.6rem;
  min-height: 44px; padding: 0.5rem 0.75rem;
  font-size: 0.8rem; font-weight: 700; color: var(--teal, #218CAC);
  text-transform: uppercase; letter-spacing: 0.06em;
  text-decoration: underline; text-underline-offset: 2px;
  cursor: pointer; transition: color 0.2s;
  font-family: var(--font-body, 'Raleway', sans-serif);
}
.srv-book-link:hover { color: var(--teal-light, #2BA4C8); }

/* ── iOS scroll-lock on overlay ── */
.bw-overlay.bw-visible { touch-action: none; }

/* ── Mobile ── */
@media (max-width: 600px) {
  .bw-modal { max-width: 100%; }
  .bw-content { padding: 1rem; }
  .bw-slots-grid {
    grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
    max-height: 260px; overflow-y: auto; -webkit-overflow-scrolling: touch;
  }
  .bw-pros-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); }
  .bw-phone-row { flex-direction: column; }
  .bw-phone-btn { width: 100%; text-align: center; }
  .bw-conf-code { font-size: 2rem; }

  /* Prevent iOS auto-zoom on input focus (requires >= 16px) */
  .bw-search-input,
  .bw-date-input,
  .bw-input,
  .bw-textarea { font-size: 16px; }
}
