@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");

/* CSS retirado do single-hotel.php */
.dropbtn {
  color: white;
  padding: 4px;
  font-size: 16px;
  border: none;
  cursor: pointer;
  width: 100%;
  text-align: left;
  position: relative;
}
.dropdown {
  position: relative;
  display: inline-block;
}
.dropdown-content {
  display: none;
  position: absolute;
  top: 2.8rem;
  background-color: #f1f1f1;
  min-width: 100%;
  overflow: auto;
  box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
  z-index: 1;
}
.dropdown-content a {
  color: black;
  padding: 10px 14px;
  text-decoration: none;
  display: block;
}
.fm:hover {
  background-color: #f5eada;
}
.show {
  display: block;
}

/* CSS da Pagina */
#disponibilidade {
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #f5eada;
}
.budget {
  padding-top: 160px;
  padding-right: 123px;
  padding-bottom: 80px;
  padding-left: 123px;
}
.section_budget {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
}
.content-budget {
  display: flex;
  flex-direction: column;
  max-width: 1120px;
  width: 100%;
  align-items: center;
  gap: 40px;
}
.title-budget {
  font-family: "Berthold Akzidenz Grotesk", sans-serif;
  font-weight: 400;
  font-style: Extended;
  font-size: 20px;
  leading-trim: NONE;
  line-height: 125%;
  letter-spacing: 0%;
  text-transform: uppercase;
  color: #695643;
}
/* Container do formulário */
:root {
  --brown: #6c4b3f;
  --brown-light: #b0a395;
  --green: #009933;
  --bg: #f9f1e9;
  --white: #fff;
}
body {
  font-family: "Berthold Akzidenz Grotesk", sans-serif;
  font-weight: 400;
  margin: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #2b2b2b;
}
#form-wrap {
  width: 638px;
  background: var(--white);
  border: 1px solid #f9f1e9;
}
/* Abas do topo */
#disponibilidade #progressbar {
  font-family: "akz-ext", sans-serif;
  display: flex !important;
  list-style: none;
  margin: 0;
  padding: 0;
  background: var(--bg);
}
#disponibilidade #progressbar li {
  flex: 1;
  padding: 16px 12px;
  text-align: center;
  font-size: 14px;
  color: var(--brown-light);
  transition: background 0.2s ease, border-color 0.2s ease;
  border-bottom: 1px solid var(--brown-light);
}
#disponibilidade #progressbar li.active {
  background: #ffffff99;
  color: var(--brown);
  border-bottom: 1px solid var(--brown);
}
#disponibilidade #progressbar li.completed {
  color: var(--brown);
  border-bottom: 2px solid var(--green);
}
/* Corpo das etapas */
#disponibilidade .form-step {
  width: 638px;
  min-height: 511px;
  display: none;
  flex-direction: column;
  gap: 24px;
  padding: 48px 80px;
  background: #f9f1e9;
  box-sizing: border-box;
}
#disponibilidade .form-step.active {
  display: flex;
}
#disponibilidade input::placeholder,
#disponibilidade textarea::placeholder {
  color: #b0a395;
}
#disponibilidade label {
  display: block;
  font-family: "akz-ext", sans-serif;
  font-size: 14px;
  margin-bottom: 8px;
  color: #695643;
}
#disponibilidade .label-checkout {
  margin-bottom: 0px;
}
#disponibilidade input,
#disponibilidade select,
#disponibilidade textarea {
  font-family: "akz-ext", sans-serif;
  color: #141414;
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #cdcdcd;
  border-radius: 3px;
  font-size: 16px;
  box-sizing: border-box;
}
#disponibilidade input#name,
#disponibilidade input[type="email"],
#disponibilidade input[type="tel"] {
  height: 48px;
}
#disponibilidade input[type="tel"] {
  padding: 12px 55px;
}
#disponibilidade input:focus,
#disponibilidade select:focus,
#disponibilidade textarea:focus {
  border: 1px solid var(--brown) !important;
  outline: none !important;
}
#disponibilidade textarea {
  min-height: 160px;
}
#disponibilidade input[type="checkbox"] {
  width: 13px;
  height: 13px;
}
#disponibilidade .iti {
  width: 100%;
}
#disponibilidade .actions {
  display: flex;
  justify-content: space-between;
  gap: 24px !important;
  margin-top: 190px !important;
}
#disponibilidade .form-step:nth-of-type(2) .actions {
  margin-top: 24px !important;
}
#disponibilidade .form-step:nth-of-type(3) {
  gap: 48px !important;
}
#disponibilidade .form-step:nth-of-type(3) .actions {
  margin-top: 30px !important;
}
#disponibilidade .action-button {
  font-family: "akz-ext", sans-serif;
  text-transform: uppercase;
  background: #695643;
  width: 100%;
  color: #fff;
  border: none;
  padding: 12px 28px;
  cursor: pointer;
  border-radius: 0px;
  font-size: 12px;
  letter-spacing: 1px;
  font-weight: 400;
}
#disponibilidade .action-button:hover {
  background: #52362e;
}
#disponibilidade .action-button.secondary {
  background: #ffffff00;
  color: #695643;
  border: 1px solid #695643;
}
#disponibilidade .action-button.secondary:hover {
  background: #e6e6e6;
}
/* Mensagem de enviado */
#disponibilidade .sent-message {
  display: none;
  text-align: center;
  margin-top: 24px;
  padding: 20px;
}
#disponibilidade .sent-message h2 {
  font-family: "akz-ext", sans-serif;
  color: #695643;
  font-size: 20px;
  font-weight: 400;
  text-transform: uppercase;
  margin-bottom: 16px;
}
#disponibilidade .sent-message p {
  font-family: "akz-ext", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 150%;
  text-align: center;
  color: #404040;
  width: 382px;
  margin: auto;
}
#disponibilidade .form-message {
  display: none;
  width: 100%;
  padding: 16px 20px;
  margin-bottom: 20px;
  border-radius: 6px;
  font-family: "Berthold", Arial, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  text-align: center;
  animation: slideIn 0.3s ease-out;
}
/* MOBILE ADJUSTMENTS */
@media (max-width: 768px) {
  .budget {
    padding: 60px 20px;
    /* reduzido */
  }

  .content-budget {
    max-width: 100%;
    padding: 0 10px;
    gap: 24px;
  }

  .title-budget {
    font-size: 16px;
    text-align: center;
  }

  #form-wrap {
    width: 100%;
    /* ocupa toda a largura disponível */
    border: none;
    /* remove borda se quiser no mobile */
  }

  #disponibilidade #progressbar {
    flex-direction: column;
    /* abas ficam empilhadas */
  }

  #disponibilidade #progressbar li {
    font-size: 14px;
    padding: 12px;
  }

  #disponibilidade .form-step {
    width: 100%;
    min-height: auto;
    padding: 24px 20px;
    gap: 24px;
  }

  #disponibilidade textarea {
    min-height: 120px;
  }

  #disponibilidade .actions {
    flex-direction: column;
  }

  #disponibilidade .action-button {
    width: 100%;
  }
}
@media (max-width: 480px) {
  .budget {
    padding: 40px 16px;
  }

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

  #disponibilidade label {
    font-size: 12px;
  }

  #disponibilidade input,
  #disponibilidade select,
  #disponibilidade textarea {
    font-size: 13px;
    padding: 10px 12px;
  }

  #disponibilidade .action-button {
    font-size: 13px;
    padding: 10px 16px;
  }
}
/* Animação de entrada */
@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Responsivo */
@media (max-width: 768px) {
  #disponibilidade .form-message {
    padding: 14px 16px;
    font-size: 14px;
    margin-bottom: 16px;
  }
}
@media (max-width: 480px) {
  #disponibilidade .form-message {
    padding: 12px 14px;
    font-size: 13px;
    border-radius: 4px;
  }
}

