/* ==================================================================
   estia/profili-interattivi — style.css

   Fusione visiva di box-icone (4 icone in cima) + slide-locatore-inquilino
   (slide ricca sotto). Hover su un'icona attiva la slide corrispondente.

   Scope rigido .estia-profili-interattivi__* (CLAUDE.md §5.2).
   Niente modifiche ai CSS dei 2 block originali.
   ================================================================== */

/* ============================================================
   1. Wrapper + tokens locali
   ============================================================ */
.estia-profili-interattivi {
    --pi-blue:        #4C70AF;
    --pi-blue-dark:   #243E6A;
    --pi-yellow:      #F5BE42;
    --pi-yellow-bar:  #F8CA28;
    --pi-gold:        #F5BE42;
    --pi-gold-hover:  #E5A821;
    --pi-sep:         #C5C4C1;
    --pi-white:       #FFFFFF;
    --pi-dur:         220ms;
    --pi-ease:        cubic-bezier(.2,.7,.2,1);
    --pi-radius-btn:  8px;

    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
    box-sizing: border-box;
    background: #fff;
}
.estia-profili-interattivi,
.estia-profili-interattivi *,
.estia-profili-interattivi *::before,
.estia-profili-interattivi *::after {
    box-sizing: inherit;
}

/* ============================================================
   2. Claim (heading sopra le icone)
   ============================================================ */
.estia-profili-interattivi__claim {
    margin: 0 auto clamp(24px, 3vw, 56px);
    max-width: 920px;
    text-align: center;
    font-weight: 700;
    font-size: clamp(20px, 2.4vw, 36px);
    line-height: 1.25;
    color: var(--pi-blue-dark);
    letter-spacing: -0.01em;
    padding: clamp(30px, 3.5vw, 55px) clamp(24px, 4vw, 72px) 0;
}

/* ============================================================
   3. 4 icone tablist (riuso pattern box-icone)
   ============================================================ */
.estia-profili-interattivi__icons {
    display: flex;
    align-items: stretch;
    justify-content: center;
    width: 100%;
    max-width: 2190px;
    margin: 0 auto;
    padding: clamp(30px, 3.5vw, 55px) clamp(24px, 4vw, 72px);
    color: var(--pi-yellow);
}
.estia-profili-interattivi__icon-btn {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: clamp(40px, 6.35vw, 140px) clamp(8px, 2vw, 60px);
    background: 0 0;
    border: 0;
    cursor: pointer;
    user-select: none;
    color: inherit;
    font: inherit;
    text-decoration: none;
    outline: 0;
    -webkit-tap-highlight-color: transparent;
    transition: color var(--pi-dur) var(--pi-ease), opacity var(--pi-dur) ease;
}
.estia-profili-interattivi__icon-btn + .estia-profili-interattivi__icon-btn {
    border-left: 1px solid var(--pi-sep);
}
.estia-profili-interattivi__icon {
    width: clamp(54px, 5.7vw, 125px);
    height: clamp(54px, 5.7vw, 125px);
    flex: 0 0 auto;
    display: block;
    color: inherit;
    transition: transform var(--pi-dur) var(--pi-ease);
}
.estia-profili-interattivi__icon svg {
    width: 100%;
    height: 100%;
    display: block;
    overflow: visible;
    fill: currentColor;
}
.estia-profili-interattivi__label {
    margin-top: clamp(18px, 2.4vw, 52px);
    width: 100%;
    font-weight: 700;
    font-size: clamp(13px, 1.05vw, 21px);
    letter-spacing: 0.02em;
    line-height: 1.25;
    text-align: center;
    text-transform: uppercase;
    color: inherit;
    overflow-wrap: break-word;
    text-wrap: balance;
    transition: transform var(--pi-dur) var(--pi-ease);
}

@media (hover: hover) {
    .estia-profili-interattivi__icon-btn:hover {
        color: var(--pi-blue);
    }
    .estia-profili-interattivi__icon-btn:hover .estia-profili-interattivi__icon {
        transform: translateY(-4px) scale(1.05);
    }
    .estia-profili-interattivi__icon-btn:hover .estia-profili-interattivi__label {
        transform: translateY(-2px);
    }
    .estia-profili-interattivi__icons:hover .estia-profili-interattivi__icon-btn:not(:hover):not(.is-active) {
        opacity: 0.55;
    }
}

.estia-profili-interattivi__icon-btn:focus-visible {
    color: var(--pi-blue);
    outline: 2px solid currentColor;
    outline-offset: 6px;
    border-radius: 4px;
}
.estia-profili-interattivi__icon-btn:focus-visible .estia-profili-interattivi__icon {
    transform: translateY(-4px) scale(1.05);
}

