/* ===============================
   Calendario Reservas — Estilos (con override fuerte)
   =============================== */

/* ---------- Variables ---------- */
:root {
  --cr-brand: #f6741d;
  --cr-bg-dark: #606060;
  --cr-bg-form: rgba(0,0,0,0.6);
  --cr-white: #ffffff;
  --cr-text: #333;
  --cr-border: #bbb;
  --cr-radius: 0px;
  --cr-control-radius: 0px;
  --cr-shadow: 0 4px 12px rgba(0,0,0,.12);
  --cr-gap: 16px;
  --cr-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Altura/espaciado de controles */
  --cr-control-h: 42px;
  --cr-control-pad-x: 12px;
  --cr-control-pad-y: 10px;
  --cr-control-fs: 15px;
}

/* ===============================
   SCOPE RESET: fuerza nuestros estilos
   =============================== */

/* Tipografía base y color */
.calendario-reservas,
.cr-banner,
.cr-banner * {
  font-family: var(--cr-font) !important;
  color: inherit;
  box-sizing: border-box;
}

/* Reseteo de inputs/selects dentro de nuestros contenedores */
.calendario-reservas input,
.calendario-reservas select,
.cr-banner input,
.cr-banner select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  color: inherit !important;
  margin: 0 !important;
  width: 100% !important;
  height: var(--cr-control-h) !important;
  padding: var(--cr-control-pad-y) var(--cr-control-pad-x) !important;
  font-size: var(--cr-control-fs) !important;
  border-radius: var(--cr-control-radius) !important;
  line-height: calc(var(--cr-control-h) - 2*var(--cr-control-pad-y)) !important;
}

/* Placeholders legibles en banner oscuro */
.cr-banner input::placeholder { color: rgba(255,255,255,.85) !important; }

/* Quitar flechas nativas en number (WebKit y Firefox) */
.calendario-reservas input[type=number]::-webkit-outer-spin-button,
.calendario-reservas input[type=number]::-webkit-inner-spin-button,
.cr-banner input[type=number]::-webkit-outer-spin-button,
.cr-banner input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}
.calendario-reservas input[type=number] { -moz-appearance: textfield !important; }
.cr-banner input[type=number] { -moz-appearance: textfield !important; }

/* Botones: quita estilos del tema y aplica los nuestros */
.submit-btn,
.cr-banner__btn {
  all: unset;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer !important;
  user-select: none !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  text-decoration: none !important;
  border-radius: 0px !important;
  height: var(--cr-control-h) !important;
  padding: 0 22px !important;
  font-weight: 700 !important;
  font-size: 16px !important;
}

/* ===============================
   Tarjeta / Modo clásico
   =============================== */
.calendario-reservas {
  max-width: 480px;
  margin: 30px auto !important;
  background: var(--cr-white) !important;
  border: 1px solid #ddd !important;
  border-radius: 0px !important;
  padding: 24px !important;
  box-shadow: 0 4px 10px rgba(0,0,0,.05) !important;
  color: var(--cr-text) !important;
}
.calendario-reservas .label {
  font-weight: 600 !important;
  margin-bottom: 10px !important;
  font-size: 1.1em !important;
}
.calendario-reservas label {
  display: block !important;
  font-size: 14px !important;
  margin-top: 15px !important;
  margin-bottom: 5px !important;
  font-weight: 500 !important;
}
.cr-grid-2 { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
.cr-field { margin-bottom: 10px !important; }

/* Botón clásico */
.submit-btn {
  width: 100% !important;
  margin-top: 20px !important;
  background: var(--cr-brand) !important;
  color: var(--cr-white) !important;
  border: 1px solid var(--cr-brand) !important;
  border-radius: 0px !important;
  transition: background .25s ease, color .25s ease !important;
}
.submit-btn:hover { background: var(--cr-white) !important; color: var(--cr-brand) !important; }

/* ===============================
   Botón flotante + modal
   =============================== */
#cr-floating-btn {
  position: fixed !important; bottom: 25px !important; right: 25px !important;
  width: 60px !important; height: 60px !important;
  background: var(--cr-white) !important;
  border: 1px solid var(--cr-brand) !important;
  border-radius: 0 !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.2) !important;
  transition: transform .2s ease-in-out !important;
  display: flex !important; justify-content: center !important; align-items: center !important;
  z-index: 9998 !important;
}
#cr-floating-btn:hover { transform: scale(1.1) !important; }
#cr-floating-btn svg { width: 45px !important; height: 45px !important; }
#cr-floating-btn svg path { fill: var(--cr-brand) !important; }

