/* =============================================================
   layout.css — Header, Hero, Card, Footer (struttura)
   Precondition: tokens.css, base.css
   ============================================================= */

/* ========== HEADER ========== */
.site-header {
    background: var(--blue-header);
    height: 80px;
    display: flex;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 50;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1);
}

.header-inner {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-8);
    display: flex;
    align-items: center;
    gap: var(--space-8);
}

.logo {
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    color: var(--white);
}

.logo__text {
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
}

.logo__mark {
    color: var(--yellow);
    font-size: 0.625rem;
    font-weight: 700;
    vertical-align: super;
    margin-left: 2px;
}

.main-nav {
    display: flex;
    gap: var(--space-7);
    flex: 1 1 auto;
    justify-content: center;
}

.main-nav a {
    color: var(--white);
    font-weight: 500;
    font-size: 0.875rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    transition: color var(--dur-base);
    white-space: nowrap;
}

.main-nav a:hover {
    color: var(--yellow);
}

.btn-stima {
    background: var(--yellow);
    color: var(--blue-dark);
    padding: 10px var(--space-6);
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.875rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: background var(--dur-base), transform var(--dur-fast);
    box-shadow: var(--shadow-stima);
    flex: 0 0 auto;
}

.btn-stima:hover {
    background: var(--yellow-hover);
}

.btn-stima:active {
    transform: translateY(1px);
}

.menu-toggle {
    display: none;
    color: var(--white);
    padding: var(--space-2);
    margin-left: auto;
}

.menu-toggle svg {
    width: 28px;
    height: 28px;
}

/* ========== HERO + CARD del valutatore originale (scoped a .estia-valutatore) ==========
   Queste regole erano globali (.hero, .card) e interferivano con altri block (hero-slideshow,
   ecosystem-card, ecc.). Scope-isolate al solo block valutatore con prefix .estia-valutatore. */
.estia-valutatore.hero {
    position: relative;
    background: var(--blue-hero);
    background-image:
        linear-gradient(135deg, var(--hero-overlay-start) 0%, var(--hero-overlay-end) 100%),
        url('../img/hero.jpg');
    background-size: cover;
    background-position: center;
    padding: var(--space-12) var(--space-6);
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1 0 auto;
}

.estia-valutatore.hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--hero-vignette);
    pointer-events: none;
}

.estia-valutatore .card {
    position: relative;
    z-index: 2;
    background: var(--white);
    border-radius: var(--radius-xl);
    border-top: 4px solid var(--yellow);
    width: 100%;
    max-width: var(--card-max);
    padding: var(--space-14) 72px var(--space-12);
    box-shadow: var(--shadow-card);
}

/* ========== FOOTER ========== */
.site-footer {
    background: var(--blue-footer);
    color: var(--white);
    border-top: 4px solid var(--yellow);
    padding: 72px var(--space-12) var(--space-6);
}

.footer-inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1.3fr 1.4fr;
    gap: var(--space-16);
}

.footer-col h4 {
    color: var(--white);
    font-size: 1.25rem;
    font-weight: 800;
    margin: 0 0 var(--space-7);
}

.footer-brand .brand-logo svg {
    height: 34px;
    width: auto;
    margin-bottom: 22px;
}

.footer-brand p {
    color: var(--footer-link);
    font-size: 0.9375rem;
    line-height: 1.55;
    margin: 0 0 26px;
    max-width: 260px;
}

.footer-brand .socials {
    list-style: none;
    padding: 0;
    margin: var(--space-2) 0 0;
    display: flex;
    gap: 18px;
}

.footer-brand .socials a {
    color: var(--footer-link);
    transition: color var(--dur-base), transform var(--dur-base);
    display: inline-flex;
}

.footer-brand .socials a:hover {
    color: var(--white);
    transform: translateY(-2px);
}

.footer-brand .socials svg {
    width: 22px;
    height: 22px;
}

.footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.footer-col ul a {
    color: var(--footer-link);
    font-size: 0.9375rem;
    font-weight: 400;
    transition: color var(--dur-base);
}

