/*
 * AlojamientosRurales - Cabecera y navegación global.
 * Este archivo es la única fuente de verdad para el layout del menú público.
 * No duplicar reglas de .site-header/.site-nav en CSS de listados, mapa o ficha.
 */

.site-header-back,
.site-header-share,
.site-nav__drawer-head {
    display: none;
}

.site-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 3000 !important;
    width: 100% !important;
    max-width: 100% !important;
    transition: box-shadow .2s ease, transform .2s ease;
}

body.site-header-scrolled .site-header {
    box-shadow: 0 8px 24px rgba(15, 23, 42, .14) !important;
}

body.site-menu-open .site-header,
.site-header:has(.site-nav__account[open]) {
    transform: translate3d(0, 0, 0) !important;
    z-index: 160000 !important;
}

/* El bloqueo de scroll del menú no mueve nada (no usa position:fixed en el body), así que la
   cabecera y el nav de anclas sticky se quedan solos en su sitio. Quitamos el transform (un
   transform en el propio elemento sticky rompe la fijación en algunos navegadores) y la animación
   para que, en listados (cabecera oculta por scroll), aparezca sin deslizarse. */
body.site-menu-open .site-header {
    transform: none !important;
    transition: none !important;
}

.site-header .brand.brand--logo img,
.site-footer__brand-link--logo img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

.site-header .brand.brand--logo img {
    max-width: 320px !important;
    max-height: 52px !important;
}

