/* Tema Paleta Azul: Definimos las variables globales */
:root {
  /* Fondo de los botones */
  --bg-btn-reservar: #002f6d;  /* Azul brillante #466AFA; */
  --bg-btn-reservar-hover: #0d57b8;  /* Azul oscuro */
  --bg-btn-reservar-outline: #002f6d;  /* Azul brillante */
  --bg-btn-reservar-outline-hover: #0d57b8;  /* Azul oscuro */
  --bg-btn-accionar: #000000;  /* Azul brillante */
  --bg-btn-accionar-hover: #051a36;  /* Azul oscuro */

  /* Colores de texto */
  --text-principal-color: #080707;  /* Negro con matiz de gris */
  --text-cuerpo-color: #000000;     /* Negro puro */
  --text-blanco-color: #ffffff;     /* Blanco puro */
  --text-blanco-color2: #000000;    /* Azul suave */

  /* Colores de texto resaltado */
  --text-resaltar-1: #E02B20; /* Rojo brillante */
  --text-resaltar-2: #ff476c; /* Naranja brillante */
  --text-resaltar-3: #000000; /* Negro puro */

  /* Color de los enlaces resaltados */
  --text-resaltar-enlace: #454545; /* Gris oscuro */
  --bg-divisor1: #000000; /* Gris oscuro profundo #151d1d #002f6d */
  --bg-divisor2: #002f6d; /* Azul brillante */
  --bg-divisor3: #ff476c; /* Naranja brillante */
}
  
  .title-descuento{
    color:var(--text-blanco-color)
  }

  /* Clase personalizada para el fondo de botón de acción */
  .bg-accionar {
    background-color: var(--bg-btn-accionar) !important;
    border-color: var(--bg-btn-accionar) !important;
    color: rgb(255, 255, 255) !important; /* Texto en blanco para contraste */
  }
  .bg-accionar:hover {
    background-color: var(--bg-btn-accionar-hover) !important;
    border-color: var(--bg-btn-accionar-hover) !important;
    color: rgb(255, 255, 255) !important; /* Texto en blanco para contraste */
  }
  
  /* Botón de reservar utilizando la variable de color */
  .bg-reservar {
    background-color: var(--bg-btn-reservar) !important;
    border-color: var(--bg-btn-reservar) !important;
    color: white !important;
  }
  
  /* Estilos para el texto general y del cuerpo 
  body {
    color: var(--text-cuerpo-color);
  }
  
  h1, h2, h3 {
    color: var(--text-principal-color);
  }
  
  /* Estilos para textos resaltados */
  .text-resaltar-1 {
    color: var(--text-resaltar-1);
  }
  
  .text-resaltar-2 {
    color: var(--text-resaltar-2);
  }
  
  .text-resaltar-3 {
    color: var(--text-resaltar-3);
  }
  
  /* Estilo para enlaces resaltados */
  a.enlace-resaltar {
    color: var(--text-resaltar-enlace);
    text-decoration: underline;
  }
  
  a.enlace-resaltar:hover {
    color: var(--text-resaltar-2); /* Cambia a verde al pasar el ratón */
  }



.bg-divisor-2 {
  background-color: var(--bg-divisor2);
  color: white;
}

.bg-encabezados
{
  background-color: var(--bg-divisor1);
  color: white;
}
.text_enlace_fBlack{

  color: var(--text-blanco-color)!important;
  text-decoration: none;
  
}
.text_enlace_fBlack:hover{
  color: var(--text-blanco-color2)!important;
  text-decoration: none;
}
  /***************************************************************Css Personalizados *************/
  .container {

    margin: 0 auto;
}
.form-row {
    margin-bottom: 1em;
}
#card-element {
    background-color: rgb(255, 255, 255);
    padding: 15px;
    width: 50%;
    border-radius: 5px;
    border: 1px solid;
    transition: border 0.3s ease;
   
   
}
#card-element:focus {
    border: 1px solid rgb(10, 10, 10);
}
#card-errors {
    color: #ff0059;
    margin-top: 1em;
}
button {
    background-color: #ffffff;
    color: white;
    padding: 10px 20px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    display: block;
    width: 100%;
}

/* Ajuste de tamaño a la mitad del Timeline */
.timeline {
  display: flex;
  align-items: center;
  position: relative;
  margin: 20px 0;
}