.footer-col ul a:hover {
    color: var(--white);
}

.newsletter p {
    color: var(--footer-link);
    font-size: 0.9375rem;
    line-height: 1.55;
    margin: 0 0 var(--space-5);
}

.newsletter input[type="email"] {
    width: 100%;
    background: var(--input-dark);
    border: 0;
    padding: 14px 18px;
    color: var(--white);
    font-size: 0.9375rem;
    border-radius: var(--radius-sm);
    font-family: inherit;
}

.newsletter input[type="email"]::placeholder {
    color: var(--footer-muted);
}

.newsletter button {
    width: 100%;
    margin-top: 14px;
    background: var(--yellow);
    color: var(--blue-dark);
    padding: 14px;
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: background var(--dur-base);
}

.newsletter button:hover {
    background: var(--yellow-hover);
}

/* ========== FOOTER BOTTOM BAR ========== */
.footer-bottom {
    max-width: var(--container-max);
    margin: var(--space-10) auto 0;
    padding-top: var(--space-8);
    border-top: 1px solid rgba(255, 255, 255, .1);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-4);
    font-size: 0.75rem;
    color: var(--footer-muted);
}

.footer-copy {
    margin: 0;
}

.footer-legal {
    display: flex;
    gap: var(--space-6);
}

.footer-legal a {
    color: var(--footer-muted);
    transition: color var(--dur-base);
}

.footer-legal a:hover {
    color: var(--white);
}

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px) {
    .header-inner { padding: 0 var(--space-6); gap: var(--space-6); }
    .main-nav { gap: var(--space-5); }
    .btn-stima { padding: 10px var(--space-5); }
    .estia-valutatore .card { padding: var(--space-12) var(--space-10) var(--space-10); }
    .footer-inner {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-12) var(--space-10);
    }
}

@media (max-width: 820px) {
    .main-nav { display: none; }
    .menu-toggle { display: inline-flex; }
    .btn-stima { margin-left: auto; }
    .logo__text { font-size: 1.5rem; }

    .estia-valutatore.hero { padding: var(--space-9) var(--space-4); }
    .estia-valutatore .card { padding: var(--space-9) var(--space-6) var(--space-8); border-radius: var(--radius-md); }

    .site-footer { padding: var(--space-14) var(--space-6) var(--space-6); }
    .footer-inner {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3);
        margin-top: var(--space-8);
    }
}

@media (max-width: 520px) {
    .header-inner { gap: var(--space-4); }
    .btn-stima { padding: 8px var(--space-4); font-size: 0.75rem; }
    .footer-legal { flex-wrap: wrap; gap: var(--space-3); }
}

/* ============================================================
 * Fase 4 — Single immobile layout grid
 * Gutenberg wp:group inserisce un .wp-block-group__inner-container
 * come unico figlio diretto del wrapper. Per evitare il "grid con 1
 * sola cella → colonne stackate", la grid si applica all'inner.
 * ============================================================ */
