
/* =========================================================
   AJUSTE FINAL V2 - RESPONSIVE / NAV / FOOTER / MODALES
   Se carga al final para corregir detalles visuales sin tocar BD.
========================================================= */
html, body {
    min-height: 100% !important;
    height: auto !important;
}
body.public-page {
    min-height: 100dvh !important;
    display: flex !important;
    flex-direction: column !important;
    overflow-x: hidden !important;
    background: linear-gradient(180deg, #f8fafc, #f2f6fb) !important;
}
body.public-page > .contenido-pie {
    margin-top: auto !important;
    width: 100% !important;
}
body.public-page .barra-superior {
    height: 72px !important;
    min-height: 72px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 28px !important;
    background: rgba(255, 255, 255, .96) !important;
    border-bottom: 1px solid rgba(226, 232, 240, .95) !important;
    box-shadow: 0 10px 28px rgba(15,23,42,.08) !important;
    z-index: 1000 !important;
}
body.public-page .logo {
    position: absolute !important;
    left: 26px !important;
    top: 6px !important;
}
body.public-page .logo a {
    display: inline-flex !important;
    align-items: center !important;
    border-radius: 14px !important;
    text-decoration: none !important;
}
body.public-page .logo a:focus-visible {
    outline: 3px solid rgba(29,78,216,.32);
    outline-offset: 4px;
}
body.public-page .logo img {
    height: 58px !important;
    max-height: 58px !important;
    width: auto !important;
    object-fit: contain !important;
}
body.public-page .navegacion {
    height: 72px !important;
    display: flex !important;
    align-items: center !important;
}
body.public-page .navegacion ul {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    flex-wrap: nowrap !important;
}
body.public-page .navegacion ul li a {
    min-height: 42px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    font-weight: 800 !important;
    color: #0f172a !important;
    white-space: nowrap !important;
}
body.public-page .usuario {
    position: absolute !important;
    right: 26px !important;
    top: 14px !important;
    margin: 0 !important;
}
body.public-page .usuario a.boton.mini-boton {
    border: 0 !important;
    border-radius: 999px !important;
    padding: 12px 18px !important;
    color: #fff !important;
    background: linear-gradient(135deg, #0f2f6f, #061a3f) !important;
    box-shadow: 0 14px 28px rgba(15,47,111,.22) !important;
    min-width: 0 !important;
    min-height: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    letter-spacing: .04em !important;
}
body.public-page .usuario a.boton.mini-boton::before,
body.public-page .usuario a.boton.mini-boton::after { display: none !important; }
body.public-page .usuario a.boton.mini-boton:hover {
    transform: translateY(-1px);
    color: #fff !important;
}

/* Inicio: quitar margen doble entre menú y video */
body.home-page .contenido {
    margin-top: 72px !important;
    padding-top: 0 !important;
}
body.home-page .video-container {
    margin-top: 0 !important;
    height: clamp(420px, 64vh, 680px) !important;
    min-height: clamp(420px, 64vh, 680px) !important;
    border-radius: 0 0 32px 32px !important;
}
body.home-page .video-container video {
    height: 100% !important;
    min-height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
}

/* Login: mantener diseño oscuro, centrar y mandar footer al final */
body.login-page {
    padding-top: 72px !important;
}
body.login-page .barra-superior {
    position: fixed !important;
    top: 0 !important;
}
body.login-page .form {
    margin: clamp(92px, 15vh, 140px) auto clamp(42px, 7vh, 78px) !important;
    flex: 0 0 auto !important;
}
body.login-page > .contenido-pie {
    margin-top: auto !important;
}

/* Propiedades: filtros profesionales en flujo, sin superponerse ni verse angostos */
body.properties-page #poda {
    width: min(980px, calc(100% - 32px)) !important;
    margin: 104px auto 18px !important;
    padding: 0 !important;
    display: block !important;
    position: relative !important;
    z-index: 40 !important;
}
body.properties-page #poda form {
    width: 100% !important;
    max-width: 100% !important;
    position: relative !important;
    display: block !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 24px !important;
    box-shadow: 0 18px 45px rgba(15,23,42,.10) !important;
    padding: 12px !important;
}
body.properties-page #poda .input {
    width: 100% !important;
    height: 58px !important;
    background: #f8fafc !important;
    border: 1px solid #dbe4f0 !important;
    border-radius: 18px !important;
    box-shadow: none !important;
    color: #0f172a !important;
    padding: 0 70px 0 18px !important;
    font-size: 15px !important;
}
body.properties-page #filter-icon {
    position: absolute !important;
    top: 22px !important;
    right: 22px !important;
    transform: none !important;
    width: 42px !important;
    height: 42px !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #0f2f6f, #061a3f) !important;
    color: #fff !important;
    z-index: 5 !important;
}
body.properties-page .filtros {
    position: static !important;
    transform: none !important;
    width: 100% !important;
    max-width: none !important;
    margin: 12px 0 0 !important;
    padding: 16px !important;
    border-radius: 20px !important;
    border: 1px solid #e2e8f0 !important;
    background: linear-gradient(180deg, #ffffff, #f8fafc) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.75) !important;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    gap: 14px !important;
}
body.properties-page .filtros.mostrar { display: grid !important; }
body.properties-page .filtro label {
    display: block !important;
    margin-bottom: 7px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
}
body.properties-page .filtro input,
body.properties-page .filtro select {
    width: 100% !important;
    min-height: 46px !important;
    border-radius: 14px !important;
    border: 1px solid #dbe4f0 !important;
    background: #fff !important;
    color: #0f172a !important;
    font-size: 14px !important;
}
body.properties-page .btn-aplicar-filtros {
    grid-column: 1 / -1 !important;
    min-height: 48px !important;
    border-radius: 16px !important;
    background: linear-gradient(135deg, #0f2f6f, #061a3f) !important;
}
body.properties-page .propiedades-hero {
    margin-top: 18px !important;
}

/* Detalle: modal cerrable con X, clic afuera y Esc */
body.detail-page #imageModal {
    z-index: 100000 !important;
    background: rgba(2,6,23,.76) !important;
    backdrop-filter: blur(8px);
    cursor: zoom-out;
    padding: 24px !important;
}
body.detail-page #imageModal .modal-content {
    width: auto !important;
    max-width: calc(100vw - 56px) !important;
    max-height: calc(100dvh - 56px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    cursor: default;
}
body.detail-page #modalImage {
    width: auto !important;
    max-width: calc(100vw - 56px) !important;
    max-height: calc(100dvh - 56px) !important;
    object-fit: contain !important;
    border-radius: 18px !important;
    box-shadow: 0 28px 80px rgba(0,0,0,.42) !important;
}
body.detail-page .close-modal {
    position: fixed !important;
    top: 22px !important;
    right: 24px !important;
    width: 48px !important;
    height: 48px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #0f172a !important;
    font-size: 34px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    z-index: 100001 !important;
    box-shadow: 0 18px 44px rgba(0,0,0,.28) !important;
}
body.modal-open { overflow: hidden !important; }