.step {
  position: relative;
  text-align: center;
  flex: 1; /* Asegura que todos los pasos tengan el mismo ancho */
}

.step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 39%;
  right: -50%; /* Ajusta la posición para conectar con el siguiente paso */
  width: calc(100% + 5px); /* Ajusta el ancho para cubrir el espacio entre pasos */
  height: 5px; /* Reducido a la mitad */
  background-color: #ccc;
  z-index: -1;
}

.step.completed::after {
  background-color: var(--bg-divisor1); /* Línea verde para los pasos completados */
}

.circle {
  width: 25px;  /* Reducido a la mitad */
  height: 25px;  /* Reducido a la mitad */
  background-color: #ccc;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 15px;  /* Reducido a la mitad */
  color: white;
  margin: 0 auto;
}

.completed .circle {
  background-color: var(--bg-divisor1); /* Verde para los pasos completados */
}

  /**********************PARA Disponibilidad de Habtaciones *******************************/

  .oferta-especial {
    font-size: 0.9em; /* Tamaño pequeño */
    font-weight: bold;
    color: #ffffff; 
    background: var(--bg-divisor3); /* Color de fondo */
    padding: 5px 10px;
    border-radius: 5px;
    display: inline-block; /* Tamaño del div adaptado al contenido */
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
    margin-right: 10px; /* Separación */
    position: relative; /* Necesario para posicionar el pseudo-elemento */
}

/* Pseudo-elemento para la colita */
.oferta-especial::after {
    content: ''; /* Elemento vacío, ya que solo es decorativo */
    position: absolute; /* Posicionamiento absoluto respecto al contenedor */
    bottom: -10px; /* Ajusta la posición vertical para colocarla debajo del div */
    right: 10px; /* Ajusta la posición horizontal para colocarla a la derecha */
    width: 0; 
    height: 0; 
    border-left: 10px solid transparent; /* Borde izquierdo transparente */
    border-right: 10px solid transparent; /* Borde derecho transparente */
    border-top: 10px solid var(--bg-divisor3); /* La colita será del mismo color que el fondo */
}

.div-especial{
  font-size: 0.9em; /* Tamaño pequeño */
  font-weight: bold;
  color: #ffffff; 
  background: var(--bg-divisor3); /* Color de fondo */
  padding: 5px 10px;
  border-radius: 5px;
  display: inline-block; /* Tamaño del div adaptado al contenido */
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
  margin-right: 10px; /* Separación */
  position: relative; /* Necesario para posicionar el pseudo-elemento */
}

  .titulo-item {
    display: inline-block; /* Hace que el párrafo esté en línea con el div */
    vertical-align: middle; /* Alinea verticalmente los elementos */
  }
  .linea-pronunciada {
    border: none; /* Elimina el borde predeterminado */
    height: 1px; /* Define el grosor de la línea */
    background-color: #363636; /* Color personalizado para la línea */
    margin: 20px 0; /* Espaciado superior e inferior */
  }


  
  /* --------------------------------------- Botón personalizado para "Reservar"  */
  .btn-reservar {
      background-color: var( --bg-btn-reservar)  ; /*  */
      border: 1px solid var( --bg-btn-reservar) ;
      color: white !important;
      font-size: 1rem;
      padding: 0.5rem 1rem;
  }

  /* Efecto hover para el botón "Reservar" */
  .btn-reservar:hover {
      background-color:var( --bg-btn-reservar-hover); /* Verde más oscuro al pasar el mouse */
      border-color:var( --bg-btn-reservar-hover);
      color: white;
      font-size: 16px;
  }

  /* Botón personalizado para "Reservar" con borde azul */
  .btn-reservar-outline {
      color: var(--bg-btn-reservar-outline); /* Azul para el texto */
      border: 1px solid var(--bg-btn-reservar-outline) ;
      background-color: transparent;
      font-size: 1rem;
      padding: 0.5rem 1rem;
  }

  /* Efecto hover para el botón con borde azul */
  .btn-reservar-outline:hover {
      background-color: var(--bg-btn-reservar-outline-hover); /* Fondo azul al pasar el mouse */
      border-color: var(--bg-btn-reservar-outline-hover);
      color: white; /* Texto blanco al pasar el mouse */
  }

  .politicasi{
   
      color: var(--text-resaltar-3);
      font-size: 1rem;
      padding: 0.5rem 1rem;
  
  }
  .contactenos {
    background-color: var(--bg-btn-accionar);
    color: white;
    
    padding: 0.5rem 1rem;
  }

  /* Estilos para el botón "Reservar y Pagar" */