.estia-profili-interattivi__icon-btn.is-active {
    color: var(--pi-blue);
}
.estia-profili-interattivi__icon-btn.is-active .estia-profili-interattivi__icon {
    transform: translateY(-4px) scale(1.08);
}
.estia-profili-interattivi__icon-btn.is-active .estia-profili-interattivi__label {
    text-decoration: none;
}

/* ============================================================
   4. Slide container — desktop (riuso pattern slide-locatore-inquilino)
   ============================================================ */
.estia-profili-interattivi__slides {
    position: relative;
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    aspect-ratio: 1984 / 1072;    /* = 2190 - 206 (rimossa arrow strip) */
    background: var(--pi-blue);
    overflow: hidden;
    box-shadow: 0 18px 46px -12px rgba(0, 0, 0, .22);
    container-type: inline-size;
    isolation: isolate;
}
.estia-profili-interattivi__slide {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: 1097fr 887fr;
    grid-template-rows: 1fr;
    opacity: 0;
    pointer-events: none;
    transition: opacity 400ms ease;
    will-change: opacity;
}
.estia-profili-interattivi__slide.is-active {
    opacity: 1;
    pointer-events: auto;
}

.estia-profili-interattivi__content {
    padding: 4.79cqw 6.62cqw 3.56cqw 9.27cqw;
    display: flex;
    flex-direction: column;
    color: var(--pi-white);
    letter-spacing: 0.02em;
}

.estia-profili-interattivi__eyebrow {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 1.28cqw;
    line-height: 1;
}
.estia-profili-interattivi__eyebrow-bar {
    flex-shrink: 0;
    width: 4.93cqw;
    height: 0.73cqw;
    background: var(--pi-yellow-bar);
}
.estia-profili-interattivi__eyebrow-label {
    font-weight: 700;
    font-size: 1.315cqw;
    letter-spacing: 0.02em;
}

.estia-profili-interattivi__title {
    margin: 4.29cqw 0 1.6cqw;
    font-weight: 700;
    font-size: 1.972cqw;
    line-height: 1.1;
    letter-spacing: 0.02em;
    color: var(--pi-white);
}

.estia-profili-interattivi__lead,
.estia-profili-interattivi__body,
.estia-profili-interattivi__benefits,
.estia-profili-interattivi__deadline {
    font-weight: 500;
    font-size: 1.132cqw;
    line-height: 1.42;
    letter-spacing: 0.02em;
}
.estia-profili-interattivi__lead {
    margin: 0 0 1.2cqw;
    font-weight: 500;
}
.estia-profili-interattivi__body { margin: 0 0 1.2cqw; }
.estia-profili-interattivi__body:last-of-type { margin-bottom: 1.6cqw; }

/* Slide senza h3 (es. Venditore/Acquirente/Inquilino): il lead diventa
   il "titolo" della card e usa la stessa scala del __title di LOCATORE,
   con margin-top per aria sotto l'eyebrow. */
.estia-profili-interattivi__slide--no-title .estia-profili-interattivi__lead {
    margin: 4.29cqw 0 1.6cqw;
    font-weight: 700;
    font-size: 1.972cqw;
    line-height: 1.1;
    letter-spacing: 0.02em;
    color: var(--pi-white);
}
.estia-profili-interattivi__benefits {
    margin: 0 0 1.6cqw;
    padding: 0;
    list-style: none;
}
.estia-profili-interattivi__benefits li {
    position: relative;
    padding-left: 1.05em;
}
.estia-profili-interattivi__benefits li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0;
    font-weight: 500;
}
.estia-profili-interattivi__deadline { margin: 0; }

.estia-profili-interattivi__actions {
    margin-top: auto;
    padding-top: 2.5cqw;
    display: flex;
    gap: 1.32cqw;
    letter-spacing: 0;
}
.estia-profili-interattivi__btn {
    flex: 0 0 auto;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 15.98cqw;
    height: 3.56cqw;
    background: var(--pi-gold);
    color: var(--pi-white);
    font-weight: 700;
    font-size: 0.996cqw;
    line-height: 1.15;
    letter-spacing: 0;
    text-decoration: none;
    border: 0;
    border-radius: var(--pi-radius-btn);
    cursor: pointer;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    transition: background-color 180ms ease, transform 120ms ease, box-shadow 180ms ease;
}
.estia-profili-interattivi__btn-line { display: block; }
.estia-profili-interattivi__btn:hover {
    background: var(--pi-gold-hover);
    box-shadow: 0 6px 14px -6px rgba(0, 0, 0, .3);
}
.estia-profili-interattivi__btn:focus-visible {
    outline: 2px solid var(--pi-white);
    outline-offset: 3px;
}
.estia-profili-interattivi__btn:active {
    transform: translateY(1px);
    box-shadow: 0 2px 6px -3px rgba(0, 0, 0, .3);
}

