/* ─────────────────────────────────────────────────────────────────────────────
   Fausto Press Room — Stile Press Kit Editoriale
   Palette: Bianco puro | Nero grafite | Accento oro
   Font: Libre Baskerville (titoli) + Source Sans 3 (testo)
───────────────────────────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Source+Sans+3:wght@300;400;500;600&display=swap');

:root {
    --fpr-nero:     #111111;
    --fpr-grafite:  #2C2C2C;
    --fpr-grigio:   #6B7280;
    --fpr-bordo:    #E5E7EB;
    --fpr-sfondo:   #FAFAF8;
    --fpr-bianco:   #FFFFFF;
    --fpr-oro:      #9A7A2E;
    --fpr-oro-lt:   #F7F0E0;
    --fpr-rosso:    #C0392B;
    --fpr-serif:    'Libre Baskerville', Georgia, serif;
    --fpr-sans:     'Source Sans 3', system-ui, sans-serif;
    --fpr-max:      1160px;
    --fpr-rad:      4px;
}

/* ─── Reset contestuale ──────────────────────────────────────────────────── */
.fpr-main *, .fpr-main *::before, .fpr-main *::after { box-sizing: border-box; }
.fpr-main img { max-width: 100%; height: auto; display: block; }
.fpr-main a { color: var(--fpr-oro); text-decoration: none; }
.fpr-main a:hover { text-decoration: underline; }

/* ─── Layout base ────────────────────────────────────────────────────────── */
.fpr-main { background: var(--fpr-sfondo); font-family: var(--fpr-sans); color: var(--fpr-grafite); }
.fpr-container { max-width: var(--fpr-max); margin: 0 auto; padding: 0 24px; }

/* ─── Archive header ─────────────────────────────────────────────────────── */
.fpr-archive-header {
    background: var(--fpr-nero);
    color: var(--fpr-bianco);
    padding: 64px 24px 56px;
    text-align: center;
    border-bottom: 3px solid var(--fpr-oro);
}
.fpr-archive-header-inner { max-width: 700px; margin: 0 auto; }
.fpr-label {
    font-family: var(--fpr-sans);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--fpr-oro);
    margin: 0 0 14px;
}
.fpr-archive-title {
    font-family: var(--fpr-serif);
    font-size: clamp(28px, 5vw, 46px);
    font-weight: 700;
    margin: 0 0 16px;
    line-height: 1.15;
    color: var(--fpr-bianco);
}
.fpr-archive-desc {
    font-size: 16px;
    color: #aaa;
    margin: 0;
    line-height: 1.6;
}

/* ─── Barra filtri ───────────────────────────────────────────────────────── */
.fpr-filter-bar {
    background: var(--fpr-bianco);
    border-bottom: 1px solid var(--fpr-bordo);
    padding: 0 24px;
    display: flex;
    gap: 4px;
    justify-content: center;
    flex-wrap: wrap;
}
.fpr-filter-btn {
    display: inline-block;
    padding: 14px 18px;
    font-family: var(--fpr-sans);
    font-size: 13px;
    font-weight: 500;
    color: var(--fpr-grigio);
    border-bottom: 2px solid transparent;
    transition: color .2s, border-color .2s;
    text-decoration: none;
    white-space: nowrap;
}
.fpr-filter-btn:hover { color: var(--fpr-nero); text-decoration: none; }
.fpr-filter-btn.active { color: var(--fpr-nero); border-bottom-color: var(--fpr-oro); font-weight: 600; }

/* ─── Grid articoli ──────────────────────────────────────────────────────── */
.fpr-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 28px;
    padding: 48px 0 64px;
}

/* ─── Card ───────────────────────────────────────────────────────────────── */
.fpr-card {
    background: var(--fpr-bianco);
    border: 1px solid var(--fpr-bordo);
    border-radius: var(--fpr-rad);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .25s, transform .25s;
}
.fpr-card:hover {
    box-shadow: 0 8px 28px rgba(0,0,0,.09);
    transform: translateY(-2px);
}
.fpr-card-img { display: block; overflow: hidden; aspect-ratio: 16/9; }
.fpr-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.fpr-card:hover .fpr-card-img img { transform: scale(1.03); }

