/**
 * Discovery listing cards — SSOT (owner explore, user home, guest homepage catalog).
 * Pair with: .role-home-listings-grid + .role-home-card on <x-card.listing compact-ui>.
 * Load after: design-tokens.css, components/listing-card.css
 * v1.5.0: Listing-page grid/featured parity; compact-ui flex order reset; featured horizontal track.
 * v1.6.0: Homepage recently viewed grid; markup uses .role-home-listings-grid only (no .guest-listings-grid).
 * v1.6.3: Catalog/discovery cells stretch to column width (removed 280px cap + centering that caused white bands).
 */

.role-home-grid {
    gap: 14px;
}

/*
 * Discovery catalog grid — responsive columns from --discovery-card-min; cells fill track width.
 * Last row may still have empty columns when count is not a multiple of column count (grid behavior).
 * Batch size: mobile 12; wide dashboards use ?per_page= (discovery-feed-per-page.js) for ~3 full rows.
 */
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) {
    --discovery-card-min: 260px;
    --discovery-card-max: 280px; /* recently-viewed horizontal strip only */
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--discovery-card-min)), 1fr));
    justify-content: start;
    justify-items: stretch;
    align-items: stretch;
    gap: clamp(14px, 1.1vw, 18px);
    width: 100%;
    min-width: 0;
}

.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > div,
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > article,
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > .listing-grid__card,
#listingGridRow.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > .listing-grid__card,
#listingGridRow.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > .listing-grid__skeleton-card,
#homeCatalogGrid.role-home-listings-grid > [role="listitem"],
#userDiscoveryGrid.role-home-listings-grid > [role="listitem"],
#ownerDiscoveryGrid.role-home-listings-grid > [role="listitem"] {
    display: flex;
    flex: unset;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    justify-self: stretch;
    box-sizing: border-box;
}

.role-home-listings-grid > div > .card,
.role-home-listings-grid > article > .card {
    width: 100%;
    height: 100%;
}

.role-home-listings-grid > .role-home-listings-grid__empty,
.role-home-listings-grid > .homepage-v2-catalog__empty-state,
.role-home-listings-grid > .listing-grid__empty {
    flex: 1 1 100%;
    max-width: 100%;
    width: 100%;
    display: block;
}

/*
 * Empty catalog (0 results): center panel in grid/list, map sidebar, discovery feeds.
 * Specificity must beat .role-home-listings-grid:not(.listing-grid--count-*) { display: grid }.
 */
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child),
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .role-home-listings-grid__empty:only-child),
.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .homepage-v2-catalog__empty-state:only-child),
#listingGridRow.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child),
#listingMapSidebarRow.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child),
#homeCatalogGrid.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child),
#ownerDiscoveryGrid.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child),
#userDiscoveryGrid.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3):has(> .listing-grid__empty:only-child) {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    justify-items: center;
    min-height: min(52vh, 28rem);
    width: 100%;
    gap: 0;
}

.role-home-listings-grid > .listing-grid__empty:only-child,
.role-home-listings-grid > .role-home-listings-grid__empty:only-child,
.role-home-listings-grid > .homepage-v2-catalog__empty-state:only-child,
#listingGridRow > .listing-grid__empty:only-child,
#listingMapSidebarRow > .listing-grid__empty:only-child,
#homeCatalogGrid > .listing-grid__empty:only-child,
#ownerDiscoveryGrid > .listing-grid__empty:only-child,
#userDiscoveryGrid > .listing-grid__empty:only-child {
    flex: 0 1 auto;
    width: 100%;
    max-width: 36rem;
    margin-inline: auto;
    align-self: center;
    justify-self: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    box-sizing: border-box;
}

.role-home-listings-grid > .listing-grid__empty:only-child .empty-state,
#listingGridRow > .listing-grid__empty:only-child .empty-state,
#listingMapSidebarRow > .listing-grid__empty:only-child .empty-state {
    width: 100%;
    margin-inline: auto;
}

.role-home-listings-grid > .listing-grid__empty:only-child .suggested-types,
#listingGridRow > .listing-grid__empty:only-child .suggested-types {
    width: 100%;
    text-align: center;
}

.role-home-listings-grid .card.card--listing {
    text-decoration: none;
}

.role-home-listings-grid .card.card--listing:hover,
.role-home-listings-grid .card.card--listing:focus,
.role-home-listings-grid .card.card--listing:active,
.role-home-listings-grid .card.card--listing:focus-within {
    text-decoration: none;
}

.role-home-listings-grid .card.card--listing :is(
    .card--listing__title,
    .card--listing__compact-price,
    .card--listing__compact-meta,
    .card--listing__compact-rating,
    .card--listing__compact-sep
) {
    text-decoration: none;
}