.reservarypagar {
  background-color: var(--bg-btn-reservar); /* Azul puro */
  border: 1px solid  var(--bg-btn-reservar);
  color: white;
  font-size: 1rem; /* Tamaño de fuente normal */
  padding: 0.5rem 1rem;
  transition: background-color 0.3s ease, border-color 0.3s ease; /* Transición suave */
}

/* Efecto hover para el botón "Reservar y Pagar" */
.reservarypagar:hover {
  background-color:  var(--bg-btn-reservar-hover); /* Azul más oscuro al pasar el mouse */
  border-color: var(--bg-btn-reservar-hover);
  font-size: 16px; /* Tamaño de fuente un poco mayor al hacer hover */
  color: white;
}

.obligatorio {
  color: var( --text-resaltar-1);
  font-weight: bold;
}
  .celda-con-etiqueta {
  position: relative;
  display: inline-block;
  }
  .celda-con-etiquetabtn {
  position: relative;
 
  }

  .etiqueta {
  visibility: hidden;
  width: 300px;
  background-color: var(--bg-divisor1);
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 5px;
  position: absolute;
  z-index: 1;
  bottom: 150%;
  left: 50%;
  margin-left: -60px;
  opacity: 0;
  transition: opacity 0.3s;
  }

  .celda-con-etiqueta:hover .etiqueta {
  visibility: visible;
  opacity: 1;
  }
  .celda-con-etiquetabtn:hover .etiqueta {
  visibility: visible;
  opacity: 1;
 
  }
  
/* Estilos generales para los elementos de Stripe */
#card-number-element,
#card-expiry-element,
#card-cvc-element {
  padding: 10px;
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  background-color: #fff;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

/* Cambiar el color del borde y la sombra al enfocar */
#card-number-element:focus,
#card-expiry-element:focus,
#card-cvc-element:focus {
  border-color: #80bdff;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* Asegurar que los elementos ocupen todo el ancho en pantallas pequeñas */
@media only screen and (max-width: 768px) {
  #card-number-element,
  #card-expiry-element,
  #card-cvc-element {
      width: 100%;
  }
}

/* Distribuir los elementos en una fila en pantallas medianas a grandes */
@media only screen and (min-width: 769px) {
  .form-group.col-md-6 {
      flex: 0 0 50%;
      max-width: 50%;
  }

  .form-group.col-md-3 {
      flex: 0 0 25%;
      max-width: 25%;
  }
}

.celda-con-etiqueta {
  position: relative;
  display: inline-block;
  }
  .celda-con-etiquetabtn {
  position: relative;
 
  }

  .etiqueta {
  visibility: hidden;
  width: 300px;
  background-color: #000;
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 5px;
  position: absolute;
  z-index: 1;
  bottom: 150%;
  left: 50%;
  margin-left: -60px;
  opacity: 0;
  transition: opacity 0.3s;
  }

  .celda-con-etiqueta:hover .etiqueta {
  visibility: visible;
  opacity: 1;
  }
  .celda-con-etiquetabtn:hover .etiqueta {
  visibility: visible;
  opacity: 1;
  }
/* Contenedor principal eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeedel formulario */
.custom-reservation-form-container {
  padding: 20px;
  background-color: #f9f9f9;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  max-width: 100%;
  margin: 20px auto;
}

.mr_form-control {
  width: 100%;
  padding: 12px 10px;
  border: 2px solid #e0e0e0;
  border-radius: 8px;
  font-size: 14px;
  transition: all 0.3s ease;
  background-color: #fff;
  box-sizing: border-box;
  text-align: center;
}

.mr_form-control:focus {
  border-color: #3498db;
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.2);
  outline: none;
}

.mr_number-input {
  width: 100%;
}

.mr_btn-primary {
  background-color: var(--bg-btn-reservar);
  border: none;
  border-radius: 0px;
  color: white;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  letter-spacing: 1px;
  box-shadow: 0 4px 6px rgba(50, 50, 93, 0.11), 0 1px 3px rgba(0, 0, 0, 0.08);
  width: 100%;
}

.mr_btn-primary:hover {
  background-color: var(--bg-btn-reservar-hover);
  transform: translateY(-2px);
  box-shadow: 0 7px 14px rgba(50, 50, 93, 0.1), 0 3px 6px rgba(0, 0, 0, 0.08);
}