.fpr-card-body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }

.fpr-card-cats { margin-bottom: 10px; display: flex; flex-wrap: wrap; gap: 6px; }
.fpr-cat-badge {
    display: inline-block;
    font-family: var(--fpr-sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--fpr-oro);
    background: var(--fpr-oro-lt);
    padding: 3px 8px;
    border-radius: 2px;
    text-decoration: none;
}
.fpr-cat-badge:hover { background: var(--fpr-oro); color: #fff; text-decoration: none; }

.fpr-card-title {
    font-family: var(--fpr-serif);
    font-size: 18px;
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 10px;
    color: var(--fpr-nero);
}
.fpr-card-title a { color: var(--fpr-nero); text-decoration: none; }
.fpr-card-title a:hover { color: var(--fpr-oro); }

.fpr-card-excerpt {
    font-size: 14px;
    line-height: 1.65;
    color: var(--fpr-grigio);
    margin: 0 0 16px;
    flex: 1;
}

.fpr-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}
.fpr-meta-item {
    font-family: var(--fpr-sans);
    font-size: 12px;
    color: var(--fpr-grigio);
}
.fpr-fonte {
    font-weight: 700;
    color: var(--fpr-nero);
}

.fpr-card-icons { display: flex; gap: 6px; font-size: 14px; }
.fpr-icon { opacity: .7; }

/* ─── Paginazione ────────────────────────────────────────────────────────── */
.fpr-pagination {
    text-align: center;
    padding: 0 0 48px;
}
.fpr-pagination .page-numbers {
    display: inline-block;
    padding: 8px 14px;
    margin: 2px;
    font-size: 13px;
    font-family: var(--fpr-sans);
    color: var(--fpr-grigio);
    border: 1px solid var(--fpr-bordo);
    border-radius: var(--fpr-rad);
    text-decoration: none;
}
.fpr-pagination .page-numbers.current,
.fpr-pagination .page-numbers:hover {
    background: var(--fpr-nero);
    color: var(--fpr-bianco);
    border-color: var(--fpr-nero);
    text-decoration: none;
}
.fpr-empty { text-align: center; padding: 64px 0; color: var(--fpr-grigio); }

/* ─── Breadcrumb ─────────────────────────────────────────────────────────── */
.fpr-breadcrumb {
    background: var(--fpr-bianco);
    border-bottom: 1px solid var(--fpr-bordo);
    padding: 12px 0;
    font-size: 12px;
    color: var(--fpr-grigio);
    font-family: var(--fpr-sans);
}
.fpr-breadcrumb a { color: var(--fpr-grigio); text-decoration: none; }
.fpr-breadcrumb a:hover { color: var(--fpr-oro); }
.fpr-breadcrumb span { margin: 0 6px; }

/* ─── Layout articolo singolo ────────────────────────────────────────────── */
.fpr-article-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 48px;
    padding-top: 48px;
    padding-bottom: 64px;
    align-items: start;
}
@media (max-width: 860px) {
    .fpr-article-layout { grid-template-columns: 1fr; }
}

/* ─── Header articolo ────────────────────────────────────────────────────── */
.fpr-article-header { margin-bottom: 32px; }
.fpr-article-title {
    font-family: var(--fpr-serif);
    font-size: clamp(24px, 4vw, 40px);
    font-weight: 700;
    line-height: 1.2;
    color: var(--fpr-nero);
    margin: 16px 0 20px;
}
.fpr-article-lead {
    font-family: var(--fpr-serif);
    font-style: italic;
    font-size: 18px;
    line-height: 1.65;
    color: var(--fpr-grafite);
    border-left: 3px solid var(--fpr-oro);
    padding-left: 20px;
    margin: 0 0 20px;
}
.fpr-article-byline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--fpr-grigio);
    font-family: var(--fpr-sans);
    padding-bottom: 20px;
    border-bottom: 1px solid var(--fpr-bordo);
}
.fpr-byline-fonte { font-weight: 700; color: var(--fpr-nero); }
.fpr-byline-sep { color: var(--fpr-bordo); }