.role-home-listings-grid .card--listing__details {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 10px 2px 0;
    flex: 1 1 auto;
    min-height: 0;
}

.role-home-card {
    border: 0;
    border-radius: 18px;
    overflow: visible;
    box-shadow: none;
    transition: transform 0.2s ease;
    background: transparent;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.role-home-card:hover {
    transform: translateY(-2px);
}

.role-home-card .card--listing__image {
    position: relative;
    flex: 0 0 auto;
    border-radius: 18px;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: var(--color-neutral-200);
    box-shadow: 0 10px 20px color-mix(in srgb, var(--color-neutral-900) 12%, transparent);
}

.role-home-card .card--listing__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.28s ease;
}

.role-home-card:hover .card--listing__img {
    transform: scale(1.03);
}

.role-home-listings-grid .card--listing__title {
    min-height: 1.35em;
    font-size: 1.1rem;
    line-height: 1.28;
    color: var(--text-primary);
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 0;
}

.role-home-listings-grid .card--listing__host-type,
.role-home-card .card--listing__meta-line {
    display: none;
}

.role-home-listings-grid .card--listing__location {
    min-height: 1.2em;
}

.role-home-card .card--listing__host-type {
    display: inline-flex;
    width: fit-content;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-primary-600);
    background: var(--color-primary-50);
    border: 1px solid var(--color-primary-100);
    border-radius: 999px;
    padding: 3px 8px;
}

.role-home-card .card--listing__location {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--text-secondary);
    font-size: 0.85rem;
    line-height: 1.3;
}

.role-home-card .card--listing__location--empty {
    visibility: hidden;
}

.role-home-card .card--listing__signal-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.role-home-card .card--listing__compact-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: auto;
    color: var(--text-tertiary);
    font-size: 0.95rem;
    font-weight: 500;
}

.role-home-card .card--listing__compact-price {
    color: var(--text-tertiary);
}

.role-home-card .card--listing__compact-sep {
    color: var(--color-neutral-400);
}

.role-home-card .card--listing__compact-rating {
    color: var(--text-secondary);
    font-weight: 600;
}

.role-home-card .card--listing__compact-included {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.15rem;
    font-size: var(--font-size-2xs, 0.6875rem);
    color: var(--text-secondary);
    line-height: 1.35;
}

.role-home-card .card--listing__compact-included .fas {
    color: var(--color-primary-600);
    font-size: 0.72rem;
}

/* compact-ui: natural DOM order (title → location → included → price); cancel legacy listing-list flex order */
.role-home-card .card--listing__details > .card--listing__title,
.role-home-card .card--listing__details > .card--listing__signal-pills,
.role-home-card .card--listing__details > .card--listing__location,
.role-home-card .card--listing__details > .card--listing__compact-included,
.role-home-card .card--listing__details > .card--listing__compact-meta,
.role-home-card .card--listing__details > .card--listing__host-type,
.role-home-card .card--listing__details > .card--listing__meta-line {
    order: unset;
}

/* Guest listing catalog: discovery grid wins over legacy listing-list flex */
.listing-page #listingGridRow.role-home-listings-grid.role-home-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--discovery-card-min)), 1fr));
    justify-content: start;
    justify-items: stretch;
    align-items: stretch;
    gap: clamp(14px, 1.1vw, 18px);
}

/* Featured “In evidenza”: responsive smart grid (wins over legacy listing-list flex) */
.listing-page .listing-featured__scroll.role-home-listings-grid.role-home-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    gap: clamp(12px, 1.1vw, 18px);
    overflow: visible;
    padding-bottom: 0;
}

.listing-page .listing-featured__scroll.role-home-listings-grid > .listing-featured__card {
    width: 100%;
    min-width: 0;
    max-width: none;
    flex: unset;
}

.listing-page .listing-featured__scroll.role-home-listings-grid:has(.listing-featured__card:only-child) {
    justify-items: center;
}

.listing-page .listing-featured__scroll.role-home-listings-grid:has(.listing-featured__card:only-child) > .listing-featured__card {
    max-width: min(100%, 320px);
    width: 100%;
}

@media (max-width: 479.98px) {
    .listing-page .listing-featured__scroll.role-home-listings-grid.role-home-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 768px) {
    .listing-page .listing-featured__scroll.role-home-listings-grid.role-home-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .listing-page .listing-featured__scroll.role-home-listings-grid.role-home-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.role-home-card .card--listing__image .card--listing__image-badge {
    top: 0.65rem;
    left: 0.65rem;
}

/* Homepage recently viewed (1–5 items): same track width as catalog, no full-row stretch */
.homepage-v2-recent .home-cards-scroll .role-home-listings-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--discovery-card-min)), var(--discovery-card-max)));
    justify-content: start;
}

