/* Ringrazio Minucio per la collaborazione con gli sfondi :) */
/* ---------------Animazioni---------*/
@-webkit-keyframes fade-in {
    0% { -webkit-transform: scale(0.8); transform: scale(0.8);}
    40%{ -webkit-transform: scale(1); transform: scale(1);}
    60%{ -webkit-transform: scale(1); transform: scale(1);}
    100%{-webkit-transform: scale(0.8);transform: scale(0.8)}
}
@keyframes fade-in {
    0% { -webkit-transform: scale(0.8); transform: scale(0.8);}
    40%{ -webkit-transform: scale(1); transform: scale(1);}
    60%{ -webkit-transform: scale(1); transform: scale(1);}
    100%{-webkit-transform: scale(0.8);transform: scale(0.8)}
}

@-webkit-keyframes fade-in_opacity {
    0% { opacity: 0;}
    40%{ opacity: 1;}
    60%{opacity: 1;}
    100%{opacity: 1;}
}

@keyframes fade-in_opacity {
    0% { opacity: 0;}
    40%{ opacity: 1;}
    60%{opacity: 1;}
    100%{opacity: 1;}
}
/* ---------------Fine Animazioni---------*/

/* ---------------Hero---------*/
.hero-front_page{
    position: relative;
    height: 100vh;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-size: cover;
    background-repeat:no-repeat;
    background-attachment: fixed;
}

.hero-front_page::before{
    position: absolute;
    content: '';
    top: 0px;
    left: 0px;
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.623);
    z-index: 1;
}

.hero-front_page::after{
    position: absolute;
    content: '';
    bottom: 0px;
    height: 1px;
    width: 100%;
    background-color: var(--separatore-color-after);
    -webkit-box-shadow: var(--separatore-color-shadow);
            box-shadow: var(--separatore-color-shadow);
    z-index: 2;
}

.hero-front_page .hero-descrizione{
    width: 100%;
    height: 100%;
    padding: 12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: rgb(255, 255, 255);
    gap: 48px;
    z-index: 2;
}

.hero-front_page .hero-descrizione .hero-titolo{
    text-align: center;
    font-size: 4.5rem;
    font-weight: 700;
}

.hero-front_page .hero-descrizione .hero-sottotitolo{
    text-align: center;
    font-size: 3rem;
    font-weight: 500;
}

.hero-front_page .hero-descrizione .hero-ctas{
    margin: 24px 0px 24px 0px;
    height: 100px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 48px;
}

/* ---------------Fine Hero---------*/

/* ------------Contenitore---------*/
.contenitore_dei_servizi{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 24px;
}