.estia-single-immobile { background: var(--bg-page, #F5F6F8); padding-bottom: var(--space-12, 96px); }
.estia-single-immobile__main-grid { max-width: var(--content-max, 1280px); margin: 0 auto; padding: 0 var(--space-5, 20px); }
.estia-single-immobile__main-grid > .wp-block-group__inner-container,
.estia-single-immobile__main-grid:not(:has(> .wp-block-group__inner-container)) {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6, 24px);
}
@media (min-width: 1024px) {
    .estia-single-immobile__main-grid > .wp-block-group__inner-container,
    .estia-single-immobile__main-grid:not(:has(> .wp-block-group__inner-container)) {
        grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
        gap: var(--space-8, 48px) var(--space-9, 56px);
        align-items: start;
    }
}
.estia-single-immobile__col-main, .estia-single-immobile__col-sidebar { min-width: 0; }
.estia-single-immobile__col-main > * + * { margin-top: var(--space-6, 24px); }

/* ============================================================
 * Layout "Sidebar Estia" — usato da page-with-sidebar.php (template
 * generico) + single.php (blog post). Wrapper PHP: <main class="estia-with-sidebar">
 *   .estia-with-sidebar__grid
 *     .estia-with-sidebar__grid-inner
 *       .estia-with-sidebar__col-main
 *       .estia-with-sidebar__col-sidebar (template-parts/sidebar-widget-area.php)
 *
 * Niente più wp-block-group__inner-container: il template costruisce la grid
 * direttamente in PHP, evitando il wrapping doppio Gutenberg.
 * ============================================================ */
.estia-with-sidebar {
    background: var(--bg-page, #F5F6F8);
    padding-bottom: var(--space-10, 64px);
}
/* Container interno: max-w-7xl + px responsive (16/24/32 px) match frozen. */
.estia-with-sidebar__grid {
    max-width: var(--content-max, 1280px);
    margin: 0 auto;
    padding: var(--space-8, 32px) var(--space-4, 16px);
}
@media (min-width: 640px) {
    .estia-with-sidebar__grid { padding-left: var(--space-6, 24px); padding-right: var(--space-6, 24px); }
}
@media (min-width: 1024px) {
    .estia-with-sidebar__grid { padding-left: var(--space-8, 32px); padding-right: var(--space-8, 32px); }
}
.estia-with-sidebar__grid-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6, 24px);
}
@media (min-width: 1024px) {
    .estia-with-sidebar__grid-inner {
        /* Frozen: lg:grid-cols-3 + col-span-2/col-span-1 = 2/1, gap-8 (32px). */
        grid-template-columns: 2fr 1fr;
        gap: var(--space-8, 32px);
    }
}
.estia-with-sidebar__col-main,
.estia-with-sidebar__col-sidebar { min-width: 0; }
.estia-with-sidebar__col-sidebar { align-self: start; }
@media (min-width: 1024px) {
    .estia-with-sidebar__col-sidebar { position: sticky; top: 96px; }
}

/* ---- Generic widget shell ----
   register_sidebar emette ogni widget come <section class="widget {class}
   estia-sidebar-widget"> con <h3 class="estia-sidebar-widget__title">. Ogni
   widget riceve cosi il "card look" (white bg + rounded + border + blue title
   bar). Vale anche per widget WP standard (Latest Posts, Search, ecc.) e per
   il widget "Custom HTML" usato per la sidebar ricca della Acquista demo. */