/* ─── Immagine in evidenza ───────────────────────────────────────────────── */
.fpr-featured-img { margin-bottom: 36px; border-radius: var(--fpr-rad); overflow: hidden; }
.fpr-featured-img img { width: 100%; height: auto; }

/* ─── Contenuto articolo ─────────────────────────────────────────────────── */
.fpr-article-content {
    font-family: var(--fpr-sans);
    font-size: 17px;
    line-height: 1.8;
    color: var(--fpr-grafite);
}
.fpr-article-content p { margin: 0 0 22px; }
.fpr-article-content h2, .fpr-article-content h3 {
    font-family: var(--fpr-serif);
    color: var(--fpr-nero);
    margin: 36px 0 14px;
}
.fpr-article-content blockquote {
    border-left: 3px solid var(--fpr-oro);
    margin: 28px 0;
    padding: 12px 20px;
    color: var(--fpr-grafite);
    font-style: italic;
    background: var(--fpr-oro-lt);
    border-radius: 0 var(--fpr-rad) var(--fpr-rad) 0;
}

/* ─── Sezioni media ──────────────────────────────────────────────────────── */
.fpr-section { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--fpr-bordo); }
.fpr-section-title {
    font-family: var(--fpr-sans);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--fpr-grigio);
    margin: 0 0 20px;
}

/* ─── Galleria ───────────────────────────────────────────────────────────── */
.fpr-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 8px;
    margin-bottom: 12px;
}
.fpr-gallery-item {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    border-radius: var(--fpr-rad);
    display: block;
    background: #eee;
}
.fpr-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.fpr-gallery-item:hover img { transform: scale(1.05); }
.fpr-gallery-zoom {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,.4);
    color: #fff;
    font-size: 22px;
    opacity: 0;
    transition: opacity .25s;
}
.fpr-gallery-item:hover .fpr-gallery-zoom { opacity: 1; }
.fpr-gallery-note { font-size: 12px; color: var(--fpr-grigio); margin: 8px 0 0; }

/* ─── Video ──────────────────────────────────────────────────────────────── */
.fpr-video-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; border-radius: var(--fpr-rad); background: #000; }
.fpr-video-wrapper iframe,
.fpr-video-wrapper video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* ─── Sidebar ────────────────────────────────────────────────────────────── */
.fpr-article-sidebar { position: sticky; top: 24px; display: flex; flex-direction: column; gap: 16px; }
.fpr-sidebar-card {
    background: var(--fpr-bianco);
    border: 1px solid var(--fpr-bordo);
    border-radius: var(--fpr-rad);
    padding: 20px;
}
.fpr-sidebar-title {
    font-family: var(--fpr-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--fpr-grigio);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--fpr-bordo);
}

/* ─── Press card ─────────────────────────────────────────────────────────── */
.fpr-press-dl { margin: 0; }
.fpr-press-dl dt {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--fpr-grigio);
    margin-top: 10px;
}
.fpr-press-dl dd { margin: 2px 0 0; font-size: 13px; color: var(--fpr-nero); font-weight: 500; }
.fpr-embargo-active { color: var(--fpr-rosso) !important; font-weight: 700 !important; }
.fpr-embargo-active span { font-size: 11px; }

.fpr-btn-outline {
    display: block;
    margin-top: 16px;
    text-align: center;
    padding: 9px 14px;
    border: 1px solid var(--fpr-oro);
    border-radius: var(--fpr-rad);
    color: var(--fpr-oro);
    font-size: 12px;
    font-weight: 600;
    font-family: var(--fpr-sans);
    text-decoration: none;
    transition: background .2s, color .2s;
}
.fpr-btn-outline:hover { background: var(--fpr-oro); color: var(--fpr-bianco); text-decoration: none; }

