﻿/* ==========================================================================
   Landing Page Styles - Casa ADV (Loghi Sempre in Fondo)
   ========================================================================== */

/* ==========================================================================
   1. Base Styles & Resets
   ========================================================================== */

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: 'Poppins', Arial, sans-serif;
    background-color: #f5f5f5;
    color: #333;
    line-height: 1.6;
    text-align: center;
    background-image: url('/Images/textureLanding.png?r=0');
    background-position: top right;
    background-repeat: no-repeat;
    background-size: auto;
    overflow-x: hidden;
    /* NIENTE padding laterale per la barra fissa qui */
}

img {
    max-width: 100%;
    height: auto;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

a {
    color: inherit;
    text-decoration: none;
}


/* ==========================================================================
   2. Partner Logos Section (Sempre in fondo e statico)
   ========================================================================== */

/* Sezione Contenitore Loghi Partner */
.partner-logos-bottom { /* Era .floating-partner-logos */
    width: 100%; /* Occupa tutta la larghezza disponibile */
    padding: 40px 15px 30px 15px; /* Padding sopra/sotto/laterale */
    margin-top: 40px; /* Spazio sopra, separandolo dalle statistiche */
    margin-bottom: 30px; /* Spazio sotto */
    /* Rimosse tutte le proprietà di position:fixed, transform, z-index, etc. */
}

/* Contenitore Flex Interno per i Loghi */
.partner-logos-container--bottom { /* Era .partner-logos-container--floating */
    display: flex;
    flex-direction: row; /* Loghi in orizzontale */
    justify-content: center; /* Centrati orizzontalmente */
    align-items: center; /* Allineati verticalmente */
    flex-wrap: wrap; /* Permetti ai loghi di andare a capo se non c'è spazio */
    gap: 30px; /* Spazio tra i loghi */
}

/* Stile Singolo Logo Partner */
.partner-logo--bottom { /* Era .partner-logo--floating */
    height: 60px; /* Altezza base desktop */
    width: auto;
    object-fit: contain;
    margin: 0; /* Reset margini */
    flex-shrink: 0; /* Evita che si restringano troppo */
}


/* ==========================================================================
   3. Page Header (Invariato)
   ========================================================================== */

.page-header {
    padding-top: 5vh;
    margin-bottom: 30px;
}

.main-logo {
    height: 15vh;
    max-height: 120px;
    width: auto;
    object-fit: contain;
}

/* ==========================================================================
   4. Main Content Area (Invariato)
   ========================================================================== */

.page-main {
    padding: 0 15px; /* Padding laterale interno per il contenuto */
    max-width: 1100px; /* Larghezza massima per il contenuto principale */
    margin-left: auto; /* Centra il contenuto principale */
    margin-right: auto;
}

/* ==========================================================================
   5. Hero Text Section (Invariato)
   ========================================================================== */

.hero-text {
    margin-bottom: 30px;
    padding: 0 5%;
}

.hero-title {
    font-family: 'Six Caps', sans-serif;
    font-size: clamp(3rem, 12vw, 6.25rem);
    color: #2c373e;
    letter-spacing: 5px;
    margin-bottom: 1.5rem;
    font-weight: 500;
    line-height: 1.1;
    text-transform: uppercase;
}

.hero-description {
    font-size: clamp(0.875rem, 2vw, 1rem);
    color: #2c373e;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;
}

/* ==========================================================================
   6. Call to Action (CTA) Section (Invariato)
   ========================================================================== */

.cta-section--prominent {
    margin-top: 35px;
    margin-bottom: 70px;
    padding: 10px 0;
}

.cta-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 20px 30px;
    background-color: #2c373e;
    color: white;
    border: none;
    border-radius: 3px;
    font-weight: bold;
    letter-spacing: 1px;
    cursor: pointer;
    transition: background-color 0.3s ease-in-out, color 0.3s ease-in-out, transform 0.2s ease;
    font-size: 14px;
    font-family: 'Poppins', Tahoma, Arial, sans-serif;
    text-decoration: none;
    text-transform: uppercase;
}

.cta-icon {
    height: 22px;
    width: auto;
    margin: 0;
}

.cta-link:hover,
.cta-link:focus {
    background-color: #b6ff00;
    color: #2c373e;
    outline: none;
    transform: translateY(-2px);
}


/* ==========================================================================
   7. Supporting Information Section (Contiene Stats) (Invariato)
   ========================================================================== */

.supporting-info {
    /* Rimosso padding/margin-top specifico qui, gestito da elementi interni */
    padding: 0; /* Nessun padding sulla section esterna */
    margin: 0; /* Nessun margine sulla section esterna */
}


