:root {
    --avis-red: #d71920;
    --avis-red-dark: #a90f18;
    --avis-blue: #163a70;
    --avis-blue-soft: #edf4ff;
    --paper: #ffffff;
    --ink: #182033;
    --muted: #697386;
    --line: rgba(22, 58, 112, 0.14);
    --shadow: 0 22px 55px rgba(22, 58, 112, 0.14);
    --radius-lg: 28px;
    --radius-md: 20px;
    --font: 'Montserrat', sans-serif;
}
 
*, *::before, *::after { 
    box-sizing: border-box; 
    margin: 0; 
    padding: 0; 
}
 
body {
    font-family: var(--font);
    color: var(--ink);
    background: linear-gradient(180deg, #ffffff 0%, #f7f9fd 48%, #ffffff 100%);
    line-height: 1.7;
}
 
/* ---- HEADER CON LOGO ---- */
.header-logo {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    padding: 0;
}
 
.logo-container {
    display: flex;
    align-items: left;
    justify-content: left;
}
 
.logo-avis {
    width: clamp(120px, 15vw, 200px);
    height: auto;
    max-height: 200px;
    display: block;
    filter: drop-shadow(0 4px 12px rgba(22, 58, 112, 0.15));
    transition: transform 220ms ease;
}
 
.logo-avis:hover {
    transform: scale(1.05);
}
 
.container {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
}
 
/* ---- HERO ---- */
.hero-bilancio {
    position: relative;
    overflow: hidden;
    padding: clamp(72px, 10vw, 130px) 0 clamp(56px, 8vw, 92px);
    background:
        radial-gradient(circle at 82% 18%, rgba(215, 25, 32, 0.18), transparent 28%),
        radial-gradient(circle at 10% 85%, rgba(22, 58, 112, 0.13), transparent 34%),
        linear-gradient(135deg, #fff 0%, #f4f7fc 100%);
}
 
.hero-grid {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: center;
    min-height: 360px;
}
 
.hero-bg-shape {
    position: absolute;
    inset: auto -80px -150px auto;
    width: clamp(280px, 38vw, 520px);
    aspect-ratio: 1;
    border-radius: 42% 58% 65% 35% / 42% 40% 60% 58%;
    background: linear-gradient(135deg, rgba(215, 25, 32, 0.16), rgba(22, 58, 112, 0.10));
    filter: blur(1px);
    z-index: 0;
}
 
.hero-text {
    position: relative;
    z-index: 1;
    max-width: 820px;
}
 
.hero-text h1 {
    margin: 0 0 24px;
    font-size: clamp(3rem, 7vw, 6.8rem);
    line-height: 0.95;
    letter-spacing: -0.07em;
    font-weight: 800;
    color: var(--avis-blue);
}
 
.hero-text .highlight {
    color: var(--avis-red);
}
 
.hero-text p {
    max-width: 720px;
    margin: 0;
    font-size: clamp(1.02rem, 1.6vw, 1.24rem);
    line-height: 1.75;
    color: var(--muted);
    font-weight: 400;
}
 
/* ---- SECTION HEADER ---- */
.section-bilancio {
    padding: clamp(64px, 8vw, 108px) 0;
}
 
.section-header {
    max-width: 760px;
    margin: 0 auto 46px;
    text-align: center;
}
 
.section-header h2 {
    margin: 0;
    font-size: clamp(2rem, 4.5vw, 3.6rem);
    line-height: 1.05;
    letter-spacing: -0.045em;
    color: var(--avis-blue);
    font-weight: 800;
}
 
.section-line {
    width: 82px;
    height: 5px;
    margin: 22px auto 20px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--avis-red), var(--avis-blue));
}
 
.section-desc {
    margin: 0;
    color: var(--muted);
    line-height: 1.75;
    font-size: 1.04rem;
}
 
/* ---- BILANCIO CARDS ---- */
.bilancio-featured-row {
    display: flex;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
    align-items: stretch;
    margin-bottom: 34px;
}
 
.bilancio-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    justify-content: center;
    max-width: 900px;
    margin: 0 auto;
}
 
