@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800;900&family=Roboto:wght@400;500;700;900&display=swap');
/* =========================================================
   MobyUP - detalhe do imóvel inspirado no padrão marketplace
   Layout clean, header branco e galeria/modal de mídia
   ========================================================= */

:root{
  --upz-bg:#f3f4f6;
  --upz-card:#fff;
  --upz-text:#191f33;
  --upz-muted:#667085;
  --upz-line:#e4e7ec;
  --upz-purple:#6d22e6;
  --upz-blue:#0ea5e9;
  --upz-green:#21a947;
  --upz-radius:16px;
  --upz-shadow:0 10px 28px rgba(16,24,40,.08);
}

body.up_zap_like_body{
  background:var(--upz-bg) !important;
  color:var(--upz-text);
}

body.up_zap_like_body .up_header,
body.up_zap_like_body .up_header_global{
  background:#fff !important;
  color:#111827 !important;
  border-bottom:1px solid #eaecf0;
  box-shadow:0 2px 12px rgba(16,24,40,.04);
}

body.up_zap_like_body .up_header_inner{
  min-height:78px;
}

body.up_zap_like_body .up_logo_img img{
  width:132px;
}

body.up_zap_like_body .up_nav a{
  color:#111827 !important;
  font-weight:800;
}

body.up_zap_like_body .up_nav a:hover{
  color:var(--upz-purple) !important;
}

body.up_zap_like_body .up_icon_link,
body.up_zap_like_body .up_btn_ghost{
  color:var(--upz-purple) !important;
  border:1px solid #7b2ff2 !important;
  background:#fff !important;
}

body.up_zap_like_body .up_btn_primary{
  color:#fff !important;
  background:var(--upz-purple) !important;
  border-color:var(--upz-purple) !important;
  box-shadow:none;
}

.up_zap_detail_main{padding:0 0 60px;}

/* Galeria topo */
.up_zap_gallery{
  position:relative;
  background:#fff;
  border-bottom:1px solid #e9edf3;
}

.up_zap_gallery_grid{
  display:grid;
  grid-template-columns:1.35fr .75fr 1.15fr;
  gap:3px;
  height:390px;
  overflow:hidden;
}

.up_zap_gallery_photo{
  border:0;
  padding:0;
  margin:0;
  display:block;
  overflow:hidden;
  cursor:pointer;
  background:#dfe6ee;
}

.up_zap_gallery_photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .25s ease, filter .25s ease;
}

.up_zap_gallery_photo:hover img{
  transform:scale(1.025);
  filter:brightness(.94);
}

.up_zap_media_buttons{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  display:flex;
  gap:12px;
  z-index:5;
}

.up_zap_media_buttons button{
  border:0;
  background:#fff;
  color:#25324b;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  font-weight:900;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  box-shadow:0 10px 26px rgba(16,24,40,.18);
  cursor:pointer;
}

.up_zap_media_buttons button:hover{
  transform:translateY(-1px);
  color:var(--upz-purple);
}

/* Estrutura principal */
.up_zap_page{
  width:min(1220px, calc(100% - 36px));
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:28px;
  align-items:start;
  padding-top:22px;
}

.up_zap_main_col{min-width:0;}
.up_zap_sidebar{
  position:sticky;
  top:96px;
  display:grid;
  gap:16px;
  z-index:4;
}

.up_zap_breadcrumb{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  font-size:13px;
}

.up_zap_breadcrumb a{
  color:#121826;
  text-decoration:underline;
  font-weight:800;
}

.up_zap_breadcrumb span{color:#98a2b3;}

.up_zap_tags_actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin:0 0 14px;
}

.up_zap_tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.up_zap_tags span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border:1px solid #111827;
  border-radius:8px;
  background:#fff;
  color:#111827;
  font-size:13px;
  font-weight:800;
}

.up_zap_action_links{
  display:flex;
  align-items:center;
  gap:18px;
}

.up_zap_action_links a,
.up_zap_action_links button{
  border:0;
  background:transparent;
  color:#111827;
  font-size:15px;
  font-weight:800;
  text-decoration:underline;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  padding:0;
}

.up_zap_action_links .up_favorito_active,
.up_zap_action_links .btn-favorito-active{
  color:#d92d20;
}