/* END - CSS retirado do single-hotel.php */
.single-hotel .hover\:bg-transparent:hover {
  color: #695643;
}
#espacos .item .col-span-6 {
  padding-left: 10px;
}

.videos-hotel {
  margin-bottom: 80px;
}
.videos-hotel .container {
  max-width: 100%;
}
.single-video {
  padding: 0 24px;
}
.single-video .video-item {
  width: 1216px !important;
  height: 421px !important;
  max-width: 100%;
  max-height: 421px;
}

/* Área geral do carrossel */
.video-carousel {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  margin: 0 auto;
  /* 🔥 Remove qualquer overflow que possa afetar o espaçamento */
  overflow: visible;
}

/* Ajuste adicional para o swiper */
.swiper {
  width: 100%;
  padding: 20px 0;
  /* 🔥 Remove TODOS os paddings laterais */
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  /* Garante que não há overflow escondido */
  overflow: visible;
}

.swiper-wrapper {
  align-items: center;
  /* 🔥 Remove qualquer transformação que possa afetar o espaçamento */
  transition-timing-function: ease-out;
}

/* 🔥 SLIDES COM ESPAÇAMENTO CORRETO */
.video-carousel .swiper-slide {
  width: 596px !important;
  min-width: 596px !important;
  height: 421px !important;
  min-height: 421px !important;
  flex-shrink: 0 !important;
  transition: transform 0.3s ease, opacity 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  /* O Swiper já gerencia o margin-right automaticamente com spaceBetween */
}

