/**
 * Indice Automatico H2 - Stile dell'indice (responsive, mobile-first)
 * Compatibile sia con la versione standard che con AMP
 */

html {
    scroll-behavior: smooth;
}

/* --- Base mobile-first --- */

.indice-articolo {
    background: #f7f7f7;
    border-left: 4px solid #333;
    padding: 0.85rem 1rem;
    margin: 1.25rem 0;
    border-radius: 2px;
    font-size: 0.95rem;
    line-height: 1.5;
    box-sizing: border-box;
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

.indice-articolo__titolo {
    font-weight: 700;
    margin: 0 0 0.5rem;
    font-size: 1rem;
}

.indice-articolo__lista {
    margin: 0;
    padding-left: 1.6rem;
}

/* Spaziatura verticale e tap target gestiti dall'<li>:
   il link resta inline così il testo lungo va a capo
   correttamente allineato al testo, non al numero. */
.indice-articolo__lista li {
    margin: 0.45rem 0;
    line-height: 1.5;
    padding-left: 0.15rem;
}

.indice-articolo__lista a {
    text-decoration: none;
    color: #0073aa;
    /* display di default (inline) per permettere il corretto
       wrapping del testo nei list items. */
}

.indice-articolo__lista a:hover,
.indice-articolo__lista a:focus {
    text-decoration: underline;
}

/* Offset per header sticky: regola se il tuo tema ha una barra fissa più alta */
h2[id] {
    scroll-margin-top: 70px;
}

/* --- Tablet (>= 600px) --- */

@media (min-width: 600px) {
    .indice-articolo {
        padding: 1rem 1.25rem;
        margin: 1.5rem 0;
        font-size: 1rem;
    }

    .indice-articolo__titolo {
        font-size: 1.05em;
        margin-bottom: 0.6rem;
    }

    .indice-articolo__lista {
        padding-left: 1.75rem;
    }

    .indice-articolo__lista li {
        margin: 0.3rem 0;
    }

    h2[id] {
        scroll-margin-top: 80px;
    }
}

/* --- Desktop (>= 960px) --- */

@media (min-width: 960px) {
    .indice-articolo {
        padding: 1.1rem 1.4rem;
    }
}