/* Cards */
.up_zap_summary_card,
.up_zap_card,
.up_zap_advertiser_card,
.up_zap_contact_card{
  background:var(--upz-card);
  border:1px solid var(--upz-line);
  border-radius:14px;
  box-shadow:none;
}

.up_zap_summary_card{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  overflow:hidden;
  margin-bottom:18px;
}

.up_zap_summary_text{
  padding:26px;
  border-right:1px solid var(--upz-line);
}

.up_zap_summary_text h1{
  margin:0 0 16px;
  color:#111827;
  font-size:28px;
  line-height:1.25;
  font-weight:900;
  letter-spacing:-.02em;
}

.up_zap_address{
  color:#344054;
  font-weight:700;
  margin:0 0 18px;
}

.up_zap_specs{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  background:#f5f6f8;
  border-radius:10px;
  padding:10px;
  margin:0 0 14px;
}

.up_zap_specs div{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:8px 10px;
}

.up_zap_specs span{
  font-size:12px;
  color:#667085;
}

.up_zap_specs strong{
  color:#25324b;
  font-size:15px;
}

.up_zap_mini_features{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  background:#f5f6f8;
  border-radius:10px;
  padding:10px 12px;
  margin-bottom:16px;
}

.up_zap_mini_features span,
.up_zap_mini_features a{
  color:#1d2939;
  font-size:13px;
  font-weight:800;
  text-decoration:none;
}

.up_zap_publish{
  color:#667085;
  margin:18px 0 0;
  font-size:14px;
  display:flex;
  align-items:center;
  gap:8px;
}

.up_zap_summary_map{
  padding:26px;
}

.up_zap_summary_map h3{
  margin:0 0 12px;
  font-size:26px;
  color:#111827;
  font-weight:900;
}

.up_zap_summary_map p{
  color:#475467;
  margin:0 0 12px;
  font-weight:700;
}

.up_zap_summary_map iframe{
  width:100%;
  height:132px;
  border:0;
  border-radius:10px;
  background:#e7edf5;
}