/* ─── Allegati ───────────────────────────────────────────────────────────── */
.fpr-att-list { list-style: none; margin: 0; padding: 0; }
.fpr-att-list li { margin-bottom: 6px; }
.fpr-att-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--fpr-sfondo);
    border: 1px solid var(--fpr-bordo);
    border-radius: var(--fpr-rad);
    text-decoration: none;
    color: var(--fpr-nero);
    transition: background .2s, border-color .2s;
}
.fpr-att-link:hover { background: var(--fpr-oro-lt); border-color: var(--fpr-oro); text-decoration: none; }
.fpr-att-icon { font-size: 18px; flex-shrink: 0; }
.fpr-att-info { flex: 1; min-width: 0; }
.fpr-att-info strong { display: block; font-size: 12px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fpr-att-info small { display: block; font-size: 10px; color: var(--fpr-grigio); text-transform: uppercase; }
.fpr-att-dl { font-size: 16px; color: var(--fpr-oro); flex-shrink: 0; }

/* ─── Sidebar cats ───────────────────────────────────────────────────────── */
.fpr-sidebar-cats { display: flex; flex-wrap: wrap; gap: 6px; }

/* ─── Share ──────────────────────────────────────────────────────────────── */
.fpr-share-btns { display: flex; flex-direction: column; gap: 7px; }
.fpr-share-btn {
    display: block;
    width: 100%;
    padding: 9px 12px;
    font-size: 12px;
    font-weight: 600;
    font-family: var(--fpr-sans);
    text-align: center;
    border-radius: var(--fpr-rad);
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: opacity .2s;
}
.fpr-share-btn:hover { opacity: .85; text-decoration: none; }
.fpr-share-li { background: #0077B5; color: #fff; }
.fpr-share-tw { background: #000; color: #fff; }
.fpr-share-em { background: var(--fpr-sfondo); border: 1px solid var(--fpr-bordo); color: var(--fpr-nero); }
.fpr-share-cp { background: var(--fpr-sfondo); border: 1px solid var(--fpr-bordo); color: var(--fpr-nero); }

/* ─── Back bar ───────────────────────────────────────────────────────────── */
.fpr-back-bar {
    background: var(--fpr-bianco);
    border-top: 1px solid var(--fpr-bordo);
    padding: 16px 0;
}
.fpr-back-link {
    font-family: var(--fpr-sans);
    font-size: 13px;
    color: var(--fpr-grigio);
    text-decoration: none;
    font-weight: 500;
}
.fpr-back-link:hover { color: var(--fpr-nero); }

/* ─── Lightbox ───────────────────────────────────────────────────────────── */
.fpr-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.93);
    z-index: 99999;
    align-items: center;
    justify-content: center;
}
.fpr-lb-inner {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}
.fpr-lb-inner img { max-width: 90vw; max-height: 82vh; object-fit: contain; border-radius: 2px; }
.fpr-lb-close, .fpr-lb-prev, .fpr-lb-next {
    position: fixed;
    background: none;
    border: 1px solid rgba(255,255,255,.3);
    color: #fff;
    cursor: pointer;
    border-radius: 50%;
    width: 44px; height: 44px;
    font-size: 22px;
    line-height: 44px;
    text-align: center;
    padding: 0;
    transition: background .2s;
}
.fpr-lb-close:hover, .fpr-lb-prev:hover, .fpr-lb-next:hover { background: rgba(255,255,255,.15); }
.fpr-lb-close { top: 16px; right: 16px; font-size: 26px; }
.fpr-lb-prev { left: 16px; top: 50%; transform: translateY(-50%); }
.fpr-lb-next { right: 16px; top: 50%; transform: translateY(-50%); }
.fpr-lb-dl-btn {
    display: inline-block;
    background: var(--fpr-oro);
    color: #fff;
    padding: 8px 20px;
    border-radius: var(--fpr-rad);
    font-family: var(--fpr-sans);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
}
.fpr-lb-dl-btn:hover { opacity: .85; text-decoration: none; }

/* ─── Mobile ─────────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .fpr-grid { grid-template-columns: 1fr; gap: 16px; }
    .fpr-archive-header { padding: 40px 20px 36px; }
    .fpr-lb-prev, .fpr-lb-next { width: 36px; height: 36px; line-height: 36px; font-size: 18px; }
}
