body {
  font-family: "Noto Sans", sans-serif;
  width: 100%;
  max-width: 500px !important;
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  min-height: 100vh;
  padding: 0px;
}

.font-family-noto {
  font-family: "Noto Sans", sans-serif;
}

.base {
  position: relative;
  float: left;
}
.d-flex {
  display: flex;
}

.align-items-center {
  align-items: center;
}
.align-items-end {
  align-items: flex-end;
}

.justify-content-center {
  justify-content: center;
}

.flex-column {
  flex-direction: column;
}

.flex-row {
  flex-direction: row !important;
}

.justify-content-between {
  justify-content: space-between !important;
}
.w-100 {
  width: 100%;
}
.w-50 {
  width: 50%;
}

.w-auto {
  width: auto !important;
}

.mb-11 {
  margin-bottom: 11px;
}
.gap-8 {
  gap: 8px;
}

.gap-11 {
  gap: 11px;
}

.font-16 {
  font-size: 16px;
}

.font-13 {
  font-size: 13px;
}

.font-14 {
  font-size: 14px;
}

.font-11 {
  font-size: 11px;
}

.font-12 {
  font-size: 12px;
}

.font-weight-350 {
  font-weight: 350;
}

.text-center {
  text-align: center;
}
#booking-shadow {
  position: absolute;
  top: 0px;
  left: 0px;
  background: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
}

.container-booking {
  position: fixed !important;
  right: 0px !important;
  bottom: 0px !important;
  display: flex !important;
  flex-direction: column !important;
  -webkit-box-pack: start !important;
  justify-content: flex-start !important;
  min-width: 320px !important;
  width: 495px;
  max-height: 936px !important;
  background: #fff;
  border-radius: 5px;
}

@media (min-width: 768px) {
  .container-booking {
    right: 20px !important;
    bottom: 20px !important;
    height: calc(100% - 40px) !important;
  }
}

.booking-header {
  background: green;
  padding: 10px 20px;
  position: relative;
  float: left;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Noto Sans", sans-serif;
  font-size: 14px;
  height: 60px;
  background: #484c3d;
}

.icon-close {
  border: 0px;
  background: none;
  font-family: "Noto Sans", sans-serif;
  color: #fff;
  font-size: 16px;
}

.m-0 {
  margin: 0px !important;
}
.p-0 {
  padding: 0px !important;
}
.my-15 {
  margin: 15px 0px;
}

button {
  cursor: pointer;
}

button:disabled,
button[disabled] {
  cursor: normal;
  opacity: 0.5;
}

.container-button {
  padding: 20px 32px !important;
  justify-content: center;
  align-items: center;
  display: flex;
  flex-direction: column;
  background-color: rgba(255, 255, 255) !important;
  z-index: 30 !important;
  box-shadow: rgba(33, 37, 41, 0.06) 0px -6px 4px 0px !important;
  position: fixed;
  bottom: 0;
  width: 436px;
  left: auto;
}

.button-search {
  border-radius: 4px !important;
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  transition-property: all !important;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
  transition-duration: 150ms !important;
  text-transform: uppercase !important;
  text-align: center !important;
  font-size: 14px !important;
  line-height: 20px !important;
  height: 48px !important;
  letter-spacing: 0.03em !important;
  color: rgba(255, 255, 255) !important;
  background: rgb(72, 76, 61) !important;
  width: 100% !important;
  border: 0px;
}

.container-calendar {
  flex-direction: column !important;
  overflow: hidden auto !important;
  flex: 1 1 0% !important;
  padding: 0px 0px 0px !important;
  scrollbar-color: rgb(222, 226, 230) transparent;
}

.separate {
  border-color: #ced4da !important;
  margin-top: 32px !important;
  margin-bottom: 32px !important;
  border-top: 1px;
}

.title-1 {
  margin-bottom: 16px !important;
  font-size: 12px !important;
  line-height: 12px !important;
  letter-spacing: 0.64px !important;
  color: #495057 !important;
  text-transform: uppercase;
}

.calendar-leyend {
  padding-top: 16px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 12px;
  line-height: 12px;
  gap: 5px;
  color: #495057;
}

.alert {
  border-radius: 4px !important;
  color: rgba(255, 255, 255, 1) !important;
  padding: 16px !important;
  display: flex;
  font-size: 14px !important;
  line-height: 20px !important;
  background: rgb(72, 76, 61) !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
}

.alert > button {
  border: 0px;
  background: none;
  color: #fff;
}

/**************controler age***************************/

.container-controler-age {
  display: flex !important;
  justify-content: space-between !important;
  height: 64px !important;
  align-items: center !important;
  background-color: #f0f2f4 !important;
  border-radius: 4px !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
  margin-top: 0px !important;
}

.container-guest {
  display: flex !important;
  justify-content: space-between !important;
  height: 64px !important;
  align-items: center !important;
  background-color: #f0f2f4 !important;
  border-radius: 4px !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
  margin-top: 0px !important;
}

.label-guest {
  font-size: 14px !important;
  line-height: 23.4px !important;
}