.up_zap_summary_map button{
  margin-top:12px;
  border:1px solid #111827;
  background:#fff;
  color:#111827;
  min-height:38px;
  padding:0 16px;
  border-radius:999px;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.up_zap_card{
  padding:24px 26px;
  margin-bottom:18px;
}

.up_zap_card h2{
  margin:0 0 18px;
  color:#111827;
  font-size:25px;
  line-height:1.2;
  font-weight:900;
}

.up_zap_values{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.up_zap_values div{
  background:#f7f8fa;
  border-radius:12px;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.up_zap_values span{
  color:#667085;
  font-weight:700;
  font-size:13px;
}

.up_zap_values strong{
  color:#111827;
  font-size:18px;
}

.up_zap_features_tabs{
  display:grid;
  grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--upz-line);
  margin-bottom:18px;
}

.up_zap_features_tabs button{
  border:0;
  background:transparent;
  color:#111827;
  padding:0 0 16px;
  font-weight:900;
  cursor:pointer;
  border-bottom:3px solid transparent;
}

.up_zap_features_tabs button.active{
  color:var(--upz-purple);
  border-bottom-color:var(--upz-purple);
}

.up_zap_features_list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.up_zap_features_list span{
  display:flex;
  align-items:center;
  gap:10px;
  color:#344054;
  font-size:16px;
}

.up_zap_features_list i{
  color:#20b15a;
}

.up_zap_description{
  color:#344054;
  line-height:1.85;
  font-size:16px;
}

.up_zap_phone_line{
  font-weight:800;
  color:#111827;
}

.up_zap_security p{
  display:flex;
  align-items:center;
  gap:12px;
  color:#344054;
}

.up_zap_security a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid #111827;
  border-radius:999px;
  min-height:40px;
  padding:0 18px;
  color:#111827;
  font-weight:900;
  text-decoration:none;
}

/* Sidebar */
.up_zap_advertiser_card{
  display:grid;
  grid-template-columns:58px minmax(0,1fr);
  gap:14px;
  padding:18px;
  margin-top:-72px;
  position:relative;
  z-index:10;
  box-shadow:0 16px 34px rgba(16,24,40,.12);
}

.up_zap_advertiser_logo{
  width:58px;
  height:58px;
  border-radius:10px;
  border:1px solid #e4e7ec;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.up_zap_advertiser_logo img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}

.up_zap_advertiser_logo span{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  background:linear-gradient(135deg,#0ea5e9,#6d22e6);
  font-size:26px;
  font-weight:900;
}

.up_zap_advertiser_info strong{
  color:#111827;
  font-size:15px;
  line-height:1.25;
  display:block;
  text-decoration:underline;
}

.up_zap_advertiser_info i{
  color:#0ea5e9;
}

.up_zap_advertiser_badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:9px;
}

.up_zap_advertiser_badges span{
  background:#f2f4f7;
  border-radius:999px;
  padding:6px 9px;
  color:#344054;
  font-size:12px;
  font-weight:800;
}

.up_zap_contact_card{
  padding:22px;
}

.up_zap_contact_card h2{
  margin:0 0 18px;
  font-size:24px;
  font-weight:900;
  color:#111827;
}

.up_zap_contact_card form{
  display:grid;
  gap:12px;
}

.up_zap_contact_card input,
.up_zap_contact_card textarea,
.up_media_contact input,
.up_media_contact textarea{
  width:100%;
  border:1px solid #d0d5dd;
  background:#fff;
  border-radius:999px;
  min-height:48px;
  padding:0 16px;
  color:#344054;
  outline:none;
  font-size:15px;
}

.up_zap_contact_card textarea,
.up_media_contact textarea{
  border-radius:14px;
  padding:14px 16px;
  min-height:96px;
  resize:vertical;
  line-height:1.5;
}

.up_zap_check{
  display:flex;
  align-items:center;
  gap:8px;
  color:#344054;
  font-size:14px;
}

.up_zap_check input{
  width:18px;
  height:18px;
  min-height:0;
  accent-color:var(--upz-purple);
}

.up_zap_send_btn{
  border:0;
  background:var(--upz-purple);
  color:#fff;
  min-height:50px;
  border-radius:999px;
  font-weight:900;
  font-size:15px;
  cursor:pointer;
}

.up_zap_whatsapp_box{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid var(--upz-line);
}

.up_zap_whatsapp_box h3{
  margin:0 0 12px;
  font-size:20px;
  color:#111827;
}

.up_zap_whatsapp_box p{
  color:#344054;
  font-weight:700;
}

.up_zap_whatsapp_box a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:#22a447;
  color:#fff;
  min-height:48px;
  border-radius:999px;
  text-decoration:none;
  font-weight:900;
}

/* Similares */
.up_zap_similar{
  margin:38px 0 20px;
}

.up_zap_similar h2{
  margin:0 0 22px;
  color:#344054;
  font-size:24px;
  font-weight:900;
}

.up_zap_similar_grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  overflow:hidden;
}

.up_zap_similar_card{
  display:flex;
  flex-direction:column;
  min-width:0;
  background:#fff;
  border:1px solid var(--upz-line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;
  color:#111827;
}

.up_zap_similar_card img{
  width:100%;
  height:150px;
  object-fit:cover;
}

.up_zap_similar_card strong{
  padding:14px 14px 4px;
  font-size:15px;
  line-height:1.35;
}

.up_zap_similar_card span{
  padding:0 14px;
  color:#667085;
  font-size:13px;
}

.up_zap_similar_specs{
  padding:14px;
  display:flex;
  gap:10px;
  color:#667085;
}

.up_zap_similar_specs em{
  font-style:normal;
  font-size:12px;
}

.up_zap_similar_card b{
  padding:0 14px 16px;
  font-size:19px;
}

/* Modal mídia */
.up_media_locked{overflow:hidden;}

.up_media_modal{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#fff;
  display:none;
}

.up_media_modal.open{
  display:block;
}

.up_media_close{
  position:fixed;
  right:28px;
  top:24px;
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  color:var(--upz-purple);
  background:#fff;
  font-size:22px;
  z-index:10002;
  cursor:pointer;
}

.up_media_content{
  height:100vh;
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  grid-template-rows:auto auto minmax(0,1fr);
  column-gap:28px;
  padding:40px 28px 0;
}

.up_media_head{
  grid-column:1 / -1;
  padding-bottom:18px;
}

.up_media_head strong{
  display:block;
  font-size:18px;
  color:#111827;
  margin-bottom:10px;
}

.up_media_specs{
  display:flex;
  flex-wrap:wrap;
  gap:26px;
  color:#344054;
  font-size:16px;
}

.up_media_tabs{
  grid-column:1 / 2;
  display:flex;
  gap:34px;
  border-bottom:1px solid var(--upz-line);
}

.up_media_tabs button{
  border:0;
  background:transparent;
  padding:0 0 14px;
  color:#111827;
  font-weight:900;
  font-size:16px;
  border-bottom:3px solid transparent;
  cursor:pointer;
}

.up_media_tabs button.active{
  color:var(--upz-purple);
  border-bottom-color:var(--upz-purple);
}

.up_media_panel{
  display:none;
  grid-column:1 / 2;
  grid-row:3 / 4;
  min-height:0;
  padding-top:16px;
}

.up_media_panel.active{
  display:block;
}

.up_media_panel iframe{
  width:100%;
  height:calc(100vh - 210px);
  border:0;
  background:#eee;
}

.up_media_photo_stage{
  position:relative;
  height:calc(100vh - 210px);
  background:#111;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.up_modal_photo{
  display:none;
  max-width:100%;
  max-height:100%;
  width:100%;
  height:100%;
  object-fit:contain;
}

.up_modal_photo.active{display:block;}

.up_media_nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:48px;
  height:48px;
  border:0;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  color:#111827;
  font-size:28px;
  z-index:2;
  cursor:pointer;
}