.bilancio-card {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border: none;
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 12px 28px rgba(22, 58, 112, 0.08);
    transition: transform 220ms ease, box-shadow 220ms ease;
    /* Gradient border via outline trick using padding + pseudo */
    padding: 3px;
    background-clip: padding-box;
}
 
/* Gradient border wrapper */
.bilancio-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 3px;
    background: linear-gradient(135deg, #000000 0%, #000000 38%, #000000 65%, #000000 100%);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    z-index: 3;
    filter: brightness(1.15) saturate(1.4);
}
 
.bilancio-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(215, 25, 32, 0.06), transparent 34%);
    opacity: 0;
    transition: opacity 220ms ease;
}
 
.bilancio-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow);
}
 
.bilancio-card:hover::before {
    opacity: 1;
}
 
/* Fallback per immagini mancanti */
.bilancio-poster:empty::after {
    content: "Immagine non disponibile";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--muted);
    font-size: 0.95rem;
    text-align: center;
    padding: 20px;
}
 
.bilancio-card.featured {
    flex: 1 1 420px;
    max-width: 760px;
    display: grid;
    grid-template-columns: minmax(260px, 0.9fr) minmax(280px, 1fr);
    align-items: stretch;
    border-radius: var(--radius-lg);
    box-shadow: 0 28px 70px rgba(22, 58, 112, 0.16);
    padding: 4px;
}
 
.bilancio-card.featured::after {
    padding: 4px;
    border-radius: var(--radius-lg);
}
 
/* Poster-only (2025): rimuove riquadro e testi, mostra solo immagine */
.poster-only {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    grid-template-columns: 1fr !important;
    /* Keep gradient border via ::after */
}
 
.poster-only .bilancio-poster {
    min-height: 470px !important;
    aspect-ratio: auto !important;
    padding: 0 !important;
    background: transparent !important;
    position: relative !important;
}
 
.poster-only .bilancio-poster img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    display: block !important;
}
 
.poster-only .download-btn.poster-download {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    z-index: 4 !important;
    padding: 10px 14px !important;
    min-height: auto !important;
    font-size: 0.85rem !important;
    border-radius: 999px !important;
    box-shadow: 0 8px 20px rgba(0,0,0,0.18) !important;
}
 
/* Riduci leggermente la dimensione della card 2025 */
 
.bilancio-card.featured.poster-only {
    flex: 1 1 300px !important;
    max-width: 420px !important;
}
 
.poster-only .bilancio-poster {
    min-height: 320px !important;
}
 
@media (max-width: 980px) {
    .bilancio-card.featured.poster-only {
        flex-basis: 100% !important;
        max-width: 100% !important;
    }
    .poster-only .bilancio-poster {
        min-height: 300px !important;
    }
}
 
.bilancio-card-top {
    position: absolute;
    top: 18px;
    left: 18px;
    z-index: 2;
}
 
.bilancio-year {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 78px;
    min-height: 42px;
    padding: 8px 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--avis-red), var(--avis-red-dark));
    color: #ffffff;
    font-weight: 800;
    letter-spacing: 0.02em;
    box-shadow: 0 10px 22px rgba(215, 25, 32, 0.28);
}
 
.bilancio-poster {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 245px;
    padding: 0;
    aspect-ratio: 4 / 5;
    background:
        linear-gradient(145deg, rgba(22, 58, 112, 0.08), rgba(215, 25, 32, 0.10)),
        #f8fafd;
    color: var(--avis-blue);
    text-align: center;
    font-weight: 800;
    font-size: 1.05rem;
    letter-spacing: -0.02em;
    overflow: hidden;
}
 
.bilancio-card.featured .bilancio-poster {
    min-height: 470px;
    aspect-ratio: auto;
    padding: 0;
    background: #eef3fb;
}
 
.bilancio-poster img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    image-rendering: auto;
    filter: contrast(1.04) saturate(1.06);
    transition: transform 240ms ease, filter 240ms ease;
    box-shadow: 0 6px 20px rgba(0,0,0,0.06);
}
 
/* Hover: leggero ingrandimento e aumento contrasto per migliorare visibilità */
.bilancio-card:hover .bilancio-poster img {
    transform: scale(1.02);
    filter: contrast(1.08) saturate(1.08);
}
 
