/* ========================================
   LFS NEWS - CSS DEDICATO
   Sfondo pagina: #FAF2E5
   Font: Lexend (gia caricato nel tema)
   ======================================== */

/* ----------------------------------------
   VARIABILI
   ---------------------------------------- */
:root {
    --lfs-bg:           #FAF2E5;
    --lfs-card-bg:      #EDE8E0;
    --lfs-accent:       #AC0606;
    --lfs-accent-dark:  #8B0505;
    --lfs-gold:         #C19E68;
    --lfs-gold-light:   rgba(193, 158, 104, 0.15);
    --lfs-gold-border:  rgba(193, 158, 104, 0.35);
    --lfs-text:         #2C2C2C;
    --lfs-text-light:   #666666;
    --lfs-link:         #0073aa;
    --lfs-link-dark:    #005177;
    --lfs-radius:       18px;
    --lfs-radius-sm:    10px;
    --lfs-shadow:       0 4px 24px rgba(0, 0, 0, 0.07);
    --lfs-shadow-hover: 0 16px 48px rgba(172, 6, 6, 0.14);
    --lfs-transition:   0.38s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ----------------------------------------
   WRAPPER GRIGLIA LISTA ARTICOLI
   ---------------------------------------- */
.lfs-news-wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    width: 100%;
    padding: 8px 0 40px 0;
    background: transparent;
}

/* ----------------------------------------
   CARD SINGOLA
   ---------------------------------------- */
.lfs-news-card {
    background: var(--lfs-card-bg);
    border-radius: var(--lfs-radius);
    box-shadow: var(--lfs-shadow);
    border: 1px solid var(--lfs-gold-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
    transition:
        transform var(--lfs-transition),
        box-shadow var(--lfs-transition),
        border-color var(--lfs-transition);
    font-family: 'Lexend', sans-serif;
}

/* Linea superiore decorativa */
.lfs-news-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--lfs-gold) 0%, var(--lfs-accent) 100%);
    opacity: 0;
    transition: opacity var(--lfs-transition);
    z-index: 1;
}

.lfs-news-card:hover::before {
    opacity: 1;
}

.lfs-news-card:hover {
    transform: translateY(-7px);
    box-shadow: var(--lfs-shadow-hover);
    border-color: rgba(172, 6, 6, 0.22);
}

/* ----------------------------------------
   IMMAGINE CARD
   ---------------------------------------- */
.lfs-news-card .lfs-card-image {
    width: 100%;
    overflow: hidden;
    position: relative;
    background: var(--lfs-gold-light);
    aspect-ratio: 4 / 3;
}

.lfs-news-card .lfs-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* ----------------------------------------
   CORPO CARD
   ---------------------------------------- */
.lfs-news-card .lfs-card-body {
    padding: 24px 26px 22px 26px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

/* Badge categoria */
.lfs-news-card .lfs-card-categoria {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--lfs-gold);
    background: var(--lfs-gold-light);
    border: 1px solid var(--lfs-gold-border);
    border-radius: 99px;
    padding: 4px 12px;
    margin-bottom: 14px;
    width: fit-content;
}

/* Titolo card */
.lfs-news-card .lfs-card-title {
    font-size: 19px;
    font-weight: 700;
    color: var(--lfs-accent) !important;
    line-height: 1.35;
    margin: 0 0 14px 0;
    letter-spacing: -0.02em;
    transition: color var(--lfs-transition);
}

.lfs-news-card:hover .lfs-card-title {
    color: var(--lfs-accent-dark) !important;
}

/* Estratto */
.lfs-news-card .lfs-card-excerpt {
    font-size: 15px;
    line-height: 1.72;
    color: var(--lfs-text-light);
    flex-grow: 1;
    font-weight: 400;
    margin: 0;
}

/* ----------------------------------------
   FOOTER CARD - link Leggi tutto
   ---------------------------------------- */
.lfs-news-card .lfs-card-footer {
    padding: 16px 26px 22px 26px;
    border-top: 1px solid rgba(193, 158, 104, 0.18);
    margin-top: 18px;
}

.lfs-news-card .lfs-leggi-tutto {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 14px;
    font-weight: 700;
    color: var(--lfs-accent);
    text-decoration: none;
    letter-spacing: 0.01em;
    transition: gap var(--lfs-transition), color var(--lfs-transition);
}

.lfs-news-card .lfs-leggi-tutto::after {
    content: '\2192';
    font-size: 16px;
    transition: transform var(--lfs-transition);
}

.lfs-news-card .lfs-leggi-tutto:hover {
    color: var(--lfs-accent-dark);
    gap: 12px;
    text-decoration: none;
}

.lfs-news-card .lfs-leggi-tutto:hover::after {
    transform: translateX(4px);
}

/* ----------------------------------------
   PAGINA SINGOLO ARTICOLO
   ---------------------------------------- */
.lfs-articolo-single {
    max-width: 760px;
    margin: 0 auto;
    padding: 40px 20px 60px 20px;
    font-family: 'Lexend', sans-serif;
    background: transparent;
}