#cr-modal-overlay {
  position: fixed !important; inset: 0 !important;
  background: rgba(0,0,0,.5) !important;
  z-index: 9999 !important;
}
.cr-modal-content {
  position: fixed !important; bottom: 25px !important; right: 25px !important;
  z-index: 10000 !important;
  transition: opacity .3s ease, transform .3s ease !important;
}
.cr-modal-hidden .cr-modal-content { opacity: 0 !important; transform: translateY(20px) !important; pointer-events: none !important; }
.cr-modal-hidden #cr-modal-overlay { display: none !important; }
.cr-modal-content .calendario-reservas { margin: 0 !important; }
#cr-modal-close {
  position: absolute !important; top: 10px !important; right: 15px !important;
  background: transparent !important; border: 0 !important;
  font-size: 28px !important; line-height: 1 !important; color: #888 !important; cursor: pointer !important;
}

/* ===============================
   Banner (modo horizontal)
   =============================== */
.cr-banner-wrap { width: 100% !important; margin: 20px 0 !important; }

.cr-banner {
  display: grid !important;
  grid-template-columns: 1.2fr 1.4fr .9fr auto !important; /* más aire para fechas */
  gap: var(--cr-gap) !important;
  align-items: start !important;
  background: var(--cr-bg-form) !important;
  color: #fff !important;
  padding: 18px 22px !important;
  border-radius: var(--cr-radius) !important;
  box-shadow: var(--cr-shadow) !important;
}

/* Grupos y etiquetas */
.cr-banner__group { display: flex !important; flex-direction: column !important; gap: 8px !important; min-width: 0 !important; }
.cr-banner__label { font-weight: 700 !important; font-size: 14px !important; color: #fff !important; }
.cr-muted { opacity: .8 !important; font-weight: 400 !important; }

/* Controles */
.cr-banner__control {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 1px solid var(--cr-border) !important;
  border-radius: var(--cr-control-radius) !important;
  padding: var(--cr-control-pad-y) var(--cr-control-pad-x) !important;
  height: var(--cr-control-h) !important;
}

/* Inputs/selects concretos dentro de control del banner (override de seguridad) */
.cr-banner__control input,
.cr-banner__control select,
.cr-banner__control .flatpickr-input {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff !important;
  width: 100% !important;
  min-width: 0 !important;
}

/* Iconos SVG dentro del control */
.cr-banner__control .cr-icon {
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  margin-right: 8px !important;
  display: inline-block !important;
  filter: none !important;
}

.cr-banner__control select { padding-right: 24px !important; }
.cr-banner__control .flatpickr-input[readonly] { background-color: transparent !important; }

/* Acción (botón) */
.cr-banner__action { display: flex !important; justify-content: flex-end !important; align-items: end !important; align-self: flex-end !important; }
.cr-banner__btn {
  background: #fff !important;
  color: #0a2f3a !important;
  border-radius: 0 !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.15) !important;
}
.cr-banner__btn:hover { filter: brightness(.95) !important; }
.cr-banner__btn:active { transform: translateY(1px) !important; }

/* Focus visible accesible */
.cr-banner__control:has(input:focus-visible),
.cr-banner__control:has(select:focus-visible),
.submit-btn:focus-visible,
.cr-banner__btn:focus-visible {
  outline: 0 solid #fff !important;
  outline-offset: 2px !important;
}

/* Responsive */
@media (max-width: 980px) {
  .cr-banner {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .cr-banner__action { justify-content: stretch !important; align-items: stretch !important; }
  .cr-banner__btn { width: 100% !important; }
}

/* ===============================
   Accesibilidad / preferencias
   =============================== */
.calendario-reservas select,
.cr-banner select,
.cr-banner input[type="date"],
.cr-banner .flatpickr-input { color-scheme: dark light !important; }

/* ===============================
   Flatpickr (tema integrado)
   =============================== */
.cr-banner .flatpickr-calendar {
  background: #fff !important;
  border-radius: 0px !important;
  font-family: var(--cr-font) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.3) !important;
}
.cr-banner .cr-date-range{
  border: 0;
  color: #FFFFFF;
}
.cr-banner .flatpickr-day.selected,
.cr-banner .flatpickr-day.startRange,
.cr-banner .flatpickr-day.endRange {
  background: var(--cr-brand) !important;
  border-color: var(--cr-brand) !important;
  color: #fff !important;
}
.cr-banner .flatpickr-day.inRange {
  background: rgba(246,116,29,.15) !important;
  border-color: transparent !important;
}
.hotel-select option{
  background: var(--cr-text);
}
.flatpickr-current-month{
  justify-content: space-between !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months{
  min-width: 0 !important;
}