.estia-with-sidebar__col-sidebar .estia-sidebar-widget {
    background: #fff;
    overflow: hidden;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget:last-child { margin-bottom: 0; }
.estia-sidebar-widget__title {
    background: var(--blue-header, #4C70AF);
    color: #fff;
    margin: 0;
    padding: var(--space-4, 16px) var(--space-5, 20px);
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.3;
}
/* Padding interno del body widget (lasciato dal contenuto del widget custom_html
   che ha già aside.estia-blog-articles vuoto di padding, ma per widget standard
   WP serve padding di default). */
.estia-with-sidebar__col-sidebar .estia-sidebar-widget > *:not(.estia-sidebar-widget__title):not(.estia-blog-articles) {
    padding: var(--space-4, 16px) var(--space-5, 20px);
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget ul { margin: 0; padding: 0; list-style: none; }
.estia-with-sidebar__col-sidebar .estia-sidebar-widget ul li { padding: var(--space-2, 8px) 0; border-bottom: 1px solid #F1F2F4; }
.estia-with-sidebar__col-sidebar .estia-sidebar-widget ul li:last-child { border-bottom: 0; }
.estia-with-sidebar__col-sidebar .estia-sidebar-widget a { color: var(--blue-header, #4C70AF); text-decoration: none; }
.estia-with-sidebar__col-sidebar .estia-sidebar-widget a:hover { color: var(--blue-dark, #1F3A6D); text-decoration: underline; }
.estia-sidebar-widget--empty { color: var(--text-muted, #8A8A89); font-size: 0.875rem; }
.estia-sidebar-widget__hint { font-size: 0.75rem; opacity: 0.7; }

/* ---- Widget specifico "Ultimi articoli del blog" (rich list con icon+date)
   Markup emesso dal widget Custom HTML pre-popolato dal seed. Conserva i nomi
   originali per il rich list, ora con prefix .estia-blog-articles. */
.estia-blog-articles {
    list-style: none;
    margin: 0;
    padding: 0;
}
.estia-blog-articles__item { border-bottom: 1px solid #F1F2F4; }
.estia-blog-articles__item:last-child { border-bottom: 0; }
.estia-blog-articles__link {
    display: flex;
    align-items: center;
    gap: var(--space-4, 16px);
    padding: var(--space-4, 16px);
    text-decoration: none;
    color: inherit;
    transition: background 180ms ease;
}
.estia-blog-articles__link:hover { background: #F8F9FB; }
.estia-blog-articles__thumb {
    flex-shrink: 0;
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md, 6px);
    background: linear-gradient(135deg, var(--blue-header, #4C70AF), #5C82C1);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.estia-blog-articles__thumb .material-symbols-outlined {
    font-size: 28px;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}
.estia-blog-articles__meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}
.estia-blog-articles__title {
    color: #1F2937;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color 180ms ease;
}
.estia-blog-articles__link:hover .estia-blog-articles__title {
    color: var(--blue-header, #4C70AF);
}
.estia-blog-articles__date {
    color: #8A8A89;
    font-size: 0.75rem;
}
.estia-blog-articles__footer {
    border-top: 1px solid #F1F2F4;
    padding: var(--space-4, 16px);
    text-align: center;
}
.estia-blog-articles__footer a {
    color: var(--blue-header, #4C70AF);
    font-size: 0.875rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    transition: color 180ms ease;
}
.estia-blog-articles__footer a:hover { color: var(--blue-dark, #1F3A6D); }
.estia-blog-articles__footer .material-symbols-outlined {
    font-size: 18px;
    font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

/* Core "Latest Posts" nella sidebar blog: layout compatto coerente con
   .estia-blog-articles (card chiara, miniatura sx + titolo grassetto/data dx).
   Usato dove i widget cliente non possono usare il markup statico — es. staging,
   dove la lista dinamica passa da un blocco core/latest-posts. */
.estia-with-sidebar__col-sidebar .wp-block-latest-posts {
    list-style: none;
    margin: 0;
    padding: 0;
    background: #fff;
    border: 1px solid #F1F2F4;
    border-radius: var(--radius-md, 8px);
    overflow: hidden;
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts > li {
    display: grid;
    grid-template-columns: 52px 1fr;
    grid-template-rows: auto auto;
    column-gap: 12px;
    align-items: start;
    margin: 0;
    padding: 10px 14px;
    border-bottom: 1px solid #F1F2F4;
    transition: background 180ms ease;
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts > li:last-child { border-bottom: 0; }
.estia-with-sidebar__col-sidebar .wp-block-latest-posts > li:hover { background: #F8F9FB; }
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__featured-image {
    grid-column: 1;
    grid-row: 1 / 3;
    margin: 0;
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__featured-image a,
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__featured-image img {
    display: block;
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__featured-image img {
    width: 52px;
    height: 52px;
    object-fit: cover;
    border-radius: var(--radius-md, 8px);
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__post-title {
    grid-column: 2;
    grid-row: 1;
    margin: 0;
    color: #1F2937;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.3;
    text-decoration: none;
    transition: color 180ms ease;
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts > li:hover .wp-block-latest-posts__post-title {
    color: var(--blue-header, #4C70AF);
}
.estia-with-sidebar__col-sidebar .wp-block-latest-posts__post-date {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
    margin-top: 2px;
    color: #8A8A89;
    font-size: 0.7rem;
}
/* CTA (bottoni) nella sidebar blog: centrati. */
.estia-with-sidebar__col-sidebar .wp-block-buttons {
    justify-content: center;
}

/* ---- Variante --blog: l'articolo del single post si veste come articolo-editoriale ---- */
.estia-blog-article__hero {
    margin: 0 0 var(--space-7, 28px);
    border-radius: var(--radius-md, 8px);
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: var(--bg-page, #F5F6F8);
}
.estia-blog-article__hero img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.estia-blog-article__card {
    background: #fff;
    border: 1px solid var(--divider, #B8C4D9);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-7, 28px) var(--space-6, 24px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
    color: var(--text-dark, #3C3C3B);
    line-height: 1.7;
    font-size: 0.95rem;
}
@media (min-width: 768px) {
    .estia-blog-article__card { padding: var(--space-12, 48px); }
}

/* Breadcrumb sopra la card del single post */
.estia-blog-article .estia-breadcrumb {
    margin: 0 0 var(--space-5, 20px);
}

/* Hyperlink in-content (post WP) — evidenzia i link inline emessi
   da `the_content()` con sottolineatura gialla + colore blu brand.
   Scope a elementi di testo (p/li/h2-h6/blockquote) per non toccare
   wrapper utility (author box, breadcrumb, hero figure). Esclude <a>
   con classe per non collidere con link di componenti già stilizzati. */
.estia-blog-article__card :where(p, li, h2, h3, h4, h5, h6, blockquote) a:not([class]),
.estia-blog-article__card :where(p, li, h2, h3, h4, h5, h6, blockquote) a[href]:not([class]) {
    color: var(--blue-header, #4C70AF);
    text-decoration: underline;
    text-decoration-color: var(--yellow, #F5BE42);
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
    text-decoration-skip-ink: auto;
    font-weight: 600;
    transition: color .15s ease, text-decoration-color .15s ease;
}
.estia-blog-article__card :where(p, li, h2, h3, h4, h5, h6, blockquote) a:not([class]):hover,
.estia-blog-article__card :where(p, li, h2, h3, h4, h5, h6, blockquote) a:not([class]):focus-visible {
    color: var(--blue-dark, #1F3A6D);
    text-decoration-color: var(--blue-dark, #1F3A6D);
}

/* Author box in fondo all'articolo */
.estia-blog-article__author {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    margin-top: var(--space-10, 40px);
    padding-top: var(--space-7, 28px);
    border-top: 1px solid var(--divider, #B8C4D9);
}
.estia-blog-article__author-avatar img {
    display: block;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
}
.estia-blog-article__author-body { min-width: 0; }
.estia-blog-article__author-eyebrow {
    margin: 0 0 4px;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--yellow, #F5BE42);
}
.estia-blog-article__author-name {
    margin: 0 0 8px;
    font-family: Manrope, var(--font-body);
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--blue-dark, #1F3A6D);
}
.estia-blog-article__author-bio {
    margin: 0;
    font-size: .92rem;
    line-height: 1.6;
    color: var(--text-muted, #6E7180);
}
@media (max-width: 520px) {
    .estia-blog-article__author { flex-direction: column; gap: 12px; }
}

/* Sidebar widget — padding interno per i widget senza title bar
   (image, buttons, html). I widget con .estia-sidebar-widget__title
   già hanno il title con padding, e il content sotto eredita. */
.estia-with-sidebar__col-sidebar .estia-sidebar-widget {
    padding: 16px 20px;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget:has(> .estia-sidebar-widget__title) {
    padding: 0;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget:has(> .estia-sidebar-widget__title) > *:not(.estia-sidebar-widget__title) {
    padding: 16px 20px;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget img {
    max-width: 100%;
    height: auto;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget .wp-block-buttons {
    margin: 0;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget h3,
.estia-with-sidebar__col-sidebar .estia-sidebar-widget h4 {
    margin: 0 0 12px;
    font-family: Manrope, var(--font-body);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--blue-dark, #1F3A6D);
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget h3:last-child,
.estia-with-sidebar__col-sidebar .estia-sidebar-widget h4:last-child {
    margin-bottom: 0;
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget p {
    margin: 0 0 12px;
    font-size: .92rem;
    line-height: 1.55;
    color: var(--text-dark, #3C3C3B);
}
.estia-with-sidebar__col-sidebar .estia-sidebar-widget p:last-child { margin-bottom: 0; }