/* Riga superiore: Torna alla lista + Badge categoria affiancati */
.lfs-single-nav {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}

/* Pulsante Torna alla lista */
.lfs-torna-lista {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 700;
    color: var(--lfs-accent);
    text-decoration: none;
    letter-spacing: 0.01em;
    background: rgba(172, 6, 6, 0.06);
    border: 1.5px solid rgba(172, 6, 6, 0.3);
    border-radius: 99px;
    padding: 8px 20px;
    transition:
        background var(--lfs-transition),
        border-color var(--lfs-transition),
        gap var(--lfs-transition),
        color var(--lfs-transition);
}

.lfs-torna-lista::before {
    content: '\2190';
    font-size: 16px;
    transition: transform var(--lfs-transition);
}

.lfs-torna-lista:hover {
    color: #fff;
    background: var(--lfs-accent);
    border-color: var(--lfs-accent);
    gap: 12px;
    text-decoration: none;
}

.lfs-torna-lista:hover::before {
    transform: translateX(-4px);
}

/* Badge categoria singolo */
.lfs-articolo-single .lfs-single-categoria {
    display: inline-block;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--lfs-accent);
    background: rgba(172, 6, 6, 0.06);
    border: 1.5px solid rgba(172, 6, 6, 0.3);
    border-radius: 99px;
    padding: 8px 20px;
    margin-bottom: 0;
}

/* Titolo singolo articolo */
.lfs-articolo-single .lfs-single-title {
    font-size: 30px;
    font-weight: 700;
    color: var(--lfs-accent) !important;
    line-height: 1.3;
    margin: 0 0 28px 0;
    letter-spacing: -0.03em;
    text-align: center !important;
}

/* Immagine in evidenza - sopra il testo */
.lfs-articolo-single .lfs-single-image {
    float: none;
    width: 100%;
    max-width: 365px;
    margin: 0 auto 28px auto;
    overflow: visible;
}

.lfs-articolo-single .lfs-single-image img {
    width: 100%;
    max-width: 465px;
    height: auto;
    display: block;
    margin: 0 auto;
    border-radius: var(--lfs-radius-sm);
    box-shadow: 0 6px 24px rgba(0,0,0,0.10);
}

/* Contenuto testo articolo */
.lfs-articolo-single .lfs-single-content {
    font-size: 16.5px;
    line-height: 1.78;
    color: var(--lfs-text);
    font-weight: 400;
}

.lfs-articolo-single .lfs-single-content p {
    margin-bottom: 16px;
}

.lfs-articolo-single .lfs-single-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--lfs-radius-sm);
}

/* Clearfix non più necessario senza float */
.lfs-articolo-single .lfs-single-body::after {
    content: none;
}

/* Divisore prima del pulsante torna */
.lfs-articolo-single .lfs-single-footer {
    margin-top: 40px;
    padding-top: 28px;
    border-top: 1px solid var(--lfs-gold-border);
    display: flex;
    justify-content: flex-start;
}

/* ----------------------------------------
   RESPONSIVE
   ---------------------------------------- */

/* Tablet - 2 colonne */
@media (max-width: 1024px) {
    .lfs-news-wrapper {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }

    .lfs-news-card .lfs-card-title {
        font-size: 17px;
    }

    .lfs-articolo-single .lfs-single-title {
        font-size: 26px;
    }
}

/* Mobile - 1 colonna */
@media (max-width: 768px) {
    .lfs-news-page {
        padding-top: 135px; /* offset header a due righe */
    }

    .lfs-news-container {
        padding-top: 90px !important;
    }

    .lfs-news-wrapper {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 4px 0 30px 0;
    }

    .lfs-news-card .lfs-card-body {
        padding: 20px 20px 16px 20px;
    }

    .lfs-news-card .lfs-card-footer {
        padding: 14px 20px 18px 20px;
    }

    .lfs-news-card .lfs-card-title {
        font-size: 16px;
    }

    .lfs-news-card .lfs-card-excerpt {
        font-size: 14px;
    }

    /* Singolo articolo su mobile */
    .lfs-articolo-single {
        padding: 90px 16px 40px 16px;
    }

    .lfs-single-nav {
        gap: 10px;
    }

    .lfs-torna-lista {
        font-size: 13px;
        padding: 7px 16px;
    }

    .lfs-articolo-single .lfs-single-categoria {
        font-size: 11px;
        padding: 7px 14px;
    }

    .lfs-articolo-single .lfs-single-title {
        font-size: 22px;
        margin-bottom: 20px;
    }

    .lfs-articolo-single .lfs-single-image {
        max-width: 100%;
        margin: 0 auto 20px auto;
    }

    .lfs-articolo-single .lfs-single-content {
        font-size: 15px;
        line-height: 1.72;
    }

}

/* ----------------------------------------
   FIX GENERATEPRESS
   ---------------------------------------- */
body.page-id-21557 .site-content,
body.page-id-21557 #content {
    padding: 0 !important;
}

body.page-id-21555 .site-content,
body.page-id-21555 #content {
    padding: 0 !important;
}