@media (min-width: 901px) {
    .site-header {
        padding: 0 !important;
        border-bottom: 0 !important;
        background: linear-gradient(180deg, #a5c957 0%, #79ad1a 46%, #518707 100%) !important;
        color: #fff !important;
    }

    .site-header__bar {
        display: grid !important;
        grid-template-columns: minmax(220px, 1fr) auto !important;
        align-items: center !important;
        gap: 24px !important;
        width: 100% !important;
        max-width: none !important;
        min-height: 68px !important;
        margin: 0 !important;
        padding: 0 24px !important;
        box-sizing: border-box !important;
        background: linear-gradient(90deg, rgba(26, 74, 20, .18) 0%, rgba(26, 74, 20, .05) 32%, rgba(255,255,255,0) 68%) !important;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.34) !important;
    }

    .site-header-back,
    .site-header-share,
    .site-nav-toggle,
    .site-nav__drawer-head {
        display: none !important;
    }

    .site-header .brand.brand--logo {
        display: inline-flex !important;
        align-items: center !important;
        width: fit-content !important;
        min-width: 0 !important;
        max-width: 320px !important;
        overflow: hidden !important;
        color: inherit !important;
    }

    .site-header .brand.brand--logo img {
        max-width: 292px !important;
        max-height: 44px !important;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, .28)) !important;
    }

    .site-nav {
        position: static !important;
        display: flex !important;
        flex-wrap: nowrap !important;
        align-items: stretch !important;
        justify-content: center !important;
        gap: 0 !important;
        width: auto !important;
        max-width: none !important;
        min-height: 68px !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: visible !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        color: inherit !important;
        transform: none !important;
    }

    .site-nav > a,
    .site-nav .account-pill,
    .site-nav__account > summary {
        position: relative !important;
        display: inline-flex !important;
        flex: 0 0 auto !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        height: 68px !important;
        min-height: 68px !important;
        margin: 0 !important;
        padding: 0 16px !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        color: rgba(255,255,255,.90) !important;
        font-size: 15px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        text-shadow: 0 1px 1px rgba(0,0,0,.14) !important;
        cursor: pointer !important;
        box-sizing: border-box !important;
    }

    .site-nav__account {
        position: relative !important;
        display: inline-flex !important;
        flex: 0 0 auto !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .site-nav__account > summary,
    .site-nav__account-section > summary {
        list-style: none !important;
        user-select: none !important;
    }

    .site-nav__account > summary::-webkit-details-marker,
    .site-nav__account-section > summary::-webkit-details-marker {
        display: none !important;
    }

    .site-nav__account-label {
        display: inline-flex !important;
        align-items: center !important;
        gap: 7px !important;
        min-width: 0 !important;
    }

    .site-nav__account-chevron {
        margin-left: 2px !important;
        font-size: 12px !important;
        opacity: .9 !important;
    }

    .site-nav > a:hover,
    .site-nav > a.is-active,
    .site-nav .account-pill:hover,
    .site-nav .account-pill.is-active,
    .site-nav__account:hover > summary,
    .site-nav__account[open] > summary,
    .site-nav__account.is-active > summary {
        color: #fff !important;
        background: rgba(255,255,255,.12) !important;
    }

    .site-nav > a.is-active::after,
    .site-nav .account-pill.is-active::after,
    .site-nav__account.is-active > summary::after,
    .site-nav__account[open] > summary::after {
        content: "";
        position: absolute;
        left: 14px;
        right: 14px;
        bottom: 0;
        height: 4px;
        border-radius: 999px 999px 0 0;
        background: #fff;
        box-shadow: 0 -1px 8px rgba(255,255,255,.22);
    }

    .site-nav > a .ar-svg-icon,
    .site-nav .account-pill .ar-svg-icon,
    .site-nav__account > summary .ar-svg-icon {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        stroke-width: 2 !important;
    }

    .site-nav__account-menu {
        position: absolute !important;
        top: calc(100% + 8px) !important;
        right: 0 !important;
        z-index: 160020 !important;
        display: grid !important;
        gap: 4px !important;
        min-width: 280px !important;
        max-width: min(360px, 92vw) !important;
        margin: 0 !important;
        padding: 8px !important;
        border: 1px solid var(--ar-line) !important;
        border-radius: 16px !important;
        background: #fff !important;
        color: var(--ar-ink) !important;
        box-shadow: 0 18px 46px rgba(15, 23, 42, .24) !important;
    }

    .site-nav .site-nav__account-menu a,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary,
    .site-nav .site-nav__account-logout button {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 9px !important;
        width: 100% !important;
        min-height: 40px !important;
        height: 40px !important;
        margin: 0 !important;
        padding: 0 11px !important;
        border: 0 !important;
        border-radius: 12px !important;
        background: #fff !important;
        color: #263443 !important;
        font: inherit !important;
        font-size: 14px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-align: left !important;
        text-decoration: none !important;
        text-shadow: none !important;
        white-space: nowrap !important;
        box-sizing: border-box !important;
        cursor: pointer !important;
    }

    .site-nav .site-nav__account-menu-label {
        padding: 8px 11px 6px !important;
        color: #5f6d5f !important;
        font-size: 12.5px !important;
        font-weight: 800 !important;
        line-height: 1.25 !important;
    }

    .site-nav .site-nav__account-section > div {
        display: grid !important;
        gap: 4px !important;
        padding: 4px 0 4px 20px !important;
    }

    .site-nav .site-nav__account-menu a:hover,
    .site-nav .site-nav__account-menu a.is-active,
    .site-nav .site-nav__account-menu .site-nav__account-section[open] > summary,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary:hover,
    .site-nav .site-nav__account-logout button:hover {
        background: #f1f8e9 !important;
        color: var(--ar-brand-darker) !important;
    }

    .site-nav .site-nav__account-menu a::after,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary::after {
        content: none !important;
    }

    .site-nav .site-nav__account-menu .ar-svg-icon {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        color: var(--ar-brand-darker) !important;
    }

    .site-nav .site-nav__account-logout {
        margin: 4px 0 0 !important;
        padding: 6px 0 0 !important;
        border-top: 1px solid var(--ar-line) !important;
        background: transparent !important;
    }

    .site-nav .site-nav__account-logout button {
        color: #8a1f1f !important;
    }

    .site-nav > a[href="/favoritos"],
    .site-nav a[href="/favoritos"] {
        display: inline-flex !important;
    }

    .site-nav__count {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 22px !important;
        height: 22px !important;
        margin-left: 2px !important;
        padding: 0 7px !important;
        border-radius: 999px !important;
        background: rgba(255,255,255,.94) !important;
        color: var(--ar-brand-dark) !important;
        font-size: 12px !important;
        font-weight: 900 !important;
    }
}

