
:root {
    --azul: #354b95;
    --vermelho: #bf3734;
    --verde-whatsapp: #61CE70;
}
* { box-sizing: border-box; margin: 0; padding: 0}

/*begin menu*/
.mobile_menu_bar:before, .mobile_menu_bar:after, #top-menu li.current-menu-ancestor>a, #top-menu li.current-menu-item>a {
    color: #222;
}
.et_mobile_menu {
    border-top: 3px solid #222;
}
/*end menu*/
.et-pb-contact-message {
    color: #ffffff;
    text-align:center;
}
input.input.et_pb_contact_captcha {
    font-size: 23px!important;
    max-width: 60px!important;
    padding: 10px;
}
.et_pb_contact p input, .et_pb_contact p textarea { color:#ffffff!important }
.grecaptcha-badge { 
    visibility: hidden!important;
    width: 0!important;
}

.grid-400 {
    display:grid;
    grid-template-columns: repeat(auto-fit,minmax(400px, 1fr));
    gap:20px;
}
.grid-300 {
    display:grid;
    grid-template-columns: repeat(auto-fit,minmax(300px, 1fr));
    gap:20px;
}
.grid-200 {
    display:grid;
    grid-template-columns: repeat(auto-fit,minmax(200px, 1fr));
    gap:20px;
}

/* HIDE WOOCOMMERCE CHART ICON */
.et-cart-info { 
    display:none!important; 
}

#main-footer {
    background-color: #222;
}
#footer-widgets .footer-widget:first-child {
    text-align:center!important;
}
img.wp-image-8 {
    max-width:150px!important;
}
.block {
    display:block;
    color:#222222;
    margin-bottom:20px;
}
#logo {
    height: 90px!important;
}

#top-menu a,
.et_mobile_menu li a {
    text-transform:uppercase!important;
}

.price,.input-text.qty.text {
    display:none!important;
}



