/* Salime Booking – v2.6.3 */
/* Mantiene estética original de 2.6.2 (sin fondo blanco) */

.salime-booking {
  max-width: 740px;
  margin: 16px auto;
  padding: 16px;
  background: transparent; /* mantiene fondo transparente */
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: #0f172a;
}

.salime-booking label {
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
  color: #0f172a;
}

.salime-booking input[type="text"],
.salime-booking input[type="email"],
.salime-booking input[type="tel"],
.salime-booking input[type="date"],
.salime-booking select,
.salime-booking textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: #fff;
  color: #0f172a;
  outline: none;
  font-size: 15px;
  box-sizing: border-box;
}

.salime-booking textarea {
  resize: vertical;
}

.salime-booking input:focus,
.salime-booking select:focus,
.salime-booking textarea:focus {
  border-color: #1e88a8;
  box-shadow: 0 0 0 3px rgba(30, 136, 168, .15);
}

/* Grid */
.salime-booking .grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px; /* separación uniforme */
}

.salime-booking .span-2 {
  grid-column: 1 / -1;
}

/* Ajuste de márgenes uniformes */
.salime-booking .grid-2 input[type="text"],
.salime-booking .grid-2 input[type="email"],
.salime-booking .grid-2 input[type="tel"],
.salime-booking .grid-2 input[type="date"],
.salime-booking .grid-2 select,
.salime-booking .grid-2 .flatpickr-alt-input,
.salime-booking textarea {
  margin-bottom: 0;
}

/* Campo de fecha */
.salime-booking .fecha-cell {
  display: flex;
  flex-direction: column;
}

/* Botón principal */
.btn-primary {
  appearance: none;
  border: 0;
  background: #1e88a8;
  color: #fff;
  border-radius: 10px;
  padding: 12px 16px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 10px;
  transition: background .2s ease, filter .2s ease;
}

.btn-primary:hover {
  filter: brightness(1.05);
}

.btn-primary:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* Mensajes de respuesta */
.salime-msg {
  margin-top: 10px;
  font-size: 14px;
}

.salime-msg.ok {
  color: #0f6b4d;
}

.salime-msg.err {
  color: #a1281a;
}

/* Disponibilidad */
.avail-hint {
  display: block;
  margin: 8px 0 6px;
  color: #334155;
}

.avail-hint.warn {
  color: #a15b00;
}

.avail-hint.bad {
  color: #a1281a;
}

.avail-meter {
  margin: 0 0 8px;
  height: 8px;
  background: #eef2f7;
  border-radius: 999px;
  overflow: hidden;
}

.avail-meter .bar {
  height: 100%;
  width: 0%;
  background: #1e88a8;
  transition: width .25s ease;
}

/* Tooltip calendario */
.flatpickr-day.salime-tip {
  position: relative;
}

.flatpickr-day.salime-tip:hover::after {
  content: attr(data-tip);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 110%;
  white-space: nowrap;
  background: #0f172a;
  color: #fff;
  font-size: 11px;
  padding: 4px 6px;
  border-radius: 6px;
  box-shadow: 0 4px 14px rgba(2, 8, 23, .25);
  pointer-events: none;
}

/* RGPD popover */
#salime-legal-popover {
  position: absolute;
  z-index: 9999;
  max-width: 520px;
  background: #fff;
  border: 1px solid #e5e9ef;
  border-radius: 12px;
  padding: 14px;
  box-shadow: 0 10px 30px rgba(2, 8, 23, .15);
}

/* RGPD line */
.rgpd-line {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 10px 0 16px;
  font-size: 14px;
}

.rgpd-line input[type="checkbox"] {
  margin-top: 3px;
}

.rgpd-line .rgpd-label a {
  color: #1e88a8;
  text-decoration: none;
}

.rgpd-line .rgpd-label a:hover {
  text-decoration: underline;
}

/* Modal éxito */
.salime-modal {
  position: fixed;
  inset: 0;
  background: rgba(2, 8, 23, .35);
  display: grid;
  place-items: center;
  opacity: 0;
  transition: opacity .2s ease;
}

.salime-modal.is-visible {
  opacity: 1;
}

.salime-modal[hidden] {
  display: none;
}

.salime-modal__card {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 22px;
  max-width: 460px;
  width: 90%;
  text-align: center;
  border: 1px solid #e5e9ef;
}

.salime-modal__icon {
  font-size: 28px;
  line-height: 1;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  margin: 0 auto 8px;
  background: #e6f7f1;
  color: #0f6b4d;
}

.salime-modal__close {
  position: absolute;
  top: 12px;
  right: 16px;
  border: 0;
  background: transparent;
  font-size: 24px;
  cursor: pointer;
}

.salime-no-scroll {
  overflow: hidden;
}

/* Flatpickr ajustes */
.flatpickr-alt-input {
  padding: 10px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  width: 100%;
}

/* Foco del input del calendario */
.flatpickr-alt-input:focus {
  border-color: #1e88a8;
  box-shadow: 0 0 0 3px rgba(30, 136, 168, .15);
}