/* Slide ativo (central) destacado */
.video-carousel .swiper-slide-active {
  opacity: 1;
  z-index: 2;
}
.video-carousel .swiper-slide-next,
.video-carousel .swiper-slide-prev {
  opacity: 1;
}

/* Container interno do vídeo */
.video-item {
  width: 100% !important;
  height: 100% !important;
  max-width: 596px;
  max-height: 421px;
  overflow: hidden;
  list-style: none;
}

/* Estilo para a imagem do thumbnail */
.video-thumbnail {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.video-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-width: 596px;
  min-height: 421px;
}

/* Ajuste do player ou thumbnail */
.video-container {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

/* Overlay do play button */
.play-icon-overlay,
.video-container .absolute {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
  cursor: pointer;
  z-index: 40;
  transition: all 0.3s ease;
}

.play-icon-overlay:hover,
.video-container .absolute:hover {
  background: rgba(0, 0, 0, 0.7);
}

/* Ícone de play */
.play-icon-overlay svg,
.video-container .absolute svg {
  width: 80px;
  height: 80px;
  opacity: 0.9;
  transition: transform 0.3s ease;
  pointer-events: none;
}

.play-icon-overlay:hover svg,
.video-container .absolute:hover svg {
  transform: scale(1.1);
}

.swiper-pagination {
  bottom: 0 !important;
  margin-bottom: -30px;
}
.swiper-pagination .swiper-pagination-bullet {
  background: #b8b8b8;
  opacity: 1;
  width: 8px;
  height: 8px;
}
.swiper-pagination .swiper-pagination-bullet-active {
  background: #695643;
}

/* MODAL STYLES - CRÍTICO PARA FUNCIONAMENTO */
.video-modal {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  background: rgba(0, 0, 0, 0.95) !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 999999 !important;
  padding: 20px;
}

/* Quando não tem a classe hidden, mostrar */
.video-modal:not(.hidden) {
  display: flex !important;
}

/* Container da modal */
.video-modal-container {
  position: relative;
  width: 90vw;
  max-width: 1200px;
  margin: 0 auto;
}

/* Conteúdo da modal - proporção 16:9 */
.video-modal-content {
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  position: relative;
  background: #000;
  border-radius: 8px;
  overflow: hidden;
}

.video-modal-content iframe {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border: none !important;
  border-radius: 8px;
}

/* Botão de fechar mais visível */
#closeModal {
  position: absolute;
  top: -60px;
  right: 0;
  background: rgba(0, 0, 0, 0.8);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 28px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  cursor: pointer;
  z-index: 1000000;
  transition: all 0.3s ease;
  font-family: Arial, sans-serif;
  line-height: 1;
}

#closeModal:hover {
  background: rgba(0, 0, 0, 1);
  border-color: rgba(255, 255, 255, 0.6);
  transform: scale(1.1);
}

/* Ajuste para o container do vídeo embed (se usado) */
.video-embed {
  width: 100%;
  height: 100%;
}