/* Contacto y páginas internas: que el contenido empuje el footer */
body.contact-page > .contenido,
body.sedes-page > .contenido,
body.simple-page > .contenido {
    flex: 1 0 auto !important;
}

@media (max-width: 900px) {
    body.public-page .barra-superior {
        position: sticky !important;
        top: 0 !important;
        height: auto !important;
        min-height: 66px !important;
        display: grid !important;
        grid-template-columns: auto auto !important;
        justify-content: space-between !important;
        gap: 8px 10px !important;
        padding: 8px 12px !important;
    }
    body.public-page .logo,
    body.public-page .usuario {
        position: static !important;
    }
    body.public-page .logo img { height: 48px !important; max-height: 48px !important; }
    body.public-page .usuario { justify-self: end !important; }
    body.public-page .usuario a.boton.mini-boton { padding: 9px 13px !important; font-size: 12px !important; }
    body.public-page .navegacion {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        height: auto !important;
        overflow-x: auto !important;
        padding: 2px 0 0 !important;
    }
    body.public-page .navegacion ul {
        width: max-content !important;
        min-width: 100% !important;
        justify-content: center !important;
        gap: 6px !important;
        flex-wrap: nowrap !important;
    }
    body.public-page .navegacion ul li a {
        min-height: 38px !important;
        padding: 0 10px !important;
        font-size: 13px !important;
    }
    body.home-page .contenido {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    body.home-page .video-container {
        height: 560px !important;
        min-height: 560px !important;
        border-radius: 0 0 24px 24px !important;
    }
    body.login-page {
        padding-top: 0 !important;
    }
    body.login-page .form {
        width: min(92vw, 360px) !important;
        margin: 64px auto 42px !important;
    }
    body.properties-page #poda {
        margin-top: 20px !important;
        width: min(100% - 24px, 720px) !important;
    }
    body.properties-page .propiedades-hero {
        margin-top: 18px !important;
    }
}
@media (max-width: 520px) {
    body.public-page .navegacion ul li a { font-size: 12px !important; padding: 0 8px !important; }
    body.public-page .usuario a.boton.mini-boton span { display: inline !important; }
    body.properties-page .filtros { grid-template-columns: 1fr !important; }
    body.detail-page #imageModal { padding: 14px !important; }
    body.detail-page .close-modal { top: 12px !important; right: 12px !important; }
}

