/* ==================================================================
   estia/property-carousel — style.css
   Copia da nuova_home/assets/css/card-immobili.css (intero, 405 righe).
   Selettori scope-isolated sotto .estia-property-carousel + adattati a render.php.
   ================================================================== */

.estia-property-carousel {
    /* Design tokens */
    --ci-primary: #0c3474;
    --ci-primary-hover: #234584;
    --ci-on-primary: #ffffff;
    --ci-secondary: #805600;
    --ci-secondary-container: #ffbd52;
    --ci-secondary-fixed: #ffddaf;
    --ci-on-secondary-container: #734d00;
    --ci-surface: #faf8ff;
    --ci-surface-container-lowest: #ffffff;
    --ci-surface-container-low: #f4f3f9;
    --ci-surface-container: #eeedf3;
    --ci-surface-container-high: #e8e7ee;
    --ci-outline: #747781;
    --ci-outline-variant: #c4c6d2;
    --ci-on-surface: #1a1b20;
    --ci-on-surface-variant: #434750;

    --ci-radius-sm: 0.375rem;
    --ci-radius-md: 0.5rem;
    --ci-radius-lg: 0.75rem;
    --ci-radius-full: 9999px;

    --ci-shadow-card: 0 1px 2px rgba(26, 27, 32, 0.04), 0 4px 16px rgba(26, 27, 32, 0.04);
    --ci-shadow-card-hover: 0 24px 48px -12px rgba(26, 27, 32, 0.12);

    --ci-gap: 24px;

    font-family: 'Montserrat', sans-serif;
    color: var(--ci-on-surface);
    background: var(--ci-surface-container-low);
    padding: 64px 0;
    box-sizing: border-box;
    /* La sezione contiene un .ci-carousel con .ci-track flex (scrollWidth ~2900px
       quando le card scrollano fuori dal viewport). Anche se .ci-carousel ha
       overflow:hidden, la propagazione dello scrollWidth ai parent può creare
       overflow-x sul body. Clip esplicito qui. */
    overflow-x: hidden;
}

.estia-property-carousel *,
.estia-property-carousel *::before,
.estia-property-carousel *::after {
    box-sizing: border-box;
}

/* ---------- Layout ---------- */
.estia-property-carousel .ci-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px;
}

.estia-property-carousel .ci-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

.estia-property-carousel .ci-header__text {
    flex: 1 1 320px;
    min-width: 0;
}

.estia-property-carousel .ci-title {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: clamp(1.75rem, 2.4vw, 2.25rem);
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--ci-primary);
    margin: 0;
}

.estia-property-carousel .ci-subtitle {
    color: var(--ci-outline);
    margin: 8px 0 0;
    font-size: 0.95rem;
    line-height: 1.5;
}

.estia-property-carousel .ci-header__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

/* ---------- Carousel navigation buttons ---------- */
.estia-property-carousel .ci-nav {
    display: inline-flex;
    gap: 8px;
}

.estia-property-carousel .ci-nav__btn {
    width: 44px;
    height: 44px;
    border-radius: var(--ci-radius-full);
    border: 0;
    background: var(--ci-surface-container-high);
    color: var(--ci-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.375rem;
    line-height: 1;
    transition: background-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}

.estia-property-carousel .ci-nav__btn:hover:not(:disabled) {
    background: var(--ci-secondary-fixed);
    transform: translateY(-1px);
}

.estia-property-carousel .ci-nav__btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.estia-property-carousel .ci-cta {
    display: inline-block;
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--ci-primary);
    text-decoration: none;
    padding-bottom: 4px;
    border-bottom: 2px solid var(--ci-secondary-container);
    transition: color 200ms ease;
}

.estia-property-carousel .ci-cta:hover {
    color: var(--ci-secondary);
}

/* ---------- Carousel ---------- */
/* margin negative removed (causava overflow-x ~12px sul body, "banda bianca" sul lato dx
   dato che l'ancestor .ci-section ha overflow: visible). Il padding interno mantiene
   il visual breathing per gli shadow delle card. */
.estia-property-carousel .ci-carousel {
    overflow: hidden;
    padding: 4px 12px 16px;
}

.estia-property-carousel .ci-track {
    display: flex;
    gap: var(--ci-gap);
    transition: transform 500ms cubic-bezier(0.22, 0.61, 0.36, 1);
    will-change: transform;
}

/* ---------- Card ---------- */
.estia-property-carousel .ci-card {
    flex: 0 0 calc((100% - (var(--ci-gap) * 3)) / 4);
    background: var(--ci-surface-container-lowest);
    border-radius: var(--ci-radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: var(--ci-shadow-card);
    transition: transform 300ms ease, box-shadow 300ms ease;
}

.estia-property-carousel .ci-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--ci-shadow-card-hover);
}