.video-embed iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* Esconder scrollbar quando modal está aberta */
body.modal-open {
  overflow: hidden !important;
}

/* RESPONSIVIDADE COM ESPAÇAMENTO CORRETO */
@media (max-width: 768px) {
  .video-modal-container {
    width: 95vw;
  }

  #closeModal {
    width: 40px;
    height: 40px;
    font-size: 24px;
    top: -50px;
  }
}

/* Responsividade do carousel mantendo 24px */
@media (max-width: 1200px) {
  .video-carousel .swiper-slide {
    width: 500px !important;
    min-width: 500px !important;
    height: 350px !important;
  }
  .video-thumbnail img {
    min-width: 500px !important;
    min-height: 350px !important;
  }
}

@media (max-width: 768px) {
  .video-carousel .swiper-slide {
    width: 400px !important;
    min-width: 400px !important;
    height: 280px !important;
  }
  .video-thumbnail img {
    min-width: 400px !important;
    min-height: 280px !important;
  }
  .play-icon-overlay svg,
  .video-container .absolute svg {
    width: 60px;
    height: 60px;
  }
}

@media (max-width: 576px) {
  .video-item {
    width: 100% !important;
    height: 290px !important;
  }
  .video-carousel .swiper-slide {
    width: 320px !important;
    min-width: 320px !important;
    height: 290px !important;
    min-height: 290px !important;
  }
  .video-carousel .swiper-slide .video-thumbnail img {
    min-width: 320px !important;
    min-height: 290px !important;
  }
  .single-video .video-item {
    height: 300px !important;
    max-width: 100%;
    max-height: 300px;
    margin-bottom: 0 !important;
  }
}

@media (max-width: 480px) {
  .video-carousel .swiper-slide {
    width: 280px !important;
    min-width: 280px !important;
    height: 225px !important;
  }
  .video-thumbnail img {
    min-width: 280px !important;
    min-height: 225px !important;
  }
  .play-icon-overlay svg,
  .video-container .absolute svg {
    width: 50px;
    height: 50px;
  }
}

/* Adriano's CSS */
#disponibilidade .single-hotel #content #hotel-submenu {
  --tw-bg-opacity: 1;
  background-color: #695643;
}
/* --- Estilos do Select - Form - lib select2 --- */
.select2-container--default {
  width: 100% !important;
}
.select2-container--default .select2-selection--single {
  display: flex !important;
  align-items: center !important;
  height: 40px !important;
  background-color: #fff !important;
  border: 1px solid #cdcdcd !important;
  border-radius: 2px !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  font-family: "akz-ext", sans-serif;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  height: 24px !important;
  position: absolute !important;
  top: 12px !important;
  right: 0px !important;
  width: 20px !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border: none !important;
  content: none !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow::after {
  font-family: "Font Awesome 6 Free", "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f078";
  color: #695643;
  font-size: 16px;
  position: absolute;
  top: 30%;
  right: 15px;
  transform: translateY(-50%);
}
.select2-container--default.select2-container--focus
  .select2-selection--single {
  border-color: #695643 !important;
  font-family: "akz-ext", sans-serif;
}
.select2-container--default
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  font-family: "akz-ext", sans-serif;
  color: #404040;
  font-weight: 400;
  padding: 0 12px;
}
.select2-container--default .select2-dropdown {
  position: relative;
  top: 5px;
  border: 1px solid #695643;
  border-radius: 2px;
}
.select2-container--open .select2-dropdown--below {
  border-top: 1px solid #695643 !important;
}
.select2-container--default .select2-results > .select2-results__options {
  font-family: "akz-ext", sans-serif;
  color: #404040 !important;
  font-weight: 400;
}
.select2-container--default .select2-results > .select2-results__options li {
  padding: 12px;
  color: #695643;
}
.select2-container--default
  .select2-results
  > .select2-results__options
  li:hover,