/* ─── Catálogo de Estúdios (/studios/) ─────────────────────────── */
.viga-catalog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 28px;
    padding: 8px 0 32px;
}
.viga-card {
    background: #262626;
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
/* Sobrescreve max-width:370px herdado do CSS inline do widget HTML */
.viga-catalog-grid .viga-card,
.viga-carousel-track .viga-card {
    max-width: none;
    min-width: 0;
    flex-shrink: 0;
}
.viga-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.45);
}
.viga-card > a img,
.viga-card img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}
.viga-card-body {
    padding: 18px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.viga-rating {
    font-size: 13px;
    font-weight: 600;
    color: #bf9000;
    display: flex;
    align-items: center;
    gap: 4px;
}
.viga-badge {
    background: rgba(191,144,0,0.15);
    border: 1px solid #bf9000;
    color: #bf9000;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 4px;
    margin-left: 6px;
    display: inline-block;
    vertical-align: middle;
}
.viga-card-title {
    font-size: 17px;
    font-weight: 700;
    color: #fff;
    margin: 0;
    line-height: 1.3;
}
.viga-card-info {
    font-size: 13px;
    color: #aaa;
    margin: 0;
}
.viga-amenities {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.viga-amenities li {
    background: #1a1a1a;
    color: #ccc;
    font-size: 12px;
    padding: 4px 10px;
    border-radius: 20px;
}
.viga-price {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    margin: auto 0 0;
    padding-top: 14px;
    border-top: 1px solid #333;
}
/* Dois botões por card */
.viga-card-actions {
    display: flex;
    gap: 10px;
    margin-top: 6px;
}
.viga-btn {
    display: block;
    padding: 11px 0;
    border-radius: 6px;
    text-align: center;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.3px;
    text-decoration: none !important;
    transition: background 0.2s ease;
    flex: 1;
}
.viga-btn.viga-btn-conhecer,
a.viga-btn-conhecer {
    background: #2d6a4f !important;
    color: #fff !important;
}
.viga-btn.viga-btn-conhecer:hover,
a.viga-btn-conhecer:hover { background: #235439 !important; color: #fff !important; }
.viga-btn.viga-btn-reservar,
a.viga-btn-reservar {
    background: #bf9000 !important;
    color: #fff !important;
}
.viga-btn.viga-btn-reservar:hover,
a.viga-btn-reservar:hover { background: #a07800 !important; color: #fff !important; }

/* ─── Carrossel de Estúdios (simplificado) ─────────────────────── */
.viga-carousel-wrapper {
    position: relative;
    overflow: hidden;
    padding: 8px 0 32px;
}
.viga-carousel-track {
    display: flex;
    gap: 24px;
    transition: transform 0.35s ease;
}
.viga-carousel-track .viga-card { flex: 0 0 calc(33.333% - 16px); }
.viga-carousel-btn {
    position: absolute;
    top: calc(50% - 16px);
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #262626;
    border: 2px solid #bf9000;
    color: #bf9000;
    font-size: 18px;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}
.viga-carousel-btn:hover { background: #bf9000; color: #fff; }
.viga-carousel-btn.prev { left: 0; }
.viga-carousel-btn.next { right: 0; }

/* ─── HBS — Step indicators, calendário e modais (paleta Viga) ── */

/* Círculos numerados dos steps */
.hbs-main-navigation-default > ul > li > a > span:first-child {
    border-color: #bf9000 !important;
    color: #bf9000 !important;
}
.hbs-main-navigation-default > ul > li.hbs-state-selected > a > span:first-child,
.hbs-main-navigation-default > ul > li.hbs-state-completed > a > span:first-child {
    background-color: #bf9000 !important;
    border-color: #bf9000 !important;
    color: #000 !important;
}
/* Texto abaixo dos círculos (labels) */
.hbs-main-navigation-default > ul > li > a > span:last-child {
    color: rgba(255,255,255,0.65) !important;
}
.hbs-main-navigation-default > ul > li.hbs-state-selected > a > span:last-child,
.hbs-main-navigation-default > ul > li.hbs-state-completed > a > span:last-child {
    color: #bf9000 !important;
}
.hbs-main-navigation-default > ul > li > a::before {
    background-color: rgba(191,144,0,0.35) !important;
}

/* Botão próximo step */
.hbs-main .hbs-button-next-step {
    background-color: #bf9000 !important;
    border-color: #bf9000 !important;
    color: #000 !important;
}
.hbs-main .hbs-button-next-step:hover { background-color: #a07800 !important; }

/* Calendário jQuery UI */
#ui-datepicker-div {
    background: #262626 !important;
    border: 1px solid #444 !important;
    border-radius: 8px !important;
    color: #fff !important;
}
#ui-datepicker-div .ui-datepicker-header {
    background: #1a1a1a !important;
    border-bottom: 1px solid #444 !important;
    color: #fff !important;
}
#ui-datepicker-div .ui-datepicker-title { color: #fff !important; }
/* Setas de navegação do calendário */
#ui-datepicker-div .ui-datepicker-prev,
#ui-datepicker-div .ui-datepicker-next {
    color: #bf9000 !important;
}
#ui-datepicker-div .ui-datepicker-prev span,
#ui-datepicker-div .ui-datepicker-next span {
    color: #bf9000 !important;
    border-color: transparent #bf9000 transparent transparent !important;
}
#ui-datepicker-div th { color: #aaa !important; font-size: 12px; }
#ui-datepicker-div td a,
#ui-datepicker-div td span { color: #ddd !important; }
#ui-datepicker-div td a:hover { background: #3a3a3a !important; }
#ui-datepicker-div .ui-datepicker-today a,
#ui-datepicker-div td.ui-datepicker-current-day a {
    background-color: #bf9000 !important;
    color: #000 !important;
    border-radius: 50% !important;
}
#ui-datepicker-div td.ui-datepicker-unselectable span { color: #555 !important; }

/* Modal de seleção de hóspedes (guest dialog) */
.hbs-guest-dialog-container .hbs-guest-dialog {
    background: #262626 !important;
    border: 1px solid #444 !important;
    color: #fff !important;
    border-radius: 8px !important;
}
.hbs-guest-dialog-container .hbs-guest-dialog .hbs-guest-dialog-room-header {
    background: #1a1a1a !important;
    color: #fff !important;
    border-radius: 6px 6px 0 0 !important;
}
.hbs-guest-dialog label,
.hbs-guest-dialog-room-content label,
.hbs-guest-dialog-room-content > label > span {
    color: #ddd !important;
}
.hbs-guest-dialog input[type="text"],
.hbs-guest-dialog select {
    background: #1a1a1a !important;
    color: #fff !important;
    border-color: #444 !important;
}
.hbs-guest-dialog .hbs-button-style-2,
.hbs-guest-dialog a.hbs-guest-dialog-room-save {
    background: #bf9000 !important;
    border-color: #bf9000 !important;
    color: #000 !important;
}
.hbs-guest-dialog .hbs-button-style-1 {
    background: #3a3a3a !important;
    border-color: #555 !important;
    color: #ddd !important;
}

/* Selectmenu jQuery UI (dropdown hotel/quarto) */
.ui-selectmenu-menu {
    background: #262626 !important;
    border: 1px solid #444 !important;
    border-radius: 6px !important;
}
.ui-selectmenu-menu .ui-menu-item-wrapper {
    color: #ddd !important;
}
.ui-selectmenu-menu .ui-menu-item-wrapper.ui-state-active {
    background: #3a3a3a !important;
    color: #fff !important;
    border: none !important;
}
.ui-selectmenu-button-closed span.ui-selectmenu-text { color: #fff !important; }
.ui-selectmenu-button { background: #1a1a1a !important; border-color: #444 !important; }

/* Labels dos campos HBS — estilo Airbnb (uppercase, pequeno) */
.hbs-main .hbs-form-field > label,
.hbs-main .hbs-form-field > div > label,
.hbs-main .hbs-form-field .hbs-form-field-label {
    text-transform: uppercase !important;
    font-size: 11px !important;
    letter-spacing: 0.08em !important;
    font-weight: 700 !important;
    color: rgba(255,255,255,0.55) !important;
}

@media (max-width: 900px) {
    .viga-carousel-track .viga-card { flex: 0 0 calc(50% - 12px); }
}
@media (max-width: 680px) {
    .viga-catalog-grid { grid-template-columns: 1fr; }
    .viga-carousel-track .viga-card { flex: 0 0 88%; }
}
/* ─────────────────────────────────────────────────────────────── */

.svg-pulse-whatsapp {
    animation: svg-pulse-whatsapp 2.1s infinite;
  }
  @keyframes svg-pulse-whatsapp {
        0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7);}
       70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(37, 211, 102, 0);}
      100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }
  @-moz-keyframes svg-pulse-whatsapp { 
      0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7);}
       70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(37, 211, 102, 0);}
      100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }
  @-webkit-keyframes svg-pulse-whatsapp { 
      0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7);}
       70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(37, 211, 102, 0);}
      100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }
  
  .svg-pulse-blue {
    animation: svg-pulse-blue 2.1s infinite;
  }
  @keyframes svg-pulse-blue {
        0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0.7);}
       70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(60, 58, 145, 0);}
      100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0);}
  }
  @-moz-keyframes svg-pulse-blue { 
    0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0.7);}
    70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(60, 58, 145, 0);}
   100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0);}
  }
  @-webkit-keyframes svg-pulse-blue { 
    0% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0.7);}
    70% {transform: scale(1);box-shadow: 0 0 0 20px rgba(60, 58, 145, 0);}
   100% {transform: scale(0.9);box-shadow: 0 0 0 0 rgba(60, 58, 145, 0);}
  }

  .pulse-input {
    animation: pulse-input 5s infinite;
  }
  @keyframes pulse-input {
        0% {transform: scale(1);box-shadow: 0 0 0 0 #ffffff;}
       70% {transform: scale(1);box-shadow: 0 0 0 5px rgba(37, 211, 102, 0);}
      100% {transform: scale(1);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }
  @-moz-keyframes pulse-input { 
      0% {transform: scale(1);box-shadow: 0 0 0 0 #ffffff;}
       70% {transform: scale(1);box-shadow: 0 0 0 5px rgba(37, 211, 102, 0);}
      100% {transform: scale(1);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }
  @-webkit-keyframes pulse-input { 
      0% {transform: scale(1);box-shadow: 0 0 0 0 #ffffff;}
       70% {transform: scale(1);box-shadow: 0 0 0 5px rgba(37, 211, 102, 0);}
      100% {transform: scale(1);box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);}
  }