@charset "UTF-8";

@import 'https://fonts.googleapis.com/css?family=Montserrat';

html {
  font-size: 12px;
}

body {
  font-family: 'Montserrat', Arian Narrow, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: #2C2C2B;
  background-color: #fff;
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
.h1,
.h2,
.h3,
.h4,
.h5 {
  font-family: inherit;
  font-weight: 300;
  line-height: 1.1;
  color: #2C2C2B;
  font-family: 'Montserrat', Arian Narrow, Arial, sans-serif;
}

h1,
.h1,
h2,
.h2 {
  color: #2C2C2B;
  font-family: 'Montserrat', Arian Narrow, Arial, sans-serif;
}

.h1 .small,
.h1 small,
.h2 .small,
.h2 small,
.h3 .small,
.h3 small,
h1 .small,
h1 small,
h2 .small,
h2 small,
h3 .small,
h3 small {
  font-size: 52%;
}

.h4 small {
  color: #eeeeee;
}

.oculto{
  display: none !important;
}

.hotel-header {
  box-shadow: 0px 2px 3px 1px rgb(126 126 126 / 26%);
  background: #ffffff;
  color: #4f4f4f;
  margin-bottom: 2rem;
  width: 100%;
  position: fixed;
  z-index: 10;
}

.btn-burger {
  display: flex;
  width: 100%;
  justify-content: flex-end;
  outline: none !important;
  border: none !important;
  box-shadow: none !important;
}

.lista-menu{
  width: 100%;
}

#main .info-hotel{
  background: #f4f4f4;
  color: #4f4f4f;
  border-color: #fff;
  box-shadow: 0px 2px 3px 1px rgb(126 126 126 / 26%);
  padding: 20px;
}

.titulo-hotel {
  color: #97438d;
  font-size: 20px;
}

#booking {
  display: flex;
  justify-content: center;
  /* margin-top: 20px; */
}

#booking .contenedor-info-booking{
  margin-top: 150px;
}

#booking .contenedor-info-booking p.small{
  width: 100%;
  text-align: right;
}

#booking .contenedor-info-booking legend{
  border-bottom: 1px solid #e5e5e5;
  font-size: 15px;
}

.contenedor-form input.form-control{
  height: 34px;
  width: 133px;
}

.contenedor-form form{
  justify-content: end;
}

.contenedor-form .btn-buscar{
  background-repeat: repeat-x;
  transition: all .5s ease;
  border-radius: 0px;
  font-family: inherit;
  color: #fff;
  text-transform: uppercase;
  width: 100px;
  height: 34px;
}

#booking .contenedor-habitaciones{
  background: #fff;
  box-shadow: 0px 0px 5px #d8dcbc;
  margin-top: 40px;
  padding: 20px;
  display: flex;
  justify-content: space-between;
}

#booking .contenedor-habitaciones .habitaciones-dinamico .item-habitacion{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  margin-bottom: 15px;
}

.form-select{
  min-width: 116px;
}

.disponibilidad{
  margin: 20px 0;
  padding-bottom: 10px;
  border-bottom: 1px solid #e1dbd0;
}

.contenedor-error{
  background: #fff9e5;
  padding: 20px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
}

.icono{
  margin-right: 5px;
}

.footer{
  background: #5b5d62;
  color: #fff;
  min-height: 50px;
}

.footer .contenedor-footer {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 50px;
}

#habitaciones {
  max-height: 500px;
  overflow: scroll;
}

#habitaciones .contenedor-info-habitacion .imagen-habitacion,
#habitaciones .contenedor-info-habitacion .info-habitacion{
  padding: 0 15px;
}

#habitaciones .contenedor-info-habitacion .carousel-img{
  height: 150px;
}
#habitaciones .contenedor-info-habitacion .carousel-no-img{
  font-size:80px;
  height: 150px;
  background: #f8f8f8;
}

#habitaciones .contenedor-info-habitacion .imagen-habitacion img{
  width: 100%;
}

#habitaciones .contenedor-info-habitacion .info-habitacion .titulo-habitacion{
  margin-top: 0;
  font-size: 20px;
  color: #2C2C2B;
  font-weight: 400;
  padding-bottom: 3px;
  border-bottom: 1px solid #e1dbd0;
  position: relative;
}

