/* Refinamiento global final: consistencia, footer profesional y mejor aprovechamiento del espacio */
:root {
    --ar-ink: #172331;
    --ar-ink-soft: #344252;
    --ar-muted-2: #657382;
    --ar-green: #3f7f46;
    --ar-green-dark: #234f2a;
    --ar-lime: #8fbd33;
    --ar-surface: #ffffff;
    --ar-surface-soft: #f8faf5;
    --ar-line: #dce3eb;
    --ar-line-soft: #edf1f4;
    --ar-radius-lg: 22px;
    --ar-radius-md: 16px;
    --ar-shadow-soft: 0 14px 38px rgba(20, 30, 40, .07);
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    line-height: 1.45;
    background: linear-gradient(180deg, #f8f9f4 0%, #f2f3ee 100%) fixed !important;
    color: var(--ar-ink) !important;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

.wrap {
    width: min(1240px, calc(100% - 40px)) !important;
}

main {
    padding: 24px 0 54px !important;
}

.site-header {
    padding: 18px 0 !important;
    background: radial-gradient(circle at 14% 0%, rgba(255,255,255,.22) 0, transparent 32%), linear-gradient(135deg, #a9cc54 0%, #76a91e 58%, #5f8d15 100%) !important;
    box-shadow: 0 8px 26px rgba(28, 58, 20, .14) !important;
}

.site-header__bar {
    min-height: 62px;
}

.brand {
    max-width: 540px;
    font-size: clamp(29px, 3.2vw, 40px) !important;
    line-height: .98 !important;
    letter-spacing: -1.35px !important;
}

.brand small {
    max-width: 540px;
    margin-top: 7px !important;
    font-size: clamp(14px, 1.6vw, 18px) !important;
    line-height: 1.2 !important;
    opacity: .96 !important;
}

.site-nav a {
    min-height: 38px;
    padding: 8px 13px !important;
    border-radius: 999px !important;
    font-size: 15px;
    letter-spacing: -.1px;
}

.site-nav a.is-active,
.site-nav a:hover {
    background: rgba(255, 255, 255, .18) !important;
    text-decoration: none !important;
}

.site-nav-toggle {
    min-height: 46px !important;
    padding: 0 18px !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.16);
}

.panel,
.hero,
.ar-list-card,
.ar-favorites-hero,
.ar-favorite-card,
.ar-favorites-empty,
.ar-favorites-toolbar {
    border-color: var(--ar-line) !important;
    box-shadow: var(--ar-shadow-soft) !important;
}

input,
select,
textarea,
button {
    font-family: inherit !important;
}

input,
select,
textarea {
    border-color: var(--ar-line) !important;
    border-radius: 12px !important;
}

.ar-ui-button,
.button,
button.button,
.ar-search-button,
.ar-search-button-light,
.ar-map-button {
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.ar-ui-button:hover,
.button:hover,
button.button:hover,
.ar-search-button:hover,
.ar-search-button-light:hover,
.ar-map-button:hover {
    transform: translateY(-1px);
}

.ar-top-search {
    border-bottom-color: var(--ar-line-soft) !important;
}

.ar-search-input,
.ar-sort,
.ar-top-search select,
.ar-home-main-search select,
.ar-home-main-search input {
    min-height: 48px;
    border-radius: 14px !important;
    box-shadow: 0 1px 2px rgba(20,30,40,.04) !important;
}

.ar-results-head {
    margin: 20px 0 22px !important;
}

.ar-results-head h1 {
    letter-spacing: -1.2px;
}

/* Footer profesional */
.site-footer {
    position: relative;
    margin-top: 28px;
    padding: 42px 0 26px;
    color: #dbe8d5;
    text-align: left;
    background: radial-gradient(circle at 12% 0%, rgba(143, 189, 51, .24), transparent 30%), linear-gradient(135deg, #162a1a 0%, #244f29 55%, #19391e 100%);
    border-top: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 -12px 38px rgba(20,30,40,.06);
}

.site-footer a {
    color: #eef8e9 !important;
    text-decoration: none;
}

.site-footer a:hover {
    color: #fff !important;
    text-decoration: underline;
}

.site-footer__inner {
    display: grid;
    grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(170px, .7fr));
    gap: 28px;
    align-items: start;
}

.site-footer__brand-link {
    display: inline-block;
    color: #fff !important;
    font-size: 26px;
    font-weight: 950;
    letter-spacing: -.8px;
    line-height: 1.05;
}

.site-footer__brand p {
    max-width: 440px;
    margin: 12px 0 18px;
    color: #dbe8d5;
    font-size: 15px;
    line-height: 1.55;
}

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

.site-footer__trust span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border-radius: 999px;
    padding: 0 11px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    color: #f3faef;
    font-size: 13px;
    font-weight: 800;
}

.site-footer__col h2 {
    margin: 0 0 12px;
    color: #fff;
    font-size: 15px;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.site-footer__col nav,
.site-footer__links {
    display: grid !important;
    gap: 8px !important;
}

.site-footer__col a {
    display: inline-flex;
    width: fit-content;
    margin: 0 !important;
    padding: 0 !important;
    color: #dbe8d5 !important;
    font-size: 15px;
    font-weight: 650;
}

.site-footer__bottom {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 30px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.13);
    color: #bed1b8;
    font-size: 13px;
}

@media (min-width: 761px) {
    .site-nav-toggle {
        display: none !important;
    }
}

@media (max-width: 900px) {
    .site-footer__inner {
        grid-template-columns: 1fr 1fr;
    }
}

/* OWNER_PANEL_DUPLICATE_GUARD_START */
.owner-main-nav,
.owner-impersonation-compact {
    display: none !important;
}
/* OWNER_PANEL_DUPLICATE_GUARD_END */

/* TABLET_DRAWER_ACCOUNT_GUARD_START
   Entre 761px y 900px el menú ya es drawer móvil, pero algunos estilos de escritorio
   podían dejar sin pintar el bloque de cuenta/propietario. */
@media (min-width: 761px) and (max-width: 900px) {
    .site-nav-toggle {
        display: inline-flex !important;
    }

    body.site-menu-open .site-nav .site-nav__account,
    .site-nav .site-nav__account {
        display: grid !important;
        visibility: visible !important;
        opacity: 1 !important;
        width: 100% !important;
        min-height: 56px !important;
        height: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        flex: 0 0 auto !important;
        background: #fff !important;
        color: #172331 !important;
        overflow: visible !important;
    }

    .site-nav .site-nav__account > summary {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 13px !important;
        width: 100% !important;
        min-height: 56px !important;
        height: 56px !important;
        padding: 0 16px !important;
        border-left: 4px solid transparent !important;
        border-radius: 0 !important;
        background: #fff !important;
        color: #344252 !important;
        font-size: 15.5px !important;
        font-weight: 850 !important;
        text-align: left !important;
        text-shadow: none !important;
        box-sizing: border-box !important;
    }

    .site-nav .site-nav__account.is-active > summary,
    .site-nav .site-nav__account[open] > summary {
        background: #f8faf5 !important;
        color: #102015 !important;
        border-left-color: #3f7f46 !important;
    }

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

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

    .site-nav .site-nav__account-chevron {
        display: inline-flex !important;
        margin-left: auto !important;
    }

    .site-nav .site-nav__account > summary .ar-svg-icon {
        display: inline-block !important;
        width: 23px !important;
        height: 23px !important;
        min-width: 23px !important;
        color: #234f2a !important;
    }
}
/* TABLET_DRAWER_ACCOUNT_GUARD_END */

/* MOBILE_OVERFLOW_GUARD_START
   Evita que footer, migas de pan o bloques full-bleed ensanchen la página en Safari móvil. */
@media (max-width: 760px) {
    html,
    body {
        max-width: 100% !important;
        overflow-x: clip !important;
    }

    @supports not (overflow: clip) {
        html,
        body {
            overflow-x: hidden !important;
        }
    }

    .wrap {
        width: calc(100% - 24px) !important;
        max-width: calc(100vw - 24px) !important;
    }

    main,
    .site-header,
    .site-footer,
    .ar-public-shell,
    .ar-results-list,
    .ar-list-card,
    .ar-card-body,
    .ar-results-head,
    .ar-top-search,
    .ar-top-search__inner {
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }

    .site-footer {
        overflow: hidden !important;
    }

    .site-footer__inner {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 24px !important;
    }

    .site-footer__brand,
    .site-footer__col,
    .site-footer__brand-link,
    .site-footer__brand p,
    .site-footer__trust,
    .site-footer__bottom {
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .site-footer__brand-link--logo img,
    .site-footer__brand-link img {
        max-width: min(100%, 320px) !important;
        height: auto !important;
    }

    .site-footer__col a {
        width: auto !important;
        max-width: 100% !important;
        white-space: normal !important;
        overflow-wrap: break-word !important;
    }

    .site-footer__bottom {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .ar-top-search {
        margin-left: -12px !important;
        margin-right: -12px !important;
        overflow-x: clip !important;
    }

    .ar-top-search__inner {
        width: 100% !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .ar-results-head {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .ar-results-head h1 {
        max-width: 100% !important;
        overflow-wrap: break-word !important;
    }

    .ar-results-head form,
    .ar-sort {
        width: 100% !important;
        max-width: 100% !important;
    }

    .ar-breadcrumb {
        display: flex !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding-bottom: 6px !important;
        white-space: nowrap !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .ar-breadcrumb::-webkit-scrollbar {
        display: none !important;
    }

    .ar-breadcrumb a,
    .ar-breadcrumb span {
        flex: 0 0 auto !important;
    }
}
/* MOBILE_OVERFLOW_GUARD_END */