.button-controller-guest {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
  transition-duration: 150ms !important;
  border-radius: 9999px !important;
  width: 24px !important;
  height: 24px !important;
  background: rgb(72, 76, 61, 1);
  color: rgba(255, 255, 255, 1);
  margin-left: 16px !important;
  border: 0px;
  outline: 0px;
}

.button-controller-guest:hover {
  background: rgb(72, 76, 61, 0.5);
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
  transition-duration: 150ms !important;
}

.button-controller-guest:disabled {
  color: #adb5bd;
  background-color: #f8f9fa !important;
}

.input-guest {
  margin-left: 16px;
  width: 24px;
  height: 24px;
  background: none;
  border: 0px;
  font-size: 18px;
}

/**********promo code************/

.container-input-border {
  width: 100%;
  display: flex !important;
  align-items: center !important;
  height: 32px !important;
  padding: 7px 16px !important;
  border-radius: 4px !important;
  position: relative !important;
  background-color: rgba(255, 255, 255, 1) !important;
  border: 1px solid #dee2e6 !important;
}

.container-input-border > label {
  color: #495057;
  text-transform: uppercase !important;
  position: absolute !important;
  pointer-events: none !important;
  font-size: 11px;
  line-height: 12px;
  letter-spacing: 1.28px !important;
  width: 85%;
  left: 0px;
  text-align: left;
  top: 20%;
  padding: 0px 16px;

  transform: translate(0px, 8px) !important;
  transition: 200ms cubic-bezier(0, 0, 0.2, 1) !important;
}

.container-input-border:hover > label,
.container-input-border > label.active {
  transform: translate(0px, 8px) !important;
  transition: 200ms cubic-bezier(0, 0, 0.2, 1) !important;
  font-size: 8px;
  top: 0;
}

.container-input-border > input,
.container-input-border > select,
.container-input-border > input:active {
  height: 20px;
  width: 100%;
  color: #495057;
  font-size: 14px;
  border: 0px;
  outline: 0;
  margin-top: 10px;
}

.btn-delete-promo-code {
  height: 47px;
  border: 0px;
  width: 100px;
  cursor: pointer;
  background: none;
}

.btn-add-promo-code {
  font-size: 14px !important;
  line-height: 20px !important;
  display: flex !important;
  align-items: center !important;
  background: none;
  border: 0px;
  outline: 0px;
  color: #484c3d;
  margin: 20px 0px;
  gap: 10px;
}

@media (min-width: 768px) {
  .title-1 {
    font-size: 14px !important;
    line-height: 14px !important;
  }

  .container-controler-age {
    height: 74px !important;
    padding-top: 14.5px !important;
    padding-bottom: 14.5px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .label-guest {
    font-size: 18px !important;
    line-height: 23.4px !important;
  }
}

@media (min-width: 768px) {
  .subcontainer-calendar {
    padding-left: 32px;
    padding-right: 32px;
  }
}

@media (min-width: 348px) {
  .subcontainer-calendar {
    padding-left: 32px;
    padding-right: 32px;
    padding-bottom: 100px;
  }
}

/********************cards room*********************************/

.card {
  position: relative !important;
  overflow: hidden !important;
  width: 100% !important;
  text-align: left !important;
  max-height: 600px !important;
  display: flex !important;
  flex-direction: column !important;
  box-sizing: border-box !important;
  border-radius: 4px !important;
  box-shadow: 0px 4px 4px 0px rgba(33, 37, 41, 0.16);
  cursor: pointer !important;
  margin-bottom: 16px !important;
  color: rgba(73, 80, 83, 1);
}

.card > img {
  border-top-left-radius: 4px !important;
  border-top-right-radius: 4px !important;
  width: 100% !important;
  background-color: #f0f2f4 !important;
  height: 240px !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.card > .container-info {
  padding: 12px 16px 16px !important;
  bottom: 0px !important;
  background-color: rgba(255, 255, 255, 1) !important;
  width: 93% !important;
  display: flex !important;
  flex-direction: column !important;
  line-height: 0 !important;
}

.title-card {
  font-size: 18px !important;
  line-height: 21.6px !important;
  letter-spacing: 0.18px !important;
  font-weight: 400 !important;
  padding-right: 24px;
  margin: 0px;
}

.leyend-card {
  font-weight: 450 !important;
  letter-spacing: 0.3px !important;
  font-size: 10px !important;
  line-height: 14px !important;
}

.price-card {
  font-size: var(--sb-font-size-sm, 14px) !important;
  line-height: 14.56px !important;
  font-weight: 300 !important;
  letter-spacing: 0.3px !important;
}

.price-card > strong {
  font-size: 20px !important;
  line-height: 28px !important;
  margin-left: 4px !important;
}

.description-card {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
  font-weight: 400 !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  letter-spacing: 0.14px !important;
  max-height: 4.2em !important;
}

.card-data-guest {
  font-size: 14px !important;
  line-height: 20px !important;
  text-transform: uppercase;
  color: #495057;
}

.status-bar {
  padding: 4px 32px 16px 32px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 16px !important;
  position: fixed;
  z-index: 1050;
  width: 100%;
  top: 0px;
}

a {
  color: rgba(73, 80, 83, 0.7);
  text-decoration: none;
}

.link-return {
  text-decoration: underline;
  text-transform: uppercase;
  font-size: 14px;
  color: #212529;
}