#habitaciones .contenedor-info-habitacion .info-habitacion .titulo-habitacion .small{
  color: #fff;
  background: #2c2c2b;
  padding: 6px 12px;
  font-size: 14px;
  text-transform: initial;
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
  box-shadow: inset 0 1px 3px #bba070;
  font-family: 'Montserrat', Arian Narrow, Arial, sans-serif;
  position: absolute;
  top: 0;
  right: 0;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar{
  border-color: #fff;
  border-radius: 0px;
  background: #f8f8f8;
  box-shadow: none;
  padding: 10px;
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  margin-bottom: 30px;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .precio{
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: flex-end;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse {
  width: 100%;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .detalle-tarifa{
  width: 100%;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .detalle-tarifa .calendario{
  width: 100px;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .detalle-tarifa .calendario .calendario-header{
  width: 100%;
  padding: 6px;
  font-size: 11px;
  background: #d2ac67;
  color: #2c2c2b;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .detalle-tarifa .calendario .calendario-body{
  width: 100%;
  padding: 6px 10px;
  margin-bottom: 2px;
  text-align: right;
  background: transparent;
  position: relative;
  border: 1px solid #d2ac67;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .detalle-tarifa .precio-promedio{
  width: 100%;
  text-align: right;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .btn-detalle-tarifa{
  background: #003282;
  color: #ffffff;
  font-weight: 300;
  border-radius: 5px;
  padding: 0.7rem;
  font-size: 1.1rem;
}

#habitaciones .contenedor-info-habitacion .contenedor-reservar .contenedor-collapse .btn-detalle-tarifa:hover{
  background-color: #003282  !important;
  border-color: #003282  !important;
  color: #fff !important;
}

.btn-reservar{
  transition: all .5s ease;
  border-radius: 0px;
  font-family: 'Montserrat', Arian Narrow, Arial, sans-serif;
  color: #fff !important;
  text-transform: uppercase;
  margin-bottom: 1rem;
  font-size: 0.8rem;
  white-space: normal !important;
}

.error-msg {
  border-color: #dc3545;
}

.seleccion-habitacion{
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: center;
}

.habitaciones {
  height: 650px;
  overflow: scroll;
}

::-webkit-scrollbar {
  -webkit-appearance: none;
}
::-webkit-scrollbar:vertical {
  width:10px;
}
::-webkit-scrollbar-button:increment,::-webkit-scrollbar-button {
  display: none;
} 
::-webkit-scrollbar:horizontal {
  height: 10px;
}
::-webkit-scrollbar-thumb {
  background-color: #797979;
  border-radius: 20px;
  border: 2px solid #f1f2f3;
}
::-webkit-scrollbar-track {
  border-radius: 10px;  
}

@media (max-width: 1279px) {
  #booking .contenedor-info-booking{
    max-width: 100%;
    width: 100%;
  }

  #booking .contenedor-info-booking .img-banner{
    height: auto;
    width: 100%;
  }

  .contenedor-form input.form-control{
    height: 45px;
    width: 100%;
  }

  .contenedor-form .btn-buscar{
    height: 45px;
    width: 150px;
  }

  .contenedor-form .contenedor-boton{
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
  }

  .contenedor-form .contenedor-boton p{
    display: none;
  }
}
@media (max-width: 430px) {
  #booking .contenedor-info-booking{
    margin-top: 240px;
  }
}

@media (max-width: 500px) {
  .contenedor-form .btn-buscar{
    width: 100%;
  }

  #booking .contenedor-habitaciones{
    flex-direction: column;
    width: 100%;
  }

  #booking .contenedor-habitaciones .numero-habitaciones{
    margin-bottom: 15px
  }

  #booking .contenedor-habitaciones .numero-habitaciones,
  #booking .contenedor-habitaciones .habitaciones-dinamico{
    width: 100%;
  }

  #booking .contenedor-habitaciones .habitaciones-dinamico .item-habitacion{
    width: 100%;
    flex-wrap: wrap;
    gap: 0;
    justify-content: space-between;
  }

  #booking .contenedor-habitaciones .habitaciones-dinamico .item-habitacion .text-no-habitacion{
    width: 100%;
    margin-bottom: 5px;
  }

  .form-select{
    min-width: 120px;
    width: 100%;
  }

  #habitaciones .contenedor-info-habitacion .contenedor-reservar .precio{
    align-items: center;
    justify-content: center;
    width: 100%;
  }

  .btn-reservar{
    width: 100%;
    margin-bottom: 20px;
    height: 40px;
    font-size: 1rem;
  }

  #habitaciones .contenedor-info-habitacion .info-habitacion{
    margin-top: 15px;
  }
}