.bilancio-poster:has(img:not([src]), img[src=""]) {
    background:
        linear-gradient(145deg, rgba(22, 58, 112, 0.08), rgba(215, 25, 32, 0.10)),
        #f8fafd;
}
 
.bilancio-card.featured .bilancio-poster:has(img:not([src]), img[src=""]) {
    background: #eef3fb;
}
 
.poster-placeholder {
    width: min(100%, 190px);
    aspect-ratio: 4 / 5;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 22px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(22, 58, 112, 0.12);
    box-shadow: inset 0 0 0 7px rgba(215, 25, 32, 0.04);
}
 
/* Forza il poster-only a non avere sfondo/bordo residuo e fa riempire completamente l'immagine */
.bilancio-card.featured.poster-only {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 4px;
}
 
.bilancio-card.featured.poster-only .bilancio-poster {
    background: transparent !important;
    padding: 0;
}
 
/* Posizionamento generale del pulsante di download dentro qualsiasi poster */
.bilancio-poster { position: relative; }
.bilancio-poster .download-btn.poster-download {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 3;
    padding: 8px 12px;
    min-height: auto;
    font-size: 0.82rem;
    border-radius: 999px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.18);
    background: rgba(22,58,112,0.95);
    color: #fff;
}
 
/* Rende tutte le card standard dei bilanci "solo poster" come il 2025 */
.bilancio-grid .bilancio-footer { 
    display: none !important; 
}
 
/* Sposta leggermente le immagini verso l'alto per migliorare la visibilità */
/* ELIMINATO: object-position: center 18% !important; */
 
/* Forza le immagini delle card 2021-2024 a riempire completamente lo spazio disponibile */
.bilancio-grid .bilancio-poster { 
    background: transparent !important; 
    padding: 0 !important;
    height: auto !important;
    min-height: 0;
    aspect-ratio: 4 / 5;
}
 
.bilancio-grid .bilancio-poster img { 
    width: 100% !important; 
    height: 100% !important; 
    object-fit: contain !important; 
    object-position: center !important; 
    display: block !important; 
}
 
.poster-placeholder i {
    color: var(--avis-red);
    font-size: 2rem;
}
 
.poster-placeholder span {
    line-height: 1.25;
}
 
.bilancio-footer {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    flex: 1;
    padding: 26px;
}
 
.bilancio-card.featured .bilancio-footer {
    justify-content: center;
    padding: clamp(32px, 5vw, 54px);
}
 
.bilancio-footer p {
    margin: 0;
    color: var(--muted);
    font-size: 0.98rem;
    line-height: 1.65;
}
 
.bilancio-card.featured .bilancio-footer p {
    color: var(--ink);
    font-size: clamp(1.08rem, 1.6vw, 1.24rem);
    line-height: 1.75;
}
 
.download-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 46px;
    padding: 12px 20px;
    border-radius: 999px;
    background: var(--avis-blue);
    color: #ffffff;
    text-decoration: none;
    font-weight: 800;
    font-size: 0.9rem;
    transition: transform 180ms ease, background-color 180ms ease, box-shadow 180ms ease;
}
 
.download-btn::before {
    content: "\f1c1";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
}
 
.download-btn:hover,
.download-btn:focus-visible {
    background: var(--avis-red);
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(215, 25, 32, 0.22);
}
 
/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) {
    .bilancio-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .bilancio-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
 
    .bilancio-card.featured {
        grid-template-columns: 1fr;
    }
 
    .bilancio-card.featured .bilancio-poster {
        min-height: 420px;
    }
}

@media (max-width: 768px) {
    .bilancio-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
 
@media (max-width: 620px) {
    .container {
        width: min(100% - 28px, 1180px);
    }
 
    .hero-grid {
        min-height: 300px;
    }
 
    .bilancio-grid {
        grid-template-columns: 1fr !important;
    }
 
    .bilancio-card.featured .bilancio-poster {
        min-height: 360px;
    }
 
    .bilancio-footer,
    .bilancio-card.featured .bilancio-footer {
        padding: 24px;
    }
}

@media (max-width: 480px) {
    .bilancio-grid {
        grid-template-columns: 1fr !important;
    }
}