.select2-container--default
  .select2-results__option--highlighted.select2-results__option--selectable {
  color: #404040 !important;
  background-color: #f5eada !important;
}
.select2-container--default .select2-results__options::-webkit-scrollbar {
  width: 10px !important;
  height: 116px !important;
}
.select2-container--default
  .select2-results__options::-webkit-scrollbar-button {
  width: 0 !important;
  height: 0 !important;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-thumb {
  background-color: #b0a395 !important;
  border-radius: 4px !important;
  height: 116px !important;
  border: 2px solid #f1f1f1 !important;
  background-clip: padding-box !important;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-track {
  background-color: #f1f1f1 !important;
  width: 12px !important;
  margin: 0 12px !important;
}
.select2-container--default .select2-results__option--selected {
  position: relative;
  background-color: #f5eada !important;
}
.select2-container--default .select2-results__option--selected::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background-image: url(../images/Icon-check.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-track {
  background-color: #f1f1f1 !important;
  width: 12px !important;
  margin: 0 12px !important;
}
.select2-container--default .select2-results__option--selected {
  position: relative;
  background-color: #f5eada !important;
}
.select2-container--default .select2-results__option--selected::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background-image: url(../images/Icon-check.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
/* --- END Estilos do Select - Form - lib select2 --- */

/* --- Estilos do Input Data - Form --- */
form .calendar {
  position: relative;
}
form .calendar .form-control {
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  background-color: #fff;
  border: 1px solid #cdcdcd;
  border-radius: 2px;
  box-sizing: border-box;
  cursor: pointer;
  color: #404040;
  font-size: 16px;
  font-family: "akz-ext", sans-serif;
  padding-right: 40px;
  -webkit-appearance: none !important;
}
form .calendar .form-control::placeholder {
  color: #b0a395;
}
form .calendar .form-control:focus {
  border: 1px solid #695643;
}
form .calendar::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  margin-top: 12px;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background-image: url(../images/calendar.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 2;
  pointer-events: none;
}
.flatpickr-calendar {
  width: 332px !important;
  padding: 0 10px !important;
  margin-top: -10px;
}
.flatpickr-calendar.animate.open {
  border: 1px solid #695643;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
  display: none;
}
.flatpickr-calendar .flatpickr-months .flatpickr-current-month {
  left: 26px;
  font-size: 14px;
  color: #49454f;
  font-weight: 500;
  width: 100%;
  text-align: left;
}
.flatpickr-calendar
  .flatpickr-months
  .flatpickr-current-month
  .numInputWrapper:hover
  span {
  right: -6px;
}
.flatpickr-calendar
  .flatpickr-months
  .flatpickr-current-month
  select
  .flatpickr-monthDropdown-month {
  color: #695643;
  transition: all 0.3s ease;
}
.flatpickr-calendar .flatpickr-months .flatpickr-monthSelect option:hover {
  background-color: #695643;
  color: #fff;
  transition: all 0.3s ease;
}
.flatpickr-calendar .flatpickr-weekdaycontainer .flatpickr-weekday,
.flatpickr-calendar .dayContainer .flatpickr-day {
  color: #1d1b20;
  font-size: 16px;
  font-weight: 400;
  font-family: "Roboto", sans-serif;
}
.flatpickr-calendar .dayContainer .flatpickr-day.flatpickr-disabled {
  opacity: 0.5;
}
.flatpickr-calendar .dayContainer .flatpickr-day.nextMonthDay,
.flatpickr-calendar .dayContainer .flatpickr-day.prevMonthDay {
  opacity: 0;
}
.flatpickr-calendar .dayContainer .flatpickr-day.today {
  border: 1px solid #695643;
  background-color: transparent;
  color: #695643;
}
.flatpickr-calendar .dayContainer .flatpickr-day:hover,
.flatpickr-calendar .dayContainer .flatpickr-day.today:hover {
  background-color: #695643;
  color: #fff;
}
.flatpickr-calendar .dayContainer .flatpickr-day.selected {
  background: #695643;
  border-color: #695643;
  color: #fff;
}
#event-date[type="text"].flatpickr-input.form-control {
  -webkit-appearance: none !important;
}

/* Etapa de Observações */
#disponibilidade #event-summary {
  display: flex;
}
#disponibilidade #event-summary .event-summary-item:first-of-type {
  margin-right: 71px;
}
#disponibilidade #event-summary .event-summary-item p {
  color: #404040;
  font-size: 12px;
  font-weight: 400;
  font-family: "akz-ext", sans-serif;
}
#disponibilidade #event-summary .event-summary-item span {
  color: #695643;
  font-family: "akz-ext", sans-serif;
  font-size: 14px;
  font-weight: 400;
}
#disponibilidade .observation span {
  opacity: 0.5;
  margin-left: 10px;
}