.up_media_nav.prev{left:18px;}
.up_media_nav.next{right:18px;}

.up_media_side{
  grid-column:2 / 3;
  grid-row:2 / 4;
  border-left:1px solid var(--upz-line);
  padding-left:28px;
}

.up_media_contact{
  position:sticky;
  top:84px;
}

.up_media_contact h3{
  margin:0 0 18px;
  font-size:24px;
}

.up_media_contact{
  display:grid;
  gap:12px;
}

.up_media_contact button{
  border:0;
  background:var(--upz-purple);
  color:#fff;
  min-height:50px;
  border-radius:999px;
  font-weight:900;
}

.up_media_contact a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  color:#fff;
  background:#20a845;
  border-radius:999px;
  text-decoration:none;
  font-weight:900;
}

.up_media_empty{
  height:calc(100vh - 210px);
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f2f4f7;
  color:#667085;
  font-weight:800;
}

/* Footer antigo não deve criar topo cinza estranho */
.up_zap_like_body .tail-top,
.up_zap_like_body .main{
  background:transparent !important;
}

/* Responsivo */
@media(max-width:1120px){
  .up_zap_page{grid-template-columns:1fr;}
  .up_zap_sidebar{position:static;}
  .up_zap_advertiser_card{margin-top:0;}
  .up_zap_summary_card{grid-template-columns:1fr;}
  .up_zap_summary_text{border-right:0;border-bottom:1px solid var(--upz-line);}
  .up_media_content{grid-template-columns:1fr;padding:24px 18px;}
  .up_media_side{display:none;}
}

@media(max-width:760px){
  .up_zap_gallery_grid{height:300px;grid-template-columns:1fr;}
  .up_zap_gallery_photo:not(.up_zap_gallery_big){display:none;}
  .up_zap_media_buttons{left:12px;right:12px;transform:none;overflow:auto;justify-content:flex-start;}
  .up_zap_media_buttons button{flex:0 0 auto;}
  .up_zap_page{width:calc(100% - 22px);}
  .up_zap_tags_actions{align-items:flex-start;flex-direction:column;}
  .up_zap_specs,.up_zap_values,.up_zap_features_list,.up_zap_similar_grid{grid-template-columns:1fr;}
  .up_zap_summary_text h1{font-size:24px;}
  body.up_zap_like_body .up_header_inner{min-height:72px;}
}

@media(max-width:520px){
  .up_zap_media_buttons button{font-size:13px;padding:0 13px;}
  .up_zap_card,.up_zap_summary_text,.up_zap_summary_map,.up_zap_contact_card,.up_zap_advertiser_card{padding:18px;}
}


/* =========================================================
   Ajuste fino de tipografia do detalhe
   Referência: VivaReal/Zap - H1 com Poppins, peso menor e desenho mais limpo
   ========================================================= */

body.up_zap_like_body,
body.up_zap_like_body input,
body.up_zap_like_body textarea,
body.up_zap_like_body button,
body.up_zap_like_body select {
    font-family: "Poppins", "Roboto", Arial, Helvetica, sans-serif !important;
}