:root {
	/* Colors */
	--Grayish_blue: hsl(237, 18%, 59%);
	--White: hsl(0, 0%, 100%);
	--Dark_desaturated_blue: hsl(216.92deg 100% 25.49%);
	--Very_dark_blue: hsl(235, 16%, 14%);
	--Very_dark_blac_blue: hsl(234, 17%, 12%);

	/* font size */
	--p-text: 1.8rem;
	--s-text: 0.55rem;

	/* custom-shape */
	--circle-width: 0.25em;
	--circle-height: 0.45em;
}

.primary {
	font-size: var(--p-text);
	color: var(--White);
	text-align: center;
}

.sub-heading {
	font-size: var(--s-text);
	color: var(--Grayish_blue);
	text-align: center;
	letter-spacing: 0.5ch;
	margin-top: 1em;
}

.countdown-timer {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1em;
}

.timer-box {
	width: 4rem;
	padding: 0.5rem;
	text-align: center;
	background-color: var(--Dark_desaturated_blue);
	position: relative;
	border-radius: 0.25em;
}

.sheet {
	position: absolute;
	width: 100%;
	height: 50%;
	left: 0;
	top: 0;
	right: 0;
	background-color: var(--Very_dark_blue);
	opacity: 0.35;
}

.flip {
	transition: transform 1s;
	transform: translate(0%, 100%) scaleY(-1);
}

.circle-left {
	width: var(--circle-width);
	height: var(--circle-height);
	position: absolute;
	background-color: var(--Very_dark_blac_blue);
	border-top-right-radius: 100%;
	border-bottom-right-radius: 100%;
	top: 45%;
	left: 0;
}

.circle-right {
	width: var(--circle-width);
	height: var(--circle-height);
	position: absolute;
	background-color: var(--Very_dark_blac_blue);
	border-top-left-radius: 100%;
	border-bottom-left-radius: 100%;
	top: 45%;
	right: 0;
}

[v-cloak] {
  display: none;
}

.table-records {
  max-height: 215px;
  overflow: scroll;
}

.add-icon {
	cursor: pointer;
	font-size: 0.9em;
}
.add-icon .fa-plus:hover {
	animation: 1s fa-beat infinite;
}

.table .icon {
  cursor: pointer;
	font-size: 0.9em;
}

.table .fa-trash-can:hover {
	animation: 1s fa-beat infinite;
}

.select2-error {
  border: 1px solid #dd3444 !important;
  border-radius: 5px;
}

.error-msg-select2 {
  font-size: .875em;
  color: #dc3545;
  width: 100%;
  margin-top: 0.25rem;
}

/* Clases por hotel */

/* Hotel de pruebas */
.pruebas{
  background: #0c7460  !important;
  border-color: #0c7460  !important;
}

.pruebas:hover,
.pruebas:focus,
.pruebas:active{
  background-color: #0c7460  !important;
  border-color: #0c7460  !important;
  color: #fff !important;
}

.border-top-pruebas {
  border-top: 0.25rem solid #4f2b0a !important;
}

.icon-pruebas {
  color: #4f2b0a;
}

/* Hotel Weenjoy */
.weenjoy{
  background: #003282  !important;
  border-color: #003282  !important;
}

.weenjoy:hover,
.weenjoy:focus,
.weenjoy:active{
  background-color: #003282  !important;
  border-color: #003282  !important;
  color: #fff !important;
}

.border-top-weenjoy {
  border-top: 0.25rem solid #003282 !important;
}

.icon-weenjoy {
  color: #003282;
}

/* Hotel Azul Arena */
.azularena{
  background: #10769d !important;
  border-color: #10769d !important;
}

.azularena:hover,
.azularena:focus,
.azularena:active{
  background-color: #234a69 !important;
  border-color: #234a69 !important;
  color: #fff !important;
}

.border-top-azularena {
  border-top: 0.25rem solid #234a69 !important;
}

.icon-azularena {
  color: #234a69;
}