.estia-profili-interattivi__photo {
    position: relative;
    overflow: hidden;
    background: var(--pi-blue);
}
.estia-profili-interattivi__photo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

/* ============================================================
   5. MOBILE + SMALL TABLET (< 1024px) — vertical stack
   ============================================================ */
@media (max-width: 1023px) {
    .estia-profili-interattivi__icons {
        padding: clamp(20px, 6vw, 32px) clamp(8px, 3vw, 16px);
    }
    .estia-profili-interattivi__icon-btn {
        padding: clamp(18px, 4vw, 28px) clamp(4px, 1.5vw, 12px);
    }
    .estia-profili-interattivi__icon {
        width: 48px;
        height: 48px;
    }
    .estia-profili-interattivi__label {
        margin-top: 14px;
        font-size: 11px;
        letter-spacing: 0;
        line-height: 1.25;
    }

    .estia-profili-interattivi__slides {
        max-width: 100%;
        aspect-ratio: auto;
        display: block;
        background: var(--pi-blue);
        box-shadow: none;
        overflow: visible;
        container-type: normal;
    }
    .estia-profili-interattivi__slide {
        position: relative;
        inset: auto;
        display: flex;
        flex-direction: column;
        opacity: 1;
        pointer-events: auto;
        transition: none;
    }
    .estia-profili-interattivi__slide:not(.is-active) {
        display: none;
    }
    .estia-profili-interattivi__photo {
        width: 100%;
        aspect-ratio: 16 / 9;
        order: 1;
    }
    .estia-profili-interattivi__content {
        order: 2;
        padding: clamp(28px, 8vw, 44px) clamp(22px, 6vw, 32px);
    }

    .estia-profili-interattivi__eyebrow {
        gap: 12px;
    }
    .estia-profili-interattivi__eyebrow-bar {
        width: 40px;
        height: 6px;
    }
    .estia-profili-interattivi__eyebrow-label {
        font-size: 14px;
        letter-spacing: 0.05em;
    }
    .estia-profili-interattivi__title {
        margin: 22px 0 16px;
        font-size: clamp(22px, 6.2vw, 30px);
        line-height: 1.2;
        overflow-wrap: break-word;
        word-break: normal;
        hyphens: auto;
    }
    .estia-profili-interattivi__title br { display: none; }

    .estia-profili-interattivi__lead,
    .estia-profili-interattivi__body,
    .estia-profili-interattivi__benefits,
    .estia-profili-interattivi__deadline {
        font-size: clamp(14px, 4vw, 17px);
        line-height: 1.5;
        overflow-wrap: break-word;
    }
    .estia-profili-interattivi__lead { margin-bottom: 14px; font-weight: 500; }
    .estia-profili-interattivi__body { margin: 0 0 14px; }

    .estia-profili-interattivi__slide--no-title .estia-profili-interattivi__lead {
        margin: 22px 0 16px;
        font-weight: 700;
        font-size: clamp(22px, 6.2vw, 30px);
        line-height: 1.2;
        letter-spacing: 0.02em;
    }
    .estia-profili-interattivi__benefits { margin-bottom: 18px; }
    .estia-profili-interattivi__deadline { margin: 0 0 24px; }
    .estia-profili-interattivi__benefits li { padding-left: 1.25em; }
    .estia-profili-interattivi__benefits li + li { margin-top: 6px; }

    .estia-profili-interattivi__actions {
        margin-top: 0;
        padding-top: 0;
        flex-direction: column;
        gap: 12px;
    }
    .estia-profili-interattivi__btn {
        flex-direction: row;
        width: 100%;
        height: auto;
        min-height: 52px;
        padding: 14px 16px;
        font-size: 14px;
        line-height: 1.2;
        gap: 6px;
    }
    .estia-profili-interattivi__btn-line { display: inline; }
}

/* ============================================================
   6. Very wide screens — cap width come slide originale
   ============================================================ */
@media (min-width: 1500px) {
    .estia-profili-interattivi__slides { max-width: 1400px; }
}

/* ============================================================
   7. Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    .estia-profili-interattivi__slide,
    .estia-profili-interattivi__icon,
    .estia-profili-interattivi__icon-btn,
    .estia-profili-interattivi__label,
    .estia-profili-interattivi__btn {
        transition: none !important;
    }
    .estia-profili-interattivi__icon-btn:hover .estia-profili-interattivi__icon,
    .estia-profili-interattivi__icon-btn.is-active .estia-profili-interattivi__icon,
    .estia-profili-interattivi__icon-btn:focus-visible .estia-profili-interattivi__icon {
        transform: none;
    }
}