/* H1 principal do imóvel */
.up_zap_summary_text h1 {
    font-family: "Poppins", "Roboto", Arial, Helvetica, sans-serif !important;
    font-size: 25px !important;
    line-height: 1.24 !important;
    font-weight: 600 !important;
    letter-spacing: -0.35px !important;
    color: #111827 !important;
    margin: 0 0 16px !important;
}

/* Títulos dos blocos: Localização, Valores, Características, Contatar anunciante */
.up_zap_summary_map h3,
.up_zap_card h2,
.up_zap_contact_card h2,
.up_zap_whatsapp_box h3 {
    font-family: "Poppins", "Roboto", Arial, Helvetica, sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: -0.25px !important;
    color: #111827 !important;
}

/* Textos e labels mais próximos do visual limpo da referência */
.up_zap_specs span,
.up_zap_values span,
.up_zap_breadcrumb,
.up_zap_tags span,
.up_zap_action_links a,
.up_zap_action_links button {
    font-family: "Roboto", "Poppins", Arial, Helvetica, sans-serif !important;
}

/* Evita aparência pesada nos valores e cards */
.up_zap_specs strong,
.up_zap_values strong {
    font-family: "Roboto", "Poppins", Arial, Helvetica, sans-serif !important;
    font-weight: 700 !important;
}

/* Mobile */
@media(max-width:760px){
    .up_zap_summary_text h1 {
        font-size: 23px !important;
        line-height: 1.28 !important;
    }
}


/* =========================================================
   Correção galeria topo + tipografia dos botões de mídia
   ========================================================= */

/* Corrige imagens ficando achatadas/como faixa fina no topo */
.up_zap_gallery {
    min-height: 390px !important;
    background: #f3f4f6 !important;
    overflow: visible !important;
}

.up_zap_gallery_grid {
    width: 100% !important;
    height: 390px !important;
    min-height: 390px !important;
    max-height: 390px !important;
    display: grid !important;
    grid-template-columns: 1.35fr .75fr 1.15fr !important;
    gap: 3px !important;
    overflow: hidden !important;
    background: #e9edf3 !important;
}

.up_zap_gallery_photo {
    width: 100% !important;
    height: 390px !important;
    min-height: 390px !important;
    max-height: 390px !important;
    display: block !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 0 !important;
    background: #dfe6ee !important;
    overflow: hidden !important;
}