@media (min-width: 901px) and (max-width: 1240px) {
    .site-header__bar {
        grid-template-columns: minmax(210px, 245px) minmax(0, 1fr) !important;
        gap: 10px !important;
        min-height: 62px !important;
        padding: 0 14px !important;
    }

    .site-header .brand.brand--logo {
        max-width: 245px !important;
    }

    .site-header .brand.brand--logo img {
        max-width: 240px !important;
        max-height: 38px !important;
    }

    .site-nav {
        justify-content: flex-end !important;
        min-height: 62px !important;
    }

    .site-nav > a,
    .site-nav .account-pill,
    .site-nav__account > summary {
        height: 62px !important;
        min-height: 62px !important;
        gap: 5px !important;
        padding: 0 8px !important;
        font-size: 13.25px !important;
        letter-spacing: -.15px !important;
    }

    .site-nav > a .ar-svg-icon,
    .site-nav .account-pill .ar-svg-icon,
    .site-nav__account > summary .ar-svg-icon {
        display: none !important;
    }

    .site-nav > a.is-active::after,
    .site-nav .account-pill.is-active::after,
    .site-nav__account.is-active > summary::after,
    .site-nav__account[open] > summary::after {
        left: 8px;
        right: 8px;
    }
}

@media (max-width: 900px) {
    .site-header {
        padding: 0 !important;
        background: linear-gradient(180deg, #9fc74b 0%, #76aa16 46%, #4f8707 100%) !important;
    }

    body.site-menu-open {
        overflow: hidden !important;
    }

    .site-header__bar {
        display: grid !important;
        grid-template-columns: 24px minmax(0, 1fr) 38px 42px !important;
        align-items: center !important;
        gap: 4px !important;
        width: 100% !important;
        max-width: none !important;
        min-height: 64px !important;
        margin: 0 !important;
        padding: 0 !important;
        box-sizing: border-box !important;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.30) !important;
    }

    .site-header-back,
    .site-header-share,
    .site-nav-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        color: #fff !important;
        box-shadow: none !important;
    }

    .site-header-back {
        width: 24px !important;
        min-width: 24px !important;
        height: 42px !important;
        min-height: 42px !important;
    }

    .site-header-share {
        width: 38px !important;
        min-width: 38px !important;
        height: 42px !important;
        min-height: 42px !important;
    }

    .site-nav-toggle {
        width: 42px !important;
        min-width: 42px !important;
        height: 42px !important;
        min-height: 42px !important;
    }

    .site-header .brand.brand--logo {
        display: inline-flex !important;
        align-items: center !important;
        min-width: 0 !important;
        max-width: none !important;
        overflow: visible !important;
    }

    .site-header .brand.brand--logo img {
        max-width: min(245px, calc(100vw - 114px)) !important;
        max-height: 34px !important;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, .26)) !important;
    }

    .site-nav-toggle span {
        display: none !important;
    }

    .site-header-back .ar-svg-icon {
        width: 23px !important;
        height: 23px !important;
        stroke-width: 2.2 !important;
    }

    .site-header-share .ar-svg-icon {
        width: 24px !important;
        height: 24px !important;
        stroke-width: 2.05 !important;
    }

    .site-nav-toggle .ar-svg-icon {
        width: 30px !important;
        height: 30px !important;
        stroke-width: 2.15 !important;
    }

    .site-nav {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        z-index: 160020 !important;
        display: flex !important;
        flex-direction: column !important;
        /* El drawer es una columna ÚNICA con scroll. Sin nowrap hereda el
           flex-wrap:wrap de la nav de escritorio (ar-layout.css) y, al abrirse
           el "Panel de propietario" cuando el contenido supera la altura del
           viewport, el bloque de cuenta salta a una 2ª columna fuera del drawer
           (visible al redimensionar desde escritorio, donde no se inyecta la
           compresión de ar-interface.js). overflow-y:auto hace que el exceso
           haga scroll en lugar de envolver. */
        flex-wrap: nowrap !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        gap: 0 !important;
        width: min(84vw, 330px) !important;
        max-width: none !important;
        height: 100dvh !important;
        min-height: 100dvh !important;
        margin: 0 !important;
        padding: 0 0 18px !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
        border-radius: 0 !important;
        background: #fff !important;
        color: var(--ar-ink) !important;
        box-shadow: 18px 0 54px rgba(15, 23, 42, .20) !important;
        transform: translate3d(-105%, 0, 0) !important;
        transition: transform .24s ease !important;
        -webkit-overflow-scrolling: touch;
        pointer-events: auto !important;
    }

    body.site-menu-open .site-nav {
        transform: translate3d(0, 0, 0) !important;
    }

    .site-nav__drawer-head {
        display: flex !important;
        flex: 0 0 66px !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 14px !important;
        height: 66px !important;
        min-height: 66px !important;
        max-height: 66px !important;
        padding: 12px 16px !important;
        border-bottom: 1px solid #e5ebf1 !important;
        background: #fff !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
    }

    .site-nav__drawer-brand {
        display: inline-flex !important;
        align-items: center !important;
        width: auto !important;
        max-width: calc(100% - 54px) !important;
        height: 42px !important;
        max-height: 42px !important;
        min-width: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
        border: 0 !important;
        background: transparent !important;
    }

    .site-nav__drawer-brand img {
        display: block !important;
        width: auto !important;
        height: auto !important;
        max-width: 205px !important;
        max-height: 31px !important;
        object-fit: contain !important;
    }

    .site-nav__drawer-close {
        display: inline-flex !important;
        flex: 0 0 40px !important;
        align-items: center !important;
        justify-content: center !important;
        width: 40px !important;
        min-width: 40px !important;
        height: 40px !important;
        min-height: 40px !important;
        max-height: 40px !important;
        margin: 0 !important;
        border: 0 !important;
        border-radius: 12px !important;
        background: #f2f4f6 !important;
        color: #263443 !important;
        font-size: 29px !important;
        line-height: 1 !important;
        cursor: pointer;
    }

    .site-nav > a,
    .site-nav .account-pill,
    .site-nav__account > summary {
        display: inline-flex !important;
        flex: 0 0 54px !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 13px !important;
        width: 100% !important;
        height: 54px !important;
        min-height: 54px !important;
        max-height: 54px !important;
        margin: 0 !important;
        padding: 0 16px !important;
        border-left: 4px solid transparent !important;
        border-radius: 0 !important;
        background: #fff !important;
        color: var(--ar-ink-soft) !important;
        font-size: 15.5px !important;
        font-weight: 800 !important;
        line-height: 1.15 !important;
        text-align: left !important;
        text-decoration: none !important;
        text-shadow: none !important;
        box-sizing: border-box !important;
        white-space: nowrap !important;
    }

    .site-nav > a .ar-svg-icon,
    .site-nav .account-pill .ar-svg-icon,
    .site-nav__account > summary .ar-svg-icon {
        width: 23px !important;
        height: 23px !important;
        min-width: 23px !important;
        color: #234f2a !important;
        stroke-width: 1.9 !important;
    }

    .site-nav > a:hover,
    .site-nav > a.is-active,
    .site-nav .account-pill:hover,
    .site-nav .account-pill.is-active,
    .site-nav__account[open] > summary,
    .site-nav__account.is-active > summary {
        background: var(--ar-surface-soft) !important;
        color: #102015 !important;
        border-left-color: var(--ar-brand-dark) !important;
    }

    .site-nav__account {
        display: block !important;
        flex: 0 0 auto !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        height: auto !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: visible !important;
        border: 0 !important;
        background: #fff !important;
        color: var(--ar-ink) !important;
        transform: none !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }

    .site-nav__account > summary,
    .site-nav__account-menu .site-nav__account-section > summary {
        cursor: pointer !important;
        list-style: none !important;
        list-style-image: none !important;
        user-select: none !important;
    }

    .site-nav__account > summary::marker,
    .site-nav__account-menu .site-nav__account-section > summary::marker {
        content: "" !important;
        font-size: 0 !important;
    }

    .site-nav__account > summary::-webkit-details-marker,
    .site-nav__account-menu .site-nav__account-section > summary::-webkit-details-marker {
        display: none !important;
    }

    .site-nav__account-label {
        display: inline-flex !important;
        align-items: center !important;
        gap: 13px !important;
        min-width: 0 !important;
    }

    .site-nav__account-label span {
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .site-nav__account-chevron {
        flex: 0 0 auto !important;
        margin-left: auto !important;
        color: #6c7565 !important;
        font-size: 13px !important;
    }

    .site-nav__account:not([open]) > .site-nav__account-menu {
        display: none !important;
    }

    .site-nav__account[open] > .site-nav__account-menu {
        display: grid !important;
    }

    .site-nav__account-menu {
        position: static !important;
        display: grid !important;
        gap: 0 !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 0 8px !important;
        overflow: visible !important;
        border: 0 !important;
        border-bottom: 1px solid #e5ebf1 !important;
        border-radius: 0 !important;
        background: var(--ar-surface-soft) !important;
        box-shadow: none !important;
    }

    .site-nav .site-nav__account-menu-label {
        display: block !important;
        padding: 10px 16px 8px 34px !important;
        background: var(--ar-surface-soft) !important;
        color: var(--ar-ink-soft) !important;
        font-size: 13.5px !important;
        font-weight: 700 !important;
        line-height: 1.25 !important;
    }

    .site-nav .site-nav__account-menu a,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary {
        display: inline-flex !important;
        flex: 0 0 46px !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        width: 100% !important;
        height: 46px !important;
        min-height: 46px !important;
        max-height: 46px !important;
        margin: 0 !important;
        padding: 0 16px 0 34px !important;
        border-left: 4px solid transparent !important;
        border-radius: 0 !important;
        background: var(--ar-surface-soft) !important;
        color: var(--ar-ink-soft) !important;
        font-size: 14.5px !important;
        font-weight: 800 !important;
        line-height: 1.15 !important;
        text-align: left !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        box-sizing: border-box !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-section > div {
        display: grid !important;
        gap: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-section > div > a {
        height: 42px !important;
        min-height: 42px !important;
        max-height: 42px !important;
        padding-left: 58px !important;
        font-size: 14px !important;
        font-weight: 750 !important;
    }

    .site-nav .site-nav__account-menu a:hover,
    .site-nav .site-nav__account-menu a.is-active,
    .site-nav .site-nav__account-menu .site-nav__account-section[open] > summary,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary:hover {
        background: #eef6df !important;
        color: #102015 !important;
        border-left-color: var(--ar-brand-dark) !important;
    }

    .site-nav .site-nav__account-menu .ar-svg-icon {
        width: 20px !important;
        height: 20px !important;
        min-width: 20px !important;
        color: #234f2a !important;
    }

    .site-nav .site-nav__account-logout {
        display: block !important;
        margin: 4px 0 0 !important;
        padding: 8px 16px 0 34px !important;
        border-top: 1px solid var(--ar-line) !important;
        background: var(--ar-surface-soft) !important;
    }

    .site-nav .site-nav__account-logout button {
        appearance: none !important;
        -webkit-appearance: none !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        width: 100% !important;
        height: 42px !important;
        min-height: 42px !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        color: #8a1f1f !important;
        font: inherit !important;
        font-size: 14.5px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-align: left !important;
        text-decoration: none !important;
        box-shadow: none !important;
        cursor: pointer !important;
    }

    .site-nav .site-nav__account-logout button .ar-svg-icon {
        width: 20px !important;
        height: 20px !important;
        min-width: 20px !important;
        color: #8a1f1f !important;
    }

    .site-nav__count {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 24px !important;
        height: 24px !important;
        margin-left: auto !important;
        padding: 0 7px !important;
        border-radius: 999px !important;
        background: var(--ar-brand-dark) !important;
        color: #fff !important;
        font-size: 13px !important;
        font-weight: 900 !important;
    }

    .site-nav-backdrop {
        position: fixed !important;
        inset: 0 !important;
        z-index: 159000 !important;
        display: none !important;
        border: 0 !important;
        background: rgba(15, 23, 42, .48) !important;
        backdrop-filter: blur(2px);
        pointer-events: auto !important;
    }

    body.site-menu-open .site-nav-backdrop {
        display: block !important;
    }

    html.ar-listings-page body.site-menu-open .ar-top-search--unified,
    html.ar-listings-page body.site-menu-open .ar-top-search,
    html.ar-listings-page body.site-menu-open .ar-map-mobile-bar,
    html.ar-listings-page body.site-menu-open .ar-map-mobile-controls {
        z-index: 1 !important;
    }
}
/* AR_MOBILE_HEADER_DRAWER_END */

/* AR_MENU_FIXED_HEIGHTS_START
   Alturas constantes del drawer móvil.
   Evita que los elementos se estiren cuando el panel de propietario está cerrado.
*/
@media (max-width: 900px) {
    .site-nav {
        justify-content: flex-start !important;
        align-content: flex-start !important;
    }

    .site-nav > a,
    .site-nav > .account-pill,
    .site-nav > .site-nav__account {
        flex-grow: 0 !important;
        flex-shrink: 0 !important;
        flex-basis: auto !important;
    }

    .site-nav > a,
    .site-nav > .account-pill {
        height: 54px !important;
        min-height: 54px !important;
        max-height: 54px !important;
        box-sizing: border-box !important;
    }

    .site-nav > .site-nav__account:not([open]) {
        height: 54px !important;
        min-height: 54px !important;
        max-height: 54px !important;
        overflow: hidden !important;
    }

    .site-nav > .site-nav__account[open] {
        height: auto !important;
        min-height: 54px !important;
        max-height: none !important;
        overflow: visible !important;
    }

    .site-nav > .site-nav__account > summary {
        flex: 0 0 54px !important;
        height: 54px !important;
        min-height: 54px !important;
        max-height: 54px !important;
        box-sizing: border-box !important;
    }

    .site-nav .site-nav__account-menu a,
    .site-nav .site-nav__account-menu .site-nav__account-section > summary {
        flex: 0 0 46px !important;
        height: 46px !important;
        min-height: 46px !important;
        max-height: 46px !important;
        box-sizing: border-box !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-section > div > a {
        flex: 0 0 42px !important;
        height: 42px !important;
        min-height: 42px !important;
        max-height: 42px !important;
        box-sizing: border-box !important;
    }
}
/* AR_MENU_FIXED_HEIGHTS_END */

/* AR_GLOBAL_HEADER_STICKY_START
   Cabecera global sticky también en Home.
   No modifica el offset del buscador de listados.
*/
.site-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 5000 !important;
}
/* AR_GLOBAL_HEADER_STICKY_END */

/* AR_LISTINGS_SEARCH_LAYER_FINAL_START
   Listados móviles:
   El buscador sticky debe quedar por encima de la cabecera cuando empieza a subir.
   La cabecera se oculta por debajo de él y no debe tapar el buscador.
*/
@media (max-width: 900px) {
    html.ar-listings-page .site-header {
        z-index: 4200 !important;
        transition: transform .24s ease, opacity .22s ease, box-shadow .2s ease !important;
        will-change: transform, opacity;
    }

    html.ar-listings-page .ar-top-search--unified,
    html.ar-listings-page .ar-top-search {
        position: sticky !important;
        top: 0 !important;
        z-index: 6200 !important;
    }

    html.ar-listings-page.ar-listing-header-hidden .site-header {
        transform: translate3d(0, -100%, 0) !important;
        opacity: 0 !important;
        pointer-events: none !important;
    }

    html.ar-listings-page body.site-menu-open .site-header,
    html.ar-listings-page.ar-listing-header-hidden body.site-menu-open .site-header {
        transform: translate3d(0, 0, 0) !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 160000 !important;
    }

    html.ar-listings-page body.site-menu-open .site-nav {
        z-index: 160020 !important;
    }

    html.ar-listings-page body.site-menu-open .site-nav-backdrop {
        z-index: 159000 !important;
    }

    html.ar-listings-page body.site-menu-open .ar-top-search--unified,
    html.ar-listings-page body.site-menu-open .ar-top-search,
    html.ar-listings-page body.site-menu-open .ar-map-mobile-bar,
    html.ar-listings-page body.site-menu-open .ar-map-mobile-controls {
        opacity: 1 !important;
        visibility: visible !important;
        z-index: 158000 !important;
        pointer-events: none !important;
    }
}
/* AR_LISTINGS_SEARCH_LAYER_FINAL_END */

/* AR_MENU_PORTAL_DRAWER_LAYER_START
   El drawer puede estar temporalmente colgado del body.
*/
@media (max-width: 900px) {
    body.site-menu-open > .site-nav {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        z-index: 160020 !important;
        width: min(84vw, 330px) !important;
        height: 100dvh !important;
        min-height: 100dvh !important;
        max-height: 100dvh !important;
        transform: translate3d(0, 0, 0) !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
        background: #fff !important;
        box-shadow: 18px 0 54px rgba(15, 23, 42, .20) !important;
    }

    body.site-menu-open > .site-nav .site-nav__drawer-head {
        display: flex !important;
    }
}
/* AR_MENU_PORTAL_DRAWER_LAYER_END */

/* AR_MENU_CLEAN_SCROLL_AND_LAYERS_START
   Menú móvil:
   - El fondo no hace scroll mientras el menú está abierto.
   - El drawer sí puede hacer scroll internamente.
   - Cabecera/contenido quedan por debajo del blur.
   - El drawer queda por encima del blur.
*/
@media (max-width: 900px) {
    html.site-menu-open,
    body.site-menu-open {
        overflow: hidden !important;
        overscroll-behavior: none !important;
    }

    body[data-ar-menu-scroll-locked="1"] {
        overflow: hidden !important;
        touch-action: none !important;
    }

    body.site-menu-open .site-header {
        z-index: 158000 !important;
        pointer-events: none !important;
    }

    body.site-menu-open > .site-nav {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: min(84vw, 330px) !important;
        height: 100dvh !important;
        min-height: 100dvh !important;
        max-height: 100dvh !important;
        z-index: 160020 !important;
        transform: translate3d(0, 0, 0) !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-y !important;
        pointer-events: auto !important;
        background: #fff !important;
    }

    body.site-menu-open .site-nav-backdrop {
        position: fixed !important;
        inset: 0 !important;
        z-index: 159000 !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        overscroll-behavior: none !important;
        touch-action: none !important;
    }
}
/* AR_MENU_CLEAN_SCROLL_AND_LAYERS_END */

/* AR_DESKTOP_ACCOUNT_MENU_LAYER_AND_LOGOUT_START
   Menú global escritorio/tablet:
   El desplegable de cuenta debe quedar por encima del buscador/mapa/listados.
   El botón de cerrar sesión debe tener la misma estética que el resto del menú.
*/
@media (min-width: 901px) {
    .site-header:has(.site-nav__account[open]),
    .site-header:focus-within {
        z-index: 220000 !important;
        overflow: visible !important;
    }

    .site-header:has(.site-nav__account[open]) .site-header__bar,
    .site-header:focus-within .site-header__bar,
    .site-header:has(.site-nav__account[open]) .site-nav,
    .site-header:focus-within .site-nav,
    .site-header:has(.site-nav__account[open]) .site-nav__account,
    .site-header:focus-within .site-nav__account {
        overflow: visible !important;
    }

    .site-nav__account[open] .site-nav__account-menu {
        z-index: 220020 !important;
    }

    .site-nav .site-nav__account-logout {
        margin: 6px -2px 0 !important;
        padding: 8px 2px 0 !important;
        border-top: 1px solid #e5ebf1 !important;
        border-radius: 0 !important;
        background: transparent !important;
    }

    .site-nav .site-nav__account-logout button {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 9px !important;
        width: 100% !important;
        min-height: 40px !important;
        margin: 0 !important;
        padding: 0 11px !important;
        border: 0 !important;
        border-radius: 12px !important;
        background: #fff !important;
        color: var(--ar-ink-soft) !important;
        font-size: 14px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        text-align: left !important;
        text-decoration: none !important;
        cursor: pointer !important;
        box-sizing: border-box !important;
        appearance: none !important;
        -webkit-appearance: none !important;
    }

    .site-nav .site-nav__account-logout button:hover,
    .site-nav .site-nav__account-logout button:focus-visible {
        background: #fff4f4 !important;
        color: #8a1f1f !important;
        outline: none !important;
    }

    .site-nav .site-nav__account-logout button .ar-svg-icon {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        color: currentColor !important;
        stroke-width: 2 !important;
    }
}
/* AR_DESKTOP_ACCOUNT_MENU_LAYER_AND_LOGOUT_END */

/* ===== Consolidado desde ar-mobile-header-safe-fixes.css (Fase 2.2 refactor CSS) =====
   Cargaba justo despues de este archivo; orden/cascada preservados. ===== */
/*
 * Ajustes seguros del menú móvil.
 * No modifica listados, tarjetas, mapa ni contenidos SEO.
 */

@media (max-width: 900px) {
    .site-nav > .site-nav__drawer-head {
        flex: 0 0 66px !important;
        height: 66px !important;
        min-height: 66px !important;
        max-height: 66px !important;
        padding: 12px 16px !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
    }

    .site-nav > .site-nav__drawer-head .site-nav__drawer-brand {
        display: inline-flex !important;
        align-items: center !important;
        min-width: 0 !important;
        width: auto !important;
        max-width: calc(100% - 54px) !important;
        height: 42px !important;
        max-height: 42px !important;
        padding: 0 !important;
        margin: 0 !important;
        overflow: hidden !important;
    }

    .site-nav > .site-nav__drawer-head .site-nav__drawer-brand img {
        display: block !important;
        width: auto !important;
        height: auto !important;
        max-width: 205px !important;
        max-height: 31px !important;
        object-fit: contain !important;
    }

    .site-nav > .site-nav__drawer-head .site-nav__drawer-close {
        flex: 0 0 40px !important;
        width: 40px !important;
        min-width: 40px !important;
        height: 40px !important;
        min-height: 40px !important;
        max-height: 40px !important;
        margin: 0 !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-menu-label {
        display: block !important;
        padding: 10px 16px 8px 34px !important;
        color: var(--ar-ink-soft) !important;
        font-size: 13.5px !important;
        font-weight: 700 !important;
        line-height: 1.25 !important;
        background: var(--ar-surface-soft) !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-logout {
        display: block !important;
        margin: 4px 0 0 !important;
        padding: 8px 16px 0 34px !important;
        border-top: 1px solid var(--ar-line) !important;
        background: var(--ar-surface-soft) !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-logout button {
        appearance: none !important;
        -webkit-appearance: none !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        width: 100% !important;
        min-height: 42px !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        color: #8a1f1f !important;
        font: inherit !important;
        font-size: 14.5px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-align: left !important;
        text-decoration: none !important;
        box-shadow: none !important;
        cursor: pointer !important;
    }

    .site-nav .site-nav__account-menu .site-nav__account-logout button .ar-svg-icon {
        width: 20px !important;
        height: 20px !important;
        min-width: 20px !important;
        color: #8a1f1f !important;
    }
}

/* ====================================================================
   Bloqueo de scroll del menú SIN romper sticky
   --------------------------------------------------------------------
   Varios sitios ponían overflow:hidden en html/body al abrir el menú. En el
   contenedor de scroll eso ROMPE position:sticky (la cabecera y el nav de anclas
   de la ficha se iban fuera de pantalla). El bloqueo real lo hace site-header.js
   con preventDefault (touchmove/wheel), así que aquí restauramos el overflow para
   que el sticky siga funcionando. Cargado al final para ganar a las reglas previas.
   ==================================================================== */
@media (max-width: 900px) {
    /* html: estado normal (scroll vertical permitido) para que el sticky se ancle al viewport. */
    html.site-menu-open {
        overflow-x: hidden !important;
        overflow-y: auto !important;
    }
    /* body: overflow VISIBLE (no hidden/auto). Si fuera auto/hidden, el body se convierte en
       contenedor de scroll y la cabecera/nav sticky se anclarían a él (que no scrollea) en vez de
       al viewport -> se irían fuera de pantalla. El bloqueo de scroll lo hace site-header.js. */
    body.site-menu-open,
    body[data-ar-menu-scroll-locked="1"] {
        overflow: visible !important;
    }
}