/* =========================================================
   Corrección final botón Login y chatbot
========================================================= */
body.public-page .usuario {
  position: absolute !important;
  right: 24px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin: 0 !important;
  z-index: 10 !important;
}
body.public-page .usuario a.boton.mini-boton,
body.public-page .usuario a.boton.mini-boton:visited {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  min-height: 44px !important;
  padding: 0 20px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg,#0f2f6f,#061a3f) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  box-shadow: 0 14px 34px rgba(15,47,111,.28) !important;
  text-decoration: none !important;
  overflow: visible !important;
}
body.public-page .usuario a.boton.mini-boton::before,
body.public-page .usuario a.boton.mini-boton::after { display:none !important; content:none !important; }
body.public-page .usuario a.boton.mini-boton:hover { transform: translateY(-1px) !important; color:#fff !important; background: linear-gradient(135deg,#123b86,#071935) !important; }
body.public-page .usuario a.boton.mini-boton ion-icon { position: static !important; color: #fff !important; font-size: 16px !important; }
body.public-page .usuario a.boton.mini-boton span { position: static !important; color: #fff !important; }
@media (max-width: 900px) {
  body.public-page .usuario { position: static !important; transform: none !important; justify-self: end !important; }
  body.public-page .usuario a.boton.mini-boton { min-height: 38px !important; padding: 0 14px !important; font-size: 12px !important; }
}

/* Fix final del botón Login público: estilo original tipo píldora azul */
body.public-page .barra-superior .usuario a.boton.mini-boton,
body.public-page .barra-superior .usuario a.boton.mini-boton:visited,
.barra-superior .usuario a.boton.mini-boton,
.barra-superior .usuario a.boton.mini-boton:visited {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  min-width: 98px !important;
  width: auto !important;
  min-height: 44px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  border: 0 !important;
  outline: 0 !important;
  background: linear-gradient(135deg,#0f2f6f,#123b86) !important;
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 950 !important;
  letter-spacing: .02em !important;
  box-shadow: 0 14px 30px rgba(15,47,111,.24) !important;
  overflow: visible !important;
}
body.public-page .barra-superior .usuario a.boton.mini-boton::before,
body.public-page .barra-superior .usuario a.boton.mini-boton::after,
.barra-superior .usuario a.boton.mini-boton::before,
.barra-superior .usuario a.boton.mini-boton::after { display:none !important; content:none !important; }
body.public-page .barra-superior .usuario a.boton.mini-boton span,
body.public-page .barra-superior .usuario a.boton.mini-boton ion-icon,
.barra-superior .usuario a.boton.mini-boton span,
.barra-superior .usuario a.boton.mini-boton ion-icon { color:#fff !important; position:static !important; z-index:auto !important; }
body.public-page .barra-superior .usuario a.boton.mini-boton:hover,
.barra-superior .usuario a.boton.mini-boton:hover {
  transform: translateY(-1px) !important;
  background: linear-gradient(135deg,#123b86,#071935) !important;
  color:#fff !important;
}


/* CR_PUBLIC_RESPONSIVE_ALL_DEVICES_20260627 */
/* =========================================================
   RESPONSIVE GLOBAL PÚBLICO - móviles, tablets y escritorio
========================================================= */
html,
body,
body.public-page {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}
body.public-page * {
    box-sizing: border-box !important;
}
body.public-page img,
body.public-page video,
body.public-page iframe,
body.public-page canvas,
body.public-page svg {
    max-width: 100% !important;
}
body.public-page .barra-superior {
    width: 100% !important;
    max-width: 100% !important;
}
body.public-page .navegacion ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
body.public-page .contenido,
body.public-page .contenedor-principal,
body.public-page .contenido-secundario,
body.public-page .detalle-container,
body.public-page .anuncios-container,
body.public-page .formulario-contacto {
    min-width: 0 !important;
}

/* Detalle de propiedad: carrusel estable y sin espacios blancos */
body.detail-page .contenedor-principal {
    width: min(1280px, calc(100% - 28px)) !important;
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
body.detail-page .carousel-container.property-gallery,
body.detail-page .carousel-container {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
}
body.detail-page .carousel-slide {
    width: 100% !important;
    min-width: 100% !important;
    flex: 0 0 auto !important;
    overflow: hidden !important;
    background: #0b1220 !important;
}
body.detail-page .carousel-image {
    display: block !important;
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
body.detail-page .thumbnail-strip {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 auto !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
}
body.detail-page .thumbnail-strip img {
    flex: 0 0 auto !important;
}
body.detail-page .formulario-contacto,
body.detail-page .detalle-container,
body.detail-page .direccion-mapa,
body.detail-page .descripcion-card,
body.detail-page .video-propiedad,
body.detail-page .anuncios-container {
    max-width: 100% !important;
}
body.detail-page .mapa-ubicacion iframe,
body.detail-page .video-propiedad iframe,
body.detail-page .video-propiedad video {
    width: 100% !important;
    max-width: 100% !important;
}
body.detail-page .detalles-propiedad {
    width: 100% !important;
    max-width: 100% !important;
}
body.detail-page .grid-anuncios {
    max-width: 100% !important;
}

@media (max-width: 1024px) {
    /* Header público usable en móviles/tablets */
    body.public-page .barra-superior,
    body.login-page .barra-superior {
        position: sticky !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        display: grid !important;
        grid-template-columns: auto auto !important;
        grid-template-areas: "logo user" "nav nav" !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 8px 10px !important;
        height: auto !important;
        min-height: 0 !important;
        padding: 8px 10px !important;
        background: rgba(15, 23, 42, .94) !important;
        border-bottom: 1px solid rgba(255,255,255,.12) !important;
        box-shadow: 0 14px 34px rgba(2,6,23,.22) !important;
        backdrop-filter: blur(14px) !important;
        z-index: 5000 !important;
    }
    body.public-page .logo,
    body.login-page .logo {
        grid-area: logo !important;
        position: static !important;
        left: auto !important;
        top: auto !important;
        transform: none !important;
        margin: 0 !important;
        display: flex !important;
        align-items: center !important;
    }
    body.public-page .logo img,
    body.login-page .logo img {
        height: 50px !important;
        max-height: 50px !important;
        width: auto !important;
        object-fit: contain !important;
    }
    body.public-page .usuario,
    body.login-page .usuario {
        grid-area: user !important;
        position: static !important;
        right: auto !important;
        top: auto !important;
        transform: none !important;
        margin: 0 !important;
        width: auto !important;
        display: flex !important;
        justify-content: flex-end !important;
        align-items: center !important;
    }
    body.public-page .usuario a.boton.mini-boton,
    body.login-page .usuario a.boton.mini-boton {
        width: auto !important;
        min-width: 0 !important;
        min-height: 38px !important;
        height: 38px !important;
        padding: 0 13px !important;
        border-radius: 999px !important;
        font-size: 12px !important;
        white-space: nowrap !important;
    }
    body.public-page .navegacion,
    body.login-page .navegacion {
        grid-area: nav !important;
        position: relative !important;
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        min-height: 0 !important;
        margin: 0 !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
    }
    body.public-page .navegacion::-webkit-scrollbar,
    body.login-page .navegacion::-webkit-scrollbar { display: none !important; }
    body.public-page .navegacion ul,
    body.login-page .navegacion ul {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 8px !important;
        width: max-content !important;
        min-width: 100% !important;
        padding: 2px 0 4px !important;
    }
    body.public-page .navegacion ul li,
    body.login-page .navegacion ul li {
        flex: 0 0 auto !important;
    }
    body.public-page .navegacion ul li a,
    body.login-page .navegacion ul li a {
        min-height: 36px !important;
        height: 36px !important;
        line-height: 1 !important;
        padding: 0 11px !important;
        border-radius: 999px !important;
        font-size: 13px !important;
        color: #f8fafc !important;
        background: rgba(255,255,255,.06) !important;
        white-space: nowrap !important;
    }
    body.public-page .navegacion ul li a:hover,
    body.login-page .navegacion ul li a:hover {
        background: rgba(96,165,250,.18) !important;
        color: #fff !important;
        transform: none !important;
    }
    body.public-page .contenido,
    body.home-page .contenido,
    body.login-page {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    body.login-page .form {
        margin-top: 28px !important;
    }

    /* Detalle de propiedad */
    body.detail-page .contenedor-principal {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        width: min(100% - 24px, 820px) !important;
        margin: 16px auto 0 !important;
        padding: 0 !important;
    }
    body.detail-page .carousel-container.property-gallery,
    body.detail-page .carousel-container {
        max-width: 100% !important;
        flex: none !important;
        border-radius: 22px !important;
    }
    body.detail-page .carousel-slide {
        height: auto !important;
        min-height: 260px !important;
        max-height: none !important;
        aspect-ratio: 16 / 10 !important;
    }
    body.detail-page .thumbnail-strip {
        justify-content: flex-start !important;
        padding: 10px !important;
        gap: 8px !important;
        background: #fff !important;
    }
    body.detail-page .thumbnail-strip img {
        width: 78px !important;
        height: 58px !important;
        border-radius: 12px !important;
    }
    body.detail-page .formulario-contacto {
        position: static !important;
        width: 100% !important;
        max-width: 100% !important;
        flex: none !important;
        border-radius: 22px !important;
    }
    body.detail-page .contenido-secundario {
        width: min(100% - 24px, 820px) !important;
        padding: 16px 0 0 !important;
    }
    body.detail-page .detalle-container {
        padding: 18px !important;
        border-radius: 22px !important;
    }
    body.detail-page .precio-mantenimiento,
    body.detail-page .caracteristicas {
        justify-content: flex-start !important;
        gap: 10px !important;
    }
    body.detail-page .direccion-mapa,
    body.detail-page .descripcion-card,
    body.detail-page .video-propiedad {
        padding: 16px !important;
        border-radius: 18px !important;
    }
    body.detail-page .mapa-ubicacion {
        min-height: 280px !important;
    }
    body.detail-page .mapa-ubicacion iframe {
        height: 300px !important;
    }
    body.detail-page .anuncios-container {
        width: min(100% - 24px, 820px) !important;
        margin: 18px auto !important;
        padding: 16px !important;
        border-radius: 22px !important;
    }
    body.detail-page .carrusel-anuncios {
        overflow: visible !important;
        justify-content: flex-start !important;
    }
    body.detail-page .grid-anuncios {
        flex-wrap: nowrap !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 4px 2px 12px !important;
        scroll-snap-type: x mandatory !important;
    }
    body.detail-page .grid-anuncios .anuncio {
        flex: 0 0 min(82vw, 280px) !important;
        width: min(82vw, 280px) !important;
        scroll-snap-align: start !important;
    }
    body.detail-page .carousel-button {
        flex: 0 0 36px !important;
        width: 36px !important;
        height: 36px !important;
        margin: 0 4px !important;
    }
}

@media (max-width: 768px) {
    body.public-page .logo img,
    body.login-page .logo img {
        height: 44px !important;
        max-height: 44px !important;
    }
    body.public-page .navegacion ul li a,
    body.login-page .navegacion ul li a {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 10px !important;
        font-size: 12px !important;
    }
    body.detail-page .carousel-slide {
        min-height: 235px !important;
        aspect-ratio: 4 / 3 !important;
    }
    body.detail-page .thumbnail-strip img {
        width: 68px !important;
        height: 52px !important;
    }
    body.detail-page .ubicacion-info h2 {
        font-size: clamp(24px, 7vw, 32px) !important;
    }
    body.detail-page .precio-mantenimiento {
        display: grid !important;
        grid-template-columns: 1fr !important;
        font-size: 1rem !important;
    }
    body.detail-page .detalles-propiedad,
    body.detail-page .detalles-propiedad tbody,
    body.detail-page .detalles-propiedad tr,
    body.detail-page .detalles-propiedad th,
    body.detail-page .detalles-propiedad td {
        display: block !important;
        width: 100% !important;
    }
    body.detail-page .detalles-propiedad tr {
        padding: 10px 0 !important;
        border-bottom: 1px solid #e4e7ec !important;
    }
    body.detail-page .detalles-propiedad th {
        border-bottom: 0 !important;
        padding: 6px 12px 2px !important;
    }
    body.detail-page .detalles-propiedad td {
        padding: 2px 12px 8px !important;
        overflow-wrap: anywhere !important;
    }
    body.detail-page .formulario-contacto input,
    body.detail-page .formulario-contacto textarea,
    body.detail-page .formulario-contacto button,
    body.detail-page .btn-maps-route {
        width: 100% !important;
    }
}

@media (max-width: 480px) {
    body.public-page .barra-superior,
    body.login-page .barra-superior {
        padding: 7px 8px !important;
    }
    body.public-page .logo img,
    body.login-page .logo img {
        height: 40px !important;
        max-height: 40px !important;
    }
    body.public-page .usuario a.boton.mini-boton span,
    body.login-page .usuario a.boton.mini-boton span {
        display: inline !important;
    }
    body.public-page .usuario a.boton.mini-boton,
    body.login-page .usuario a.boton.mini-boton {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 10px !important;
        font-size: 11px !important;
    }
    body.public-page .navegacion ul li a,
    body.login-page .navegacion ul li a {
        padding: 0 9px !important;
        font-size: 11px !important;
    }
    body.detail-page .contenedor-principal,
    body.detail-page .contenido-secundario,
    body.detail-page .anuncios-container {
        width: min(100% - 16px, 440px) !important;
    }
    body.detail-page .carousel-slide {
        min-height: 210px !important;
        aspect-ratio: 4 / 3 !important;
    }
    body.detail-page .thumbnail-strip {
        padding: 8px !important;
    }
    body.detail-page .thumbnail-strip img {
        width: 62px !important;
        height: 48px !important;
    }
    body.detail-page .gallery-btn {
        width: 38px !important;
        height: 38px !important;
        font-size: 28px !important;
    }
    body.detail-page .gallery-prev { left: 8px !important; }
    body.detail-page .gallery-next { right: 8px !important; }
    body.detail-page .detalle-container,
    body.detail-page .formulario-contacto,
    body.detail-page .anuncios-container {
        padding: 14px !important;
    }
    body.detail-page .mapa-ubicacion iframe {
        height: 250px !important;
    }
    body.detail-page .contenido-pie {
        font-size: 12px !important;
        line-height: 1.5 !important;
    }
}