.up_zap_gallery_photo img {
    display: block !important;
    width: 100% !important;
    height: 390px !important;
    min-height: 390px !important;
    max-height: 390px !important;
    object-fit: cover !important;
    object-position: center center !important;
    border: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Botões Fotos/Vídeo/Mapa/Tour com tipografia mais próxima da referência */
.up_zap_media_buttons {
    bottom: -28px !important;
    gap: 10px !important;
}

.up_zap_media_buttons button {
    font-family: "Roboto", "Poppins", Arial, Helvetica, sans-serif !important;
    min-height: 48px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #283247 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: -0.1px !important;
    box-shadow: 0 10px 26px rgba(16,24,40,.16) !important;
}

.up_zap_media_buttons button i {
    font-size: 18px !important;
    color: #344054 !important;
}

.up_zap_media_buttons button:hover {
    color: #6d22e6 !important;
    transform: translateY(-1px) !important;
}

/* Empurra o conteúdo abaixo para compensar os botões sobrepostos */
.up_zap_page {
    padding-top: 58px !important;
}

/* Mantém H1 limpo e mais parecido com a referência */
.up_zap_summary_text h1 {
    font-family: "Poppins", "Roboto", Arial, Helvetica, sans-serif !important;
    font-size: 24px !important;
    line-height: 1.25 !important;
    font-weight: 600 !important;
    letter-spacing: -0.3px !important;
}

/* Títulos internos um pouco menos pesados */
.up_zap_summary_map h3,
.up_zap_card h2,
.up_zap_contact_card h2 {
    font-family: "Poppins", "Roboto", Arial, Helvetica, sans-serif !important;
    font-size: 24px !important;
    line-height: 1.25 !important;
    font-weight: 600 !important;
    letter-spacing: -0.25px !important;
}

/* Responsivo */
@media(max-width: 760px) {
    .up_zap_gallery,
    .up_zap_gallery_grid,
    .up_zap_gallery_photo,
    .up_zap_gallery_photo img {
        height: 300px !important;
        min-height: 300px !important;
        max-height: 300px !important;
    }

    .up_zap_gallery_grid {
        grid-template-columns: 1fr !important;
    }

    .up_zap_gallery_photo:not(.up_zap_gallery_big) {
        display: none !important;
    }

    .up_zap_media_buttons {
        bottom: -24px !important;
        left: 12px !important;
        right: 12px !important;
        transform: none !important;
        overflow-x: auto !important;
        justify-content: flex-start !important;
    }

    .up_zap_media_buttons button {
        flex: 0 0 auto !important;
        min-height: 44px !important;
        padding: 0 16px !important;
        font-size: 14px !important;
    }

    .up_zap_page {
        padding-top: 54px !important;
    }
}


/* =========================================================
   Correção do botão Favoritar no detalhe
   Volta ao padrão discreto da referência, sem bloco vermelho
   ========================================================= */

.up_zap_action_links {
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
}

.up_zap_action_links a,
.up_zap_action_links button,
.up_zap_action_links .btn-favorito,
.up_zap_action_links .btn-favorito-active {
    appearance: none !important;
    -webkit-appearance: none !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    border-radius: 0 !important;
    color: #111827 !important;
    font-family: "Roboto", "Poppins", Arial, Helvetica, sans-serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    text-decoration: underline !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    cursor: pointer !important;
}

.up_zap_action_links a:hover,
.up_zap_action_links button:hover,
.up_zap_action_links .btn-favorito:hover {
    color: #6d22e6 !important;
}

.up_zap_action_links .btn-favorito i,
.up_zap_action_links .btn-favorito-active i,
.up_zap_action_links a i {
    color: #111827 !important;
    font-size: 17px !important;
    line-height: 1 !important;
}

/* Quando estiver favoritado, mantém discreto, só coração preenchido */
.up_zap_action_links .up_favorito_active,
.up_zap_action_links .btn-favorito-active {
    color: #111827 !important;
    background: transparent !important;
    border: 0 !important;
}

.up_zap_action_links .up_favorito_active i,
.up_zap_action_links .btn-favorito-active i {
    color: #d92d20 !important;
}

/* Evita que regras globais antigas do .btn-favorito vazem para esta área */
.up_zap_tags_actions .btn,
.up_zap_tags_actions .btn-favorito,
.up_zap_tags_actions .btn-favorito-active {
    width: auto !important;
    max-width: none !important;
}

/* Mobile: mantém alinhado e sem estourar */
@media(max-width: 760px) {
    .up_zap_tags_actions {
        align-items: flex-start !important;
        flex-direction: column !important;
    }

    .up_zap_action_links {
        gap: 18px !important;
        flex-wrap: wrap !important;
    }
}


/* =========================================================
   Abas Características: Imóvel / Condomínio
   CSS mínimo, sem alterar galeria, header ou layout geral
   ========================================================= */
.up_zap_features_panel {
    display: none;
}

.up_zap_features_panel.active {
    display: block;
}


/* =========================================================
   Tour virtual 360°: permite arrastar/girar dentro do player
   Mantém o CSS completo do detalhe, sem retrocesso visual.
   ========================================================= */
[data-up-media-panel="tour"],
[data-up-media-panel="videos"] {
    pointer-events: auto;
}

[data-up-media-panel="tour"] iframe,
[data-up-media-panel="videos"] iframe,
.up_media_iframe_360 {
    width: 100%;
    min-height: 520px;
    border: 0;
    display: block;
    pointer-events: auto !important;
    touch-action: auto !important;
}


/* Fallback visual para tours 360 do YouTube quando o embed limitar o arraste */
.up_tour360_help {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 16px;
    background: #ffffff;
    border: 1px solid rgba(15, 35, 65, .12);
    border-top: 0;
    color: #334155;
    font-size: 13px;
}

.up_tour360_help a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 16px;
    border-radius: 999px;
    background: #6d22e6;
    color: #fff !important;
    font-weight: 800;
    text-decoration: none !important;
    white-space: nowrap;
}

.up_tour360_help a:hover {
    filter: brightness(.96);
}

@media (max-width: 768px) {
    .up_tour360_help {
        flex-direction: column;
        align-items: flex-start;
    }

    .up_tour360_help a {
        width: 100%;
    }
}