/* Validação dos inputs do form */
/* Mensagem de erro abaixo do input */
#disponibilidade .error-message {
  position: absolute;
  display: none; /* Oculta por padrão */
  color: #ff0000;
  padding: 0 !important;
  text-align: left !important;
  margin: 0 0px 0px 20px !important;
  margin-top: 4px !important;
  font-family: "akz-ext", sans-serif;
  font-size: 14px !important;
  font-weight: 500 !important;
}
#disponibilidade .error-message::before {
  content: "";
  position: absolute;
  left: -20px;
  top: 45%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background-image: url(../images/error_field.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* Mostra a mensagem quando o form-step tem a classe error */
#disponibilidade .form-step.error .error-message {
  display: block;
}
#disponibilidade .form-step.active.error .calendar::after {
  margin-top: 0 !important;
}

/* Estilização do loading como overlay */
/* Estilo adicional para loading e sucesso (opcional, para centralizar) */
.hidden {
  display: none !important;
}
#disponibilidade form .aguarde {
  background: #f9f1e9;
  height: 500px;
}
#disponibilidade form .aguarde #aguarde-screen {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  padding-top: 180px;
}
#disponibilidade form .aguarde #aguarde-screen.active {
  display: flex !important;
  position: relative;
  top: 0;
  left: 0;
  z-index: 1000;
  justify-content: center;
  align-items: center;
}
#disponibilidade form .aguarde #aguarde-screen p {
  font-family: "akz-ext", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  text-align: center;
  color: #404040;
  width: 382px;
  margin: 24px auto;
}
#disponibilidade form .aguarde #aguarde-screen .spinner {
  border: 5px solid #f5eada;
  border-top: 5px solid #6c4b3f;
  border-radius: 50%;
  width: 45px;
  height: 45px;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

#disponibilidade #loading,
#disponibilidade #sent-message,
#disponibilidade #sentError-message {
  padding: 0;
  background-color: #f9f1e9;
  margin: 0;
  width: 100%;
  height: 500px;
}
#disponibilidade #loading {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5); /* Fundo semi-transparente */
  justify-content: center;
  align-items: center;
  z-index: 1000; /* Garante que fique acima de tudo */
}
#disponibilidade #sent-message .message-default,
#disponibilidade #sentError-message .message-default {
  padding-top: 180px;
}
#disponibilidade #loading.active {
  display: flex;
}
/* Ajuste para progressbar em telas de loading/sucesso */
#disponibilidade #loading.active + #progressbar,
#disponibilidade #sent-message + #progressbar {
  margin-top: 20px; /* Espaçamento se necessário */
}

/* Estilo para campos com erro */
/* 1. Esconde a mensagem de erro por padrão */
#disponibilidade .error-message {
  display: none;
  color: #ff0000; /* Cor da notificação (marrom) */
  font-size: 11px;
  margin-top: 4px;
  font-family: "akz-ext", sans-serif;
}
/* 3. Estiliza o campo e mostra a mensagem de erro quando o grupo tem a classe 'has-error' */
#disponibilidade .form-group.has-error input:not([type="checkbox"]),
#disponibilidade .form-group.has-error select {
  border: 1px solid #ff0000 !important; /* Borda de destaque no input/select */
  outline: none !important;
}
#disponibilidade .form-group.has-error .error-message {
  display: block; /* Torna a mensagem de erro visível */
}
/* Para o Select2 (Tipo de Evento), que precisa de estilo extra */
#disponibilidade
  .form-group.has-error
  .select2-container--default
  .select2-selection--single {
  border: 1px solid #ff0000 !important;
}

#hotel-eventos #caracteristicas h4 {
  color: #695643;
}
#hotel-eventos #caracteristicas .description-text {
  color: #404040;
}