/* ==========================================================================
   8. Stats Section (Dentro Supporting Info) (Invariato)
   ========================================================================== */

.stats-section {
     margin-top: 40px; /* Spazio sopra le statistiche */
     margin-bottom: 0; /* Nessun margine sotto, lo gestisce la sez. loghi */
}

.stats-container {
    display: flex;
    justify-content: center;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 20px;
    max-width: 650px;
    margin: 0 auto;
    padding: 0 10px;
}

.stat-box {
    flex-grow: 1;
    flex-basis: 250px;
    padding: 20px 25px;
    border-radius: 4px;
    color: #2c373e;
    display: flex;
    align-items: center;
    gap: 15px;
    text-align: left;
    min-height: 80px;
    background-color: rgba(255, 255, 255, 0.8);
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    transition: transform 0.2s ease;
}
.stat-box:hover {
    transform: translateY(-3px);
}

.stat-box--projects {
    background-color: #fff;
}

.stat-box--customers {
    background-color: #b6ff00;
}

.stat-box__value {
    font-size: 1.875rem; /* 30px */
    font-weight: bold;
    min-width: 50px;
    text-align: right;
    line-height: 1;
}

.stat-box__plus {
    font-size: 1.75rem; /* 28px */
    font-weight: bold;
    line-height: 1;
}

.stat-box__label {
    font-size: 0.875rem; /* 14px */
    line-height: 1.4;
}


/* ==========================================================================
   9. Media Queries (SOLO per aggiustamenti su schermi piccoli)
   ========================================================================== */

/* ---- Tablet (< 992px) ---- */
@media (max-width: 991.98px) {
    /* Nessuna modifica necessaria per la posizione dei loghi */
    .partner-logo--bottom {
        height: 50px; /* Riduci leggermente dimensione loghi */
    }

    .hero-title {
        letter-spacing: 4px;
    }
    .stats-container {
        max-width: 550px;
    }
}


/* ---- Mobile (< 768px) ---- */
@media (max-width: 767.98px) {
    /* Aggiusta spaziature */
    .page-header { padding-top: 4vh; margin-bottom: 20px; }
    .main-logo { height: 12vh; max-height: 100px; }
    .hero-text { margin-bottom: 25px; }
    .hero-title { letter-spacing: 2px; }
    .cta-section--prominent { margin-top: 30px; margin-bottom: 50px; }
    .cta-link { padding: 18px 25px; font-size: 13px; }
    .stats-section { margin-top: 30px; }

    /* Spaziatura e dimensione Loghi su Mobile */
     .partner-logos-bottom {
         margin-top: 35px;
         padding: 25px 15px 25px 15px; /* Riduci padding vert */
         margin-bottom: 25px;
    }
     .partner-logos-container--bottom {
        gap: 25px; /* Riduci gap tra loghi */
    }
     .partner-logo--bottom {
         height: 45px; /* Riduci dimensione loghi */
    }


    /* Adattamento Stats per Mobile */
    .stats-container {
        flex-direction: column;
        align-items: center;
        gap: 15px;
        max-width: 90%;
        padding: 0;
    }
    .stat-box {
        flex-basis: auto;
        width: 100%;
        max-width: 320px;
        justify-content: center;
        text-align: center;
        padding: 15px 20px;
        min-height: auto;
    }
    .stat-box:hover {
        transform: none;
    }
    .stat-box__value { font-size: 1.625rem; min-width: 40px; text-align: center; }
    .stat-box__plus { font-size: 1.5rem; }
    .stat-box__label { font-size: 0.8125rem; text-align: left; }
}


/* ---- Mobile Molto Piccolo (< 480px) ---- */
@media (max-width: 479.98px) {
    .main-logo { height: 10vh; max-height: 80px; }
    .hero-title { letter-spacing: 1.5px; }
    .cta-link { padding: 15px 20px; font-size: 12px; gap: 8px; }
    .cta-icon { height: 18px; }

    /* Spaziatura e dimensione Loghi */
    .partner-logos-bottom { margin-top: 30px; padding: 20px 15px; margin-bottom: 20px; }
    .partner-logos-container--bottom { gap: 20px; }
    .partner-logo--bottom { height: 35px; } /* Loghi ancora più piccoli */

    /* Adattamento Stats */
    .stat-box { padding: 12px 15px; }
    .stat-box__value { font-size: 1.375rem; }
    .stat-box__plus { font-size: 1.25rem; }
    .stat-box__label { font-size: 0.75rem; }
}