/* ------------Primo Contenitore---------*/
.contenitore_dei_servizi .contenitore_primario{
    padding: 24px;
    margin:48px 0px 48px 0px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 24px;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-titolo{
    text-align: center;
    font-size: 3.5rem;
    font-weight: 800;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede{
    padding: 24px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;

}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento{
    margin: 0px;
    padding: 0px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-decoration: none;
    -webkit-transition: 0.2s ease-out;
    -o-transition: 0.2s ease-out;
    transition: 0.2s ease-out;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento:hover{
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento:hover .contenitore-scheda-svg,
.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento:hover img.contenitore-scheda-svg{
    -webkit-filter: drop-shadow(0 0 10px rgb(255, 0, 0));
            filter: drop-shadow(0 0 10px rgb(255, 0, 0));
    fill: rgb(228, 228, 228);
    stroke: none;
    stroke-width: 0px;
}
.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento:hover .contenitore-scheda_titolo::after{
    -webkit-box-shadow: 0px 0px 20px 1px rgb(255, 0, 0);
            box-shadow: 0px 0px 20px 1px rgb(255, 0, 0);
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda{
    padding: 24px;
    height: 250px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: space-evenly;
        -ms-flex-pack: space-evenly;
            justify-content: space-evenly;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12px;
    border-radius: 6px;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda-svg,
.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda img.contenitore-scheda-svg {
    width: 30%;
    height: 100%;
    fill: rgb(10, 10, 10);
    stroke: red;
    stroke-width: 8px;
    -webkit-transition: 0.2s ease;
    -o-transition: 0.2s ease;
    transition: 0.2s ease;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda-svg:hover,
.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda img.contenitore-scheda-svg:hover{
    -webkit-filter: drop-shadow(0 0 10px rgb(255, 0, 0));
            filter: drop-shadow(0 0 10px rgb(255, 0, 0));
    fill: rgb(228, 228, 228);
    stroke: none;
    stroke-width: 0px;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda_titolo{
    position: relative;
    font-size: 2rem;
    text-align: center;
}

.contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda_titolo::after{
    position: absolute;
    content: '';
    width: 100%;
    height: 1px;
    background-color: aliceblue;
    left: 0px;
    bottom: -5px;
    background-color: rgb(173, 0, 0);
}
/* ------------Fine Primo Contenitore---------*/

/* ------------Secondario Contenitore---------*/
.contenitore_dei_servizi .contenitore_secondario{
    margin: 50px 0;
    width: 100%;
    min-height: 500px;
    height: auto;
    padding: 24px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}


.contenitore_dei_servizi .contenitore-tema_custom{
    -webkit-animation: fade-in;
            animation: fade-in;
    -webkit-animation-timeline: view();
            animation-timeline: view();
    scroll-margin-top: calc(50vh - 250px);
    opacity: 1;
    transform: none;
}

.contenitore_dei_servizi .contenitore-tema_pronto{
    -webkit-animation: fade-in;
            animation: fade-in;
    -webkit-animation-timeline: view();
            animation-timeline: view();
    scroll-margin-top: calc(50vh - 250px);
    opacity: 1;
    transform: none;
}

.contenitore_dei_servizi .contenitore-assistenza{
    -webkit-animation: fade-in;
            animation: fade-in;
    -webkit-animation-timeline: view();
            animation-timeline: view();
    scroll-margin-top: calc(50vh - 250px);
    opacity: 1;
    transform: none;
}

.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione{
    padding: 12px 0;
    width: 90%;
    max-width: 90%;
    margin: 0 auto;
    height: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: space-evenly;
        -ms-flex-pack: space-evenly;
            justify-content: space-evenly;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    gap: 24px;
    text-align: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore_secondario-titolo{
    font-size: 3rem;
    text-align: center;
    width: 100%;
    max-width: 100%;
}
.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore_secondario-paragrafo{
    font-size: 2rem;
    text-align: center;
    width: 100%;
    max-width: 100%;
    line-height: 1.5;
    -webkit-animation: fade-in_opacity;
            animation: fade-in_opacity;
    -webkit-animation-timeline: view();
            animation-timeline: view();
    animation-range: entry 0% cover 45%;
}


.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .cta,
.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore-cta{
    margin: 24px auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    text-align: center;
    -webkit-align-self: center;
            align-self: center;
    font-size: 1.15rem;
    color: white;
    background-color: rgb(10,10,10);
    border: 1px solid rgba(255, 255, 255, 0.192);
    border-radius: var(--radius-md);
    text-decoration: none;
    -webkit-transition: 0.2s ease-out;
    -o-transition: 0.2s ease-out;
    transition: 0.2s ease-out;
}

.contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore-cta:hover{
    background-color: rgb(255, 255, 255);
    color: rgb(0, 0, 0);
    -webkit-box-shadow: 0px 0px 20px rgb(173,0,0);
            box-shadow: 0px 0px 20px rgb(173,0,0);
}

/* ------------Fine Secondario Contenitore---------*/

.contenitore_terzo{
    margin-bottom: 150px;
    padding: 0px 48px 0px 40px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 24px;
    -webkit-animation: fade-in_opacity;
            animation: fade-in_opacity;
    animation-timeline: view();
}

.contenitore_terzo .contenitore_terzo-titolo{
    font-size: 2.5rem;
    text-align: center;
}

.contenitore_terzo .contenitore_terzo-paragarfo{
    font-size: 2rem;
    text-align: center;
}

.contenitore_terzo .contenitore-tabelle{
    padding: 48px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; 
}

.contenitore_terzo .contenitore-tabelle .tabella{
    height: auto;
    min-height: 280px;
    width: 40%;
    padding: 32px 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 16px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.contenitore_terzo .contenitore-tabelle .tabella:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(173, 0, 0, 0.15);
}

body.active .contenitore_terzo .contenitore-tabelle .tabella {
    border-color: rgba(0, 0, 0, 0.08);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.contenitore_terzo .contenitore-tabelle .tabella .tabella-titolo{
    font-size: 2rem;
    text-align: center;
}

.contenitore_terzo .contenitore-tabelle .tabella .tabella-paragrafo{
    font-size: 1.5rem;
    text-align: center;
}

.contenitore_terzo .contenitore_terzo-parte_finale{
    margin-top: 24px;
    height: 150px;
    width: 100%;
    padding: 12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

.contenitore_terzo .contenitore_terzo-parte_finale .contenitore_terzo-titolo2{
    font-size: 2.5rem;
    text-align: center;
}

@media screen and (max-width: 1024px) {
    .hero-front_page{
        background-position-y:190px;
        background-size:cover;
        background-position: center center;
        background-repeat: no-repeat;
        background-attachment:unset;
    }

    .hero-front_page .hero-descrizione .hero-titolo {
        font-size: var(--size-titoli-hero-device);
        line-height: 1.2;
    }

    .hero-front_page .hero-descrizione .hero-sottotitolo {
        font-size: var(--size-sottotitolo-hero-device);
    }

    .hero-front_page .hero-descrizione .hero-ctas {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        height: auto;
        gap: 16px;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
    }

    .contenitore_dei_servizi {
        padding: 15px;
        box-sizing: border-box;
    }

    .contenitore_dei_servizi .contenitore_primario {
        margin: 24px 0;
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-titolo {
        font-size: var(--size-titolo-device);
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda_titolo {
        font-size: var(--size-titolo-device);
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-schede {
        display: none;
        width: 100%;
        gap: 12px;
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda .contenitore-scheda-svg,
    .contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda img.contenitore-scheda-svg {
        display: none !important;
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-schede .spostamento .contenitore-scheda {
        height: auto;
        min-height: auto;
        padding: 16px;
    }

    .contenitore_dei_servizi .contenitore_secondario {
        width: 100%;
        min-height: auto;
        height: auto;
        padding: 24px 0;
        margin: 0;
    }

    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione {
        width: 90%;
        max-width: 90%;
        margin: 0 auto;
        padding: 0 0 8px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: stretch;
            -ms-flex-align: stretch;
                align-items: stretch;
        gap: 12px;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }

    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore_secondario-titolo {
        font-size: var(--size-titolo-device) !important;
        width: 100%;
        text-align: center;
    }

    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore_secondario-paragrafo {
        font-size: var(--size-descrizione-device) !important;
        width: 100%;
        text-align: center;
        line-height: 1.5;
        -webkit-animation: fade-in_opacity;
                animation: fade-in_opacity;
        -webkit-animation-timeline: view();
                animation-timeline: view();
        animation-range: entry 0% cover 45%;
    }

    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .cta,
    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore-cta {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        font-size: 1rem;
    }

    .contenitore_dei_servizi .contenitore_secondario .contenitore_secondario-descrizione .contenitore-cta:hover {
        background-color: #ffffff;
        color: #000000;
        -webkit-box-shadow: 0px 4px 15px rgba(173, 0, 0, 0.4);
                box-shadow: 0px 4px 15px rgba(173, 0, 0, 0.4);
        -webkit-transform: translateY(-2px);
            -ms-transform: translateY(-2px);
                transform: translateY(-2px);
    }

    .contenitore_terzo {
        padding: 12px;
        width: 100%;
    }

    .contenitore_terzo .contenitore-tabelle {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        padding: 10px;
        gap: 20px;
    }

    .contenitore_terzo .contenitore-tabelle .tabella {
        width: 100% !important;
        height: auto;
        margin-bottom: 15px;
    }

    .contenitore_terzo .contenitore-tabelle .tabella .tabella-titolo{
        text-align: center;
        font-size: var(--size-titolo-device);
    }

    .contenitore_terzo .contenitore-tabelle .tabella .tabella-paragrafo{
        text-align: center;
        font-size: var(--size-descrizione-device);
    }

    .contenitore_terzo .contenitore_terzo-titolo{
        font-size: var(--size-titolo-device);
        text-align: center;
    }

    .contenitore_terzo .contenitore_terzo-parte_finale .contenitore_terzo-titolo2{
        font-size: var(--size-titolo-device);
        text-align: center;
    }

    .contenitore_terzo .contenitore_terzo-paragarfo {
        font-size: var(--size-descrizione-device);
        text-align: center;
        padding: 0 10px;
    }

    .contenitore_terzo-parte_finale{
        gap: 12px;
    }

}


/* --------------- Media Queries per Smartphone (max 691px) ---------*/
@media screen and (max-width: 691px) {
    .hero-front_page .hero-descrizione .hero-titolo {
        font-size: var(--size-titoli-hero-device);
        line-height: 1.2;
    }

    .hero-front_page .hero-descrizione .hero-sottotitolo {
        font-size: var(--size-sottotitolo-hero-device);
    }

    .hero-front_page .hero-descrizione .hero-ctas {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        height: auto;
        gap: 16px;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
    }

    .contenitore_dei_servizi .contenitore-servizi {
        display: flex !important;
    }

    .contenitore_dei_servizi .contenitore_primario .contenitore-schede {
        flex-direction: column;
        gap: 24px;
    }

}