.mr_row {
  display: flex;
  flex-wrap: wrap;
  margin: -15px;
}

.mr_col {
  flex: 1;
  padding: 15px;
  min-width: 200px;
}

.mr_icon {
  width: 20px;
  height: 20px;
  margin-right: 8px;
  vertical-align: text-bottom;
  flex-shrink: 0;
}

/* Ajustes responsivos */
@media (max-width: 768px) {
  .mr_row {
      flex-direction: column;
  }

  .mr_col {
      width: 100%;
  }
}

.mr-custom-card-header {
  padding: 10px 15px; /* Ajusta el padding para hacer el encabezado más delgado */
  border-top-left-radius: 10px; /* Esquinas redondeadas */
  border-top-right-radius: 10px; /* Esquinas redondeadas */
  background-color:var(--bg-divisor1); /* Color de fondo del encabezado */
  color: #fff; /* Color del texto */
  font-size: 18px; /* Tamaño de fuente más pequeño */
}

.mr-custom-card-header h3 {
  margin: 0; /* Elimina el margen del título */
  font-size: 18px; /* Ajusta el tamaño de la fuente dentro del h3 */
  font-weight: 600; /* Ajusta el grosor del texto */
}

.mr-card {
  border: 2px solid var(--bg-divisor1); /* Borde del mismo color que el fondo del encabezado */
  border-radius: 10px; /* Esquinas redondeadas de toda la card */
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Sombra suave */
}

.mr-card-body {
  padding: 20px; /* Ajusta el padding del cuerpo de la card */
}

/* Estilos adicionales si lo necesitas para la sombra más visible */
.mr-card-shadow {
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2); /* Sombra más resaltada */
}

#form-cambio-moneda {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  background-color: #f8f9fa;
  border: 1px solid #dee2e6;
  border-radius: 8px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  width: fit-content;
}

#form-cambio-moneda label {
  font-weight: bold;
  color: #495057;
  font-size: 14px;
}

#select-moneda {
  padding: 5px 10px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 14px;
  background-color: #ffffff;
  color: #495057;
  cursor: pointer;
  outline: none;
}

#select-moneda:hover {
  border-color: #007bff;
}

#select-moneda:focus {
  border-color: #007bff;
  box-shadow: 0 0 5px rgba(0, 123, 255, 0.25);
}
/* Estilos específicos para el formulario de cupones  perfecto */
.formulario-cupon_mr {
  max-width: 400px;
  margin: auto;
  padding: 20px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 10px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.formulario-cupon_mr h2 {
  text-align: center;
  color: #333;
}

.label-cupon_mr {
  display: block;
  margin-bottom: 8px;
  font-weight: bold;
}

.input-cupon_mr {
  width: 100%;
  padding: 10px;
  margin-bottom: 15px;
  border: 1px solid #ccc;
  border-radius: 5px;
  font-size: 16px;
  color: green;
  font-weight: bold;
}

.input-cupon_mr:focus {
  outline: none;
  border-color: #4caf50; /* Verde */
  box-shadow: 0 0 5px rgba(76, 175, 80, 0.5); /* Verde */
}

.boton-cupon_mr {
  display: block;
  width: 100%;
  padding: 10px;
  font-size: 16px;
  background-color: #4caf50; /* Verde */
  color: #fff;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-weight: bold;
}

.boton-cupon_mr:hover {
  background-color: #45a049;
}

.resultado-cupon_mr {
  text-align: center;
  margin-top: 20px;
  font-size: 16px;
  display: none;
}

.resultado-cupon_mr.success {
  color: #4caf50; /* Verde */
}

.resultado-cupon_mr.error {
  color: #f44336; /* Rojo */
}
/*secciones de cuponess */
.ventana-cupon {
  position: fixed;
  top: 50px;
  right: 20px;
  width: 250px;
  background: #f8f9fa;
  border: 2px solid #28a745;
  padding: 15px;
  border-radius: 8px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
  z-index: 1000;
  font-size: 14px;
}

.ventana-cupon h4 {
  margin: 0;
  color: #28a745;
  font-size: 16px;
}

.ventana-cupon p {
  margin: 5px 0;
}

#cerrar-ventana {
  background: transparent;
  border: none;
  color: red;
  font-size: 16px;
  cursor: pointer;
  float: right;
}