.role-home-grid--spotlight .role-home-card.card--listing--compact {
    outline: 1px solid var(--color-primary-200);
    outline-offset: 2px;
    border-radius: 20px;
}

@media (max-width: 640px) {
    .role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) {
        grid-template-columns: 1fr;
    }

    .role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > div,
    .role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > article,
    .role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > .listing-grid__card,
    #listingGridRow.role-home-listings-grid:not(.listing-grid--count-1):not(.listing-grid--count-2):not(.listing-grid--count-3) > .listing-grid__card,
    #homeCatalogGrid.role-home-listings-grid > [role="listitem"],
#userDiscoveryGrid.role-home-listings-grid > [role="listitem"],
#ownerDiscoveryGrid.role-home-listings-grid > [role="listitem"] {
        max-width: none;
        justify-self: stretch;
    }
}

/* Pochi risultati (1–3): neutralizza micro-tile legacy di listing-list.css sul container */
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-1,
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-2,
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-3 {
    max-width: 100%;
    width: 100%;
}

.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-1,
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-2 {
    display: grid;
    gap: clamp(14px, 1.1vw, 18px);
    justify-content: center;
}

.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-1 {
    grid-template-columns: minmax(0, min(100%, 360px));
}

.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-2 {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

@media (min-width: 575.98px) {
    .listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: min(100%, 720px);
        margin-left: auto;
        margin-right: auto;
    }
}

.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-3 {
    display: grid;
    gap: clamp(14px, 1.1vw, 18px);
    grid-template-columns: 1fr;
    max-width: min(100%, 1080px);
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 575.98px) {
    .listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 767.98px) {
    .listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-1 > .listing-grid__card,
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-2 > .listing-grid__card,
.listing-page #listingGridRow.role-home-listings-grid.listing-grid--count-3 > .listing-grid__card {
    max-width: min(100%, 360px);
    justify-self: center;
}

.listing-page #listingMapView .listing-map-sidebar .role-home-listings-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
}

.listing-page #listingMapView .listing-map-sidebar .role-home-listings-grid > .listing-grid__card {
    width: 100%;
    max-width: none;
}

@media (min-width: 768px) {
    .listing-page #listingMapView .listing-map-sidebar .role-home-listings-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .listing-page #listingMapView .listing-map-sidebar .role-home-listings-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card.card--listing--compact,
.listing-page .listing-featured__scroll .listing-featured__card .role-home-card.card--listing--compact,
.listing-page #listingMapView .listing-map-sidebar .listing-grid__card .role-home-card.card--listing--compact {
    border: 0;
    box-shadow: none;
    overflow: visible;
    background: transparent;
    border-radius: 18px;
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__image,
.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__image--ratio,
.listing-page .listing-featured__scroll .role-home-card .card--listing__image,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__image {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: 18px;
    overflow: hidden;
    min-height: 0;
    box-shadow: 0 10px 20px color-mix(in srgb, var(--color-neutral-900) 12%, transparent);
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__image .card--listing__img,
.listing-page .listing-featured__scroll .role-home-card .card--listing__image .card--listing__img,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__image .card--listing__img {
    position: static;
    inset: auto;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__details,
.listing-page .listing-featured__scroll .role-home-card .card--listing__details,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__details {
    padding: 10px 2px 0;
    gap: 5px;
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__title,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__title {
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.28;
    min-height: 1.35em;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    display: block;
    overflow: visible;
}

.listing-page .listing-featured__scroll .role-home-card .card--listing__title {
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.28;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    overflow-wrap: normal;
    word-break: normal;
    min-height: calc(1.28em * 2);
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__location,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__location {
    display: inline-flex;
    color: var(--text-secondary);
    font-size: 0.85rem;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    overflow: visible;
}

.listing-page .listing-featured__scroll .role-home-card .card--listing__location {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    line-clamp: 1;
    overflow: hidden;
    color: var(--text-secondary);
    font-size: 0.85rem;
    overflow-wrap: normal;
    word-break: normal;
    min-height: 1.3em;
}

.listing-page .role-home-listings-grid .listing-grid__card .role-home-card .card--listing__meta-line,
.listing-page .listing-featured__scroll .role-home-card .card--listing__meta-line,
.listing-page #listingMapView .listing-map-sidebar .role-home-card .card--listing__meta-line {
    display: none;
}

@media (hover: hover) and (pointer: fine) {
    .listing-page .role-home-listings-grid .listing-grid__card .role-home-card.card--listing--compact:hover,
    .listing-page .listing-featured__scroll .role-home-card.card--listing--compact:hover {
        transform: translateY(-2px);
        box-shadow: none;
    }
}