/* Card link wrapper (render.php wraps entire card in <a>) */
.estia-property-carousel .ci-card__link {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-decoration: none;
    color: inherit;
}

/* Media */
.estia-property-carousel .ci-card__media {
    position: relative;
    height: 220px;
    overflow: hidden;
}

.estia-property-carousel .ci-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 600ms ease;
}

.estia-property-carousel .ci-card:hover .ci-card__image {
    transform: scale(1.06);
}

.estia-property-carousel .ci-card__badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--ci-primary);
    color: var(--ci-on-primary);
    font-family: 'Manrope', sans-serif;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 6px 12px;
    border-radius: var(--ci-radius-sm);
    line-height: 1;
}

.estia-property-carousel .ci-card__badge--affitto {
    background: #1a5276;
}

/* Body */
.estia-property-carousel .ci-card__body {
    padding: 20px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}

.estia-property-carousel .ci-card__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.estia-property-carousel .ci-card__category {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ci-outline);
}

.estia-property-carousel .ci-card__price {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--ci-primary);
    white-space: nowrap;
}

.estia-property-carousel .ci-card__title {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 1.0625rem;
    line-height: 1.3;
    color: var(--ci-primary);
    margin: 4px 0 2px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.6em;
}

.estia-property-carousel .ci-card__title-link {
    color: inherit;
    text-decoration: none;
    transition: color 200ms ease;
}

.estia-property-carousel .ci-card__title-link:hover,
.estia-property-carousel .ci-card__title-link:focus-visible {
    color: var(--ci-primary-hover);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.estia-property-carousel .ci-card__address {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    font-size: 0.8125rem;
    color: var(--ci-on-surface-variant);
    line-height: 1.3;
}

.estia-property-carousel .ci-card__features {
    list-style: none;
    padding: 0;
    margin: 8px 0 16px;
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* ---------- "Visualizza" CTA button ---------- */
.estia-property-carousel .ci-card__button {
    margin-top: auto;
    align-self: stretch;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ci-primary);
    color: var(--ci-on-primary);
    text-decoration: none;
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 0.8125rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 12px 20px;
    border-radius: var(--ci-radius-md);
    border: 0;
    cursor: pointer;
    transition: background-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
    box-shadow: 0 4px 12px rgba(12, 52, 116, 0.18);
}

.estia-property-carousel .ci-card__button:hover,
.estia-property-carousel .ci-card__button:focus-visible {
    background: var(--ci-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(12, 52, 116, 0.28);
}

.estia-property-carousel .ci-card__button:active {
    transform: translateY(0);
}

.estia-property-carousel .ci-card__feature {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--ci-on-surface-variant);
}

/* ---------- Dots ---------- */
.estia-property-carousel .ci-dots {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 32px;
}

.estia-property-carousel .ci-dots__dot {
    width: 28px;
    height: 4px;
    border-radius: var(--ci-radius-full);
    border: 0;
    padding: 0;
    background: var(--ci-outline-variant);
    cursor: pointer;
    transition: background-color 200ms ease, width 200ms ease;
}

.estia-property-carousel .ci-dots__dot:hover {
    background: var(--ci-outline);
}

.estia-property-carousel .ci-dots__dot.is-active {
    background: var(--ci-primary);
    width: 40px;
}

/* ---------- Responsive ---------- */
@media (max-width: 1080px) {
    .estia-property-carousel .ci-card {
        flex-basis: calc((100% - (var(--ci-gap) * 2)) / 3);
    }
}

@media (max-width: 820px) {
    .estia-property-carousel {
        padding: 48px 0;
    }
    .estia-property-carousel .ci-container {
        padding: 0 24px;
    }
    .estia-property-carousel .ci-card {
        flex-basis: calc((100% - var(--ci-gap)) / 2);
    }
    .estia-property-carousel .ci-card__media {
        height: 200px;
    }
}

@media (max-width: 560px) {
    .estia-property-carousel .ci-header {
        margin-bottom: 28px;
    }
    .estia-property-carousel .ci-card {
        flex-basis: 100%;
    }
    .estia-property-carousel .ci-card__media {
        height: 220px;
    }
    .estia-property-carousel .ci-header__actions {
        width: 100%;
        justify-content: space-between;
    }
}

/* ---------- Accessibility ---------- */
.estia-property-carousel .ci-nav__btn:focus-visible,
.estia-property-carousel .ci-cta:focus-visible,
.estia-property-carousel .ci-dots__dot:focus-visible {
    outline: 2px solid var(--ci-secondary-container);
    outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .estia-property-carousel .ci-track,
    .estia-property-carousel .ci-card,
    .estia-property-carousel .ci-card__image,
    .estia-property-carousel .ci-nav__btn,
    .estia-property-carousel .ci-dots__dot {
        transition: none !important;
    }
}
