body {
    --bg-color: #DCDCDC;
    --bg-image: url("../img/bg.jpg");
    --lead-overlay: rgba(33, 125, 187, 0.8);
    --nav-text: #3498db;
    --nav-text-hover: #217dbb;
    --nav-text-bg-hover: #EAEAEA;
    --nav-bg: #F7F7F7;
    --lead-subheading: #a0cfee;
    --dark-switch: #212121;
    --paragraph-heading: #222;
    --paragraph-text: #666666;
    --section: #F7F7F7;
    --card-bg: #fff;
    --project-image-bg: #3498db;
    --skill-bg: #fff;
    --skill-hover: #fff;
    --contact-bg: #3498db;
    --contact-fields-bg: #fff;
    --contact-fields-focus: #fff;
    --contact-text: #666666;
    --contact-send-bg: #fff;
    --contact-send-text: #3498db;
    --footer-bg: #F7F7F7;
    --footer-text: #666666;
    --to-top-arrow: #b9bfc4;
    --acknowledgements-bg: #F7F7F7;
    --lead-content2-color: #000;
}

body.dark {
    --bg-color: #000;
    --bg-image: url("../img/bg-dark.jpg");
    --lead-overlay: rgba(6, 16, 26, 0.8);
    --nav-text: #fff;
    --nav-text-hover: #fff;
    --nav-text-bg-hover: #424242;
    --nav-bg: #212121;
    --lead-subheading: rgba(255, 255, 255, 0.85);
    --paragraph-heading: rgba(255, 255, 255, 0.85);
    --paragraph-text: rgba(255, 255, 255, 0.7);
    --section-heading: rgba(255, 255, 255, 1);
    --section: #192133;
    --card-bg: #212121;
    --project-image-bg: #165079;
    --skill-bg: #212121;
    --skill-hover: #424242;
    --contact-bg: #165079;
    --contact-fields-bg: #212121;
    --contact-fields-focus: #424242;
    --contact-text: #fff;
    --contact-send-bg: rgba(255, 255, 255, 0.95);
    --contact-send-text: #165079;
    --footer-bg: #192133;
    --footer-text: rgba(255, 255, 255, 0.85);
    --to-top-arrow: rgba(255, 255, 255, 0.85);
    --acknowledgements-bg: #121212;
    --lead-content2-color: #fff;
}

body .dark {
    display: none
}

body.dark .dark {
    display: inline-block
}

body.dark .light {
    display: none
}

body,
html {
    padding: 0;
    margin: 0;
    max-width: 100%;
    overflow-x: hidden;
}

body {
    --color-mode-transition: 0.2s ease-out;
    background-color: var(--bg-color);
    /*background-image: var(--bg-image);*/
    font-family: Lato, sans-serif;
    font-size: 16px
}

body.active {
    overflow: hidden;
    z-index: -1
}

.no-js #experience-timeline>div {
    background: #fff;
    padding: 10px;
    margin-bottom: 10px;
    transition: border-color var(--color-mode-transition);
    border: 1px solid var(--section-border)
}

.no-js #experience-timeline>div h3 {
    font-size: 1.5em;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    display: inline-block;
    margin: 0
}

.no-js #experience-timeline>div h4 {
    font-size: 1.2em;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--paragraph-heading);
    margin: 0 0 15px 0
}

.no-js #experience-timeline>div p {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    font-size: .9em;
    margin: 0
}

.no-js #experience-timeline:after,
.no-js #experience-timeline:before {
    content: none
}

@keyframes dropHeader {
    0% {
        transform: translateY(-100%)
    }

    100% {
        transform: translateY(0)
    }
}

header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    z-index: 10;
    animation-name: dropHeader;
    animation-iteration-count: 1;
    animation-timing-function: ease;
    animation-duration: .75s
}

header ul {
    display: inline-block;
    transition: background-color var(--color-mode-transition);
    background: var(--nav-bg);
    text-align: center;
    padding: 10px;
    margin: 0;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px
}

header li {
    display: inline-block
}

header a {
    color: var(--nav-text);
    padding: 10px
}

header a:hover {
    color: var(--nav-text-hover);
    text-decoration: none;
    background: var(--nav-text-bg-hover);
    border-radius: 5px
}

header a:focus {
    color: var(--nav-text);
    text-decoration: none
}

header.active {
    display: block
}

header.sticky {
    position: fixed;
    z-index: 999
}

#menu.active {
    display: block
}

#mobile-menu-open {
    display: none;
    cursor: pointer;
    position: fixed;
    right: 15px;
    top: 10px;
    color: #3498db;
    font-size: 1.5em;
    z-index: 20;
    padding: 0 7px;
    border-radius: 5px;
    background: #fff;
    transition: .3s ease all !important;
    box-shadow: 0 3px 6px rgba(0, 0, 0, .08), 0 3px 6px rgba(0, 0, 0, .15)
}

#mobile-menu-open:hover {
    transform: scale(1.05);
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}

#mobile-menu-close {
    display: none;
    text-align: right;
    width: 100%;
    transition: background-color var(--color-mode-transition);
    background: var(--nav-bg);
    font-size: 1.5em;
    padding-right: 15px;
    padding-top: 10px;
    cursor: pointer;
    color: #3498db
}

#mobile-menu-close span {
    font-size: .5em;
    text-transform: uppercase
}

#mobile-menu-close i {
    vertical-align: middle
}

footer {
    transition: background-color var(--color-mode-transition);
    background: var(--footer-bg);
    display: flex;
    flex-direction: column !important;
    justify-content: center;
    align-items: center;
    vertical-align: middle;
    width: 100%;
    padding: 50px 0

}

.education-block-inner {
    width: 100%;
}

.imag {
    width: 100%;
}

.privacy-container{
    display: flex;
    gap: 5px;
}

@media only screen and (max-width: 750px) {
    .footer-wrapper {
        flex-direction: column !important;
        width: 90% !important
    }

    .top {
        order: 1;
        width: 100% !important;
        margin-top: 20px;
        margin-bottom: 5px
    }

    .social {
        order: 2;
        margin: 8px 0;
        width: 100% !important;
        justify-content: center !important
    }

    .copyright {
        order: 3;
        width: 100% !important;
        align-items: center !important
    }
    
}

.footer-wrapper {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    vertical-align: middle;
    width: 85%
}

.copyright {
    display: flex;
    align-items: flex-start;
    vertical-align: middle;
    flex-direction: column
}

.copyright-inner p {
    margin: 0;
    transition: color var(--color-mode-transition);
    font-size: 13px;
    color: var(--footer-text)
}

.copyright-inner {
    display: flex;
    align-items: center;
    vertical-align: middle;
    flex-direction: column
}

.top {
    width: 33.33%;
    display: flex;
    align-items: center;
    vertical-align: middle;
    flex-direction: column
}

.top span {
    cursor: pointer;
    display: block;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    transition: border-color var(--color-mode-transition);
    border: 3px solid var(--to-top-arrow);
    text-align: center
}

.top i {
    transition: color var(--color-mode-transition);
    color: var(--footer-text)
}

.social {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    vertical-align: middle
}

.social a {
    font-size: 20px;
    display: block;
    transition: color var(--color-mode-transition);
    color: var(--footer-text);
    padding: 10px;
    transition: transform .2s !important
}

.social a:hover {
    transform: scale(1.2);
    color: #3498db
}

.social ul {
    margin: 5px 0 0 0;
    padding: 0
}

.social li {
    display: inline-block;
    font-size: 1.25em;
    list-style: none
}

.btn-rounded-white {
    display: inline-block;
    color: #3498db;
    padding: 15px 25px;
    background: #fff;
    border-radius: 30px;
    transition: .5s ease all !important
}

.btn-rounded-white:hover {
    text-decoration: none;
}

.shadow {
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24)
}

.shadow-large {
    box-shadow: 0 3px 6px rgba(0, 0, 0, .08), 0 3px 6px rgba(0, 0, 0, .15)
}

.heading {
    position: relative;
    display: inline-block;
    font-size: 2em;
    font-weight: 400;
    margin: 0 0 30px 0
}

.heading:after {
    position: absolute;
    content: '';
    top: 100%;
    height: 1px;
    width: 50px;
    left: 0;
    right: 0;
    margin: 0 auto;
    background: #3498db
}

.background-alt {
    transition: background-color var(--color-mode-transition);
    background: var(--section-dark)
}

.section {
    padding: 2rem 1rem;
    max-width: 1200px;
    margin: 0 auto;    
}

.benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    justify-content: center;
    flex-direction: column;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    margin: 40px auto;
    padding: 50px 25px;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
}

.services {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
    gap: 1.5rem;
    justify-content: center;
    flex-direction: column;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    color: var(--paragraph-text);
    margin: 40px auto;
    padding: 50px 25px;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
}

.benefit, .service {
    margin-top: 10px;
    background: var(--card-bg);
    color: var(--paragraph-text);
    padding: 1.5rem;
    border-radius: 8px;
    text-align: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}



.benefit-card i {
    font-size: 3rem;
    color: #007BFF; /* Cambia colore a seconda del tema */
    margin-bottom: 10px;
}


.timeline {
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    justify-content: center;
    align-items: center;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    color: var(--paragraph-text);
    margin: 40px auto;
    padding: 50px 25px;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
}
.step {
    flex: 1 1 calc(25% - 1rem);
    background: var(--card-bg);
    padding: 1.5rem;
    text-align: center;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.cta {
    text-align: center;
    padding: 2rem 1rem;
    background: #0d6efd;
    color: #fff;
}
.cta a {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    background: #fff;
    color: #0d6efd;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
}

#lead {
    position: relative;
    height: 100vh;
    width: 100vw;
    background: url(../img/heading-background.jpg);
    background-size: cover;
    padding: 15px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center
}

#lead2 {
    background-image: url("../img/cloud.webp");
    position: relative;
    height: 60vh;
    width: 100vw;
    background-size: cover;
    padding: 15px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center
}


#lead-content {
    position: absolute;
    z-index: 10;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center
}

#lead-content h1,
#lead-content h2 {
    margin: 0
}

#lead-content h1 {
    color: #fff;
    font-weight: 600;
    font-size: 4em;
    line-height: 1em;
    white-space: nowrap
}

#lead-content h2 {
    transition: color var(--color-mode-transition);
    color: var(--lead-subheading);
    font-weight: 500;
    font-size: 2em;
    margin-bottom: 15px;
    line-height: 1.4em
}

#lead-content2 {
    z-index: 10;
}

#lead-content2 h1 {
    color: #fff;
}

#lead-overlay {
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transition: background-color var(--color-mode-transition);
    background: var(--lead-overlay);
    z-index: 1
}

#lead-down {
    position: absolute;
    width: 35px;
    height: 35px;
    text-align: center;
    z-index: 10;
    bottom: 23px;
    color: #fff;
    -webkit-transition: -webkit-transform .2s ease-in-out !important;
    -moz-transition: -moz-transform .2s ease-in-out !important;
    -o-transition: -o-transform .2s ease-in-out !important;
    -ms-transition: -ms-transform .2s ease-in-out !important;
    transition: transform .2s ease-in-out !important
}

#lead-down:hover {
    -webkit-transform: rotate(360deg) scale(1.12);
    -moz-transform: rotate(360deg) scale(1.12);
    -o-transform: rotate(360deg) scale(1.12);
    -ms-transform: rotate(360deg) scale(1.12);
    transform: rotate(360deg) scale(1.12)
}

#lead-down span {
    cursor: pointer;
    display: block;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    transition: border-color var(--color-mode-transition);
    border: 3px solid var(--lead-subheading);
    text-align: center
}

#lead-down i {
    animation: pulsate 1.5s ease;
    animation-iteration-count: infinite;
    vertical-align: top;
    padding-top: 7px
}

@keyframes pulsate {
    0% {
        transform: scale(1, 1)
    }

    50% {
        transform: scale(1.2, 1.2)
    }

    100% {
        transform: scale(1, 1)
    }
}

.stripe {
    margin-top: 50px;
    color: var(--paragraph-text);
}

.frame {
    padding: 0.5%;
    border-radius: 5%;
    border: 1px solid #3498db;
}

#about {
    text-align: justify
}

#modalita {
    text-align: justify
}

/*
#about {
    transition: background-color var(--color-mode-transition);
    background: var(--section-light);
    padding: 0px 0px;
    transition: border-color var(--color-mode-transition);
    border-bottom: 1px solid var(--section-border);
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    max-width: 1100px;
}*/

#about h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#about h5 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#about p {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    margin: 0;
    padding-left: 50px;
    padding-right: 50px
}

#modalita h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#services {
    text-align: center;
}

#services h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#experience {
    text-align: center;
}

/*
#experience {
    padding: 50px 15px;
    text-align: center;
    transition: border-color var(--color-mode-transition);
    border-bottom: 1px solid var(--section-border)
}*/

#experience h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#experience-timeline {
    margin: 30px auto 0 auto;
    position: relative;
    max-width: 1000px
}

#experience-timeline:before {
    position: absolute;
    content: '';
    top: 0;
    bottom: 0;
    left: 303px;
    right: auto;
    height: 100%;
    width: 3px;
    background: #3498db;
    z-index: 0
}

#experience-timeline:after {
    position: absolute;
    content: '';
    width: 3px;
    height: 40px;
    background: #3498db;
    background: linear-gradient(to bottom, #3498db, rgba(52, 152, 219, 0));
    top: 100%;
    left: 303px
}

#blog {
    text-align: center;
}

#blog h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#certificates {
    text-align: center;
}

#certificates h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

.vtimeline-content {
    margin-left: 350px;
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    padding: 15px;
    border-radius: 5px;
    text-align: left
}

.vtimeline-content h3 {
    font-size: 1.5em;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    display: inline-block;
    margin: 0
}

.vtimeline-content h4 {
    font-size: 1.2em;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--paragraph-heading);
    margin: 0 0 15px 0
}

.vtimeline-content p {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    font-size: .9em;
    margin: 0
}

.vtimeline-point {
    position: relative;
    display: block;
    vertical-align: top;
    margin-bottom: 30px
}

.vtimeline-icon {
    position: relative;
    color: #fff;
    width: 50px;
    height: 50px;
    transition: background-color var(--color-mode-transition);
    background: var(--project-image-bg);
    border-radius: 50%;
    float: left;
    z-index: 99;
    margin-left: 280px
}

.vtimeline-icon i {
    display: block;
    font-size: 2em;
    margin-top: 10px
}

.vtimeline-date {
    width: 260px;
    text-align: right;
    position: absolute;
    left: 0;
    top: 10px;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

/*
#education {
    transition: background-color var(--color-mode-transition);
    background: var(--section-light);
    padding: 50px 15px 20px 15px;
    border-bottom: 1px solid var(--section-border);
    text-align: center
}
*/
#education h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    margin-bottom: 50px
}

.education-block {
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    border-radius: 5px;
    width: 800px;
    margin: 0 auto 30px auto;
    padding: 30px;
    text-align: left;
    transition: .5s ease all !important;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
}

.left-block {
    color: var(--lead-content2-color);
    float: left;
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    border-radius: 5px;
    width: 45%;
    margin-left: 50px;
    padding: 30px;
    text-align: left;
    transition: .5s ease all !important;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
}

/*
.education-block:hover {
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}*/

.education-block h3 {
    font-weight: 500;
    float: left;
    margin: 0;
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

.education-block span {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    float: right
}

.education-block h4 {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-heading);
    clear: both;
    font-size: 1.1em;
    font-weight: 300;
    margin: 0 0 15px 0
}

.education-block p,
.education-block ul {
    margin: 0;
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    font-size: .9em;
    text-align: justify;
}

.education-block ul {
    padding: 0 0 0 15px
}

#projects {
    text-align: center
}

/*
#projects {
    padding: 50px 15px;
    transition: border-color var(--color-mode-transition);
    border-bottom: 1px solid var(--section-border);
    text-align: center
}*/

#projects h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    margin-bottom: 50px
}

#projects .container {
    margin: 0;
}

.project {
    position: relative;
    max-width: 900px;
    margin: 0 auto 30px auto;
    overflow: hidden;
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    border-radius: 5px;
    transition: .5s ease all !important;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
}

/*
.project:hover {
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}*/

.project-image {
    float: left;
    margin-left: 15px;
    width: 300px;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    transition: background-color var(--color-mode-transition);
    background: var(--project-image-bg);
    font-size: 1.1em
}

.project-image img,
.project-image video {
    border-radius: 5px;
    transition: .5s ease all !important
}

.project-image img:hover,
.project-image video:hover {
    cursor: pointer;
    /*box-shadow: 0 10px 20px rgba(0, 0, 0, .19), 0 6px 6px rgba(0, 0, 0, .23)*/
}

.container {
    width: 1300px;
}

.area {
    float: left;
    margin-left: 15px;
    width: 300px;
    height: 420px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    transition: background-color var(--color-mode-transition);
    background: var(--project-image-bg);
    font-size: 1.2em;
    position: relative;
    max-width: 400px;
    overflow: hidden;
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    border-radius: 5px;
    transition: .5s ease all !important;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 15px 10px rgba(0, 0, 0, 0.3);
}

.area2 {
    float: left;
    margin-left: 15px;
    width: 300px;
    height: 420px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    transition: background-color var(--color-mode-transition);
    background: var(--project-image-bg);
    font-size: 1.1em;
    position: relative;
    max-width: 400px;
    overflow: hidden;
    transition: background-color var(--color-mode-transition);
    background: var(--card-bg);
    border-radius: 5px;
    transition: .5s ease all !important;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 15px 10px rgba(0, 0, 0, 0.3);
}

.area-image {
    width: 100px;
    height: 100px;
}


.robot-cleaner-thumb {
    width: 280px;
    height: 175px
}

.gogosisters-thumb {
    width: 280px;
    height: 156px
}

.separable-thumb {
    width: 280px;
    height: 175px
}

.yahtzee-thumb {
    width: 228px;
    height: 280px
}

.connecting-rods-thumb {
    width: 262px;
    height: 280px
}

.fruits-inspector-thumb {
    width: 231px;
    height: 280px
}

.giacenza-media-thumb {
    width: 280px;
    height: 179px
}

.tablets-analyser-thumb {
    width: 167px;
    height: 280px
}

.area-info {
    position: absolute;
    top: 50%;
    color: var(--paragraph-text);
    transform: translateY(-50%);
    padding: 15px
}

.area-info p {
    font-size: 14px;
}

.scopri {
    padding: 5px;
    color: #fdfdfd;
    background-color:#007bffa0;
    
}

.scopri:hover {
    color: #0064e0b5; 
    background-color: #fdfdfd;
    font-size: 1.4em;
}

.project-info {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 300px;
    padding: 15px
}

.project-info h3 {
    font-size: 1.5em;
    font-weight: 300;
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    margin: 0 0 15px 0
}

.project-info p {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    margin: 0 0 15px 0;
    font-size: .9em;
    text-align: justify;
}

.no-image .project-info {
    position: relative;
    margin: 0;
    padding: 30px 15px;
    transform: none
}

#more-projects {
    display: none
}

#skills {
    text-align: center
}

/*
#skills {
    transition: background-color var(--color-mode-transition);
    background: var(--section-light);
    padding: 50px 15px;
    text-align: center
}*/

#skills h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    margin-bottom: 50px
}

#skills ul {
    display: block;
    margin: 0 auto;
    padding: 0;
    max-width: 800px
}

#skills li {
    display: inline-block;
    margin: 7px;
    padding: 5px 10px;
    transition: color var(--color-mode-transition);
    color: var(--section-heading);
    background: var(--skill-bg);
    list-style: none;
    cursor: default;
    font-size: 1.2em;
    transition: .3s ease all !important;
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
}

#skills li a {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

#skills li:hover {
    transform: scale(1.02);
    background: var(--skill-hover);
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19)
}

#contact {
    text-align: center;
}

/*
#contact {
    padding: 50px 15px;
    transition: background-color var(--color-mode-transition);
    background: var(--contact-bg);
    text-align: center
}*/

#contact h2 {
    margin: 0 0 15px 0;
    color: var(--section-heading);
}

#contact-form {
    max-width: 600px;
    margin: 0 auto;
    width: 100%;
}

#contact-form input,
#contact-form textarea {
    display: block;
    width: 100%;
    padding: 10px;
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
    margin-bottom: 10px;
    background: var(--contact-fields-bg);
    color: var(--contact-text);
    transition: .5s ease all !important
}

#contact-form input::-webkit-input-placeholder,
#contact-form textarea::-webkit-input-placeholder {
    color: var(--contact-text);
}

#contact-form input:-moz-placeholder,
#contact-form textarea:-moz-placeholder {
    color: var(--contact-text);
    opacity: 1
}

#contact-form input::-moz-placeholder,
#contact-form textarea::-moz-placeholder {
    color: var(--contact-text);
    opacity: 1
}

#contact-form input:-ms-input-placeholder,
#contact-form textarea:-ms-input-placeholder {
    color: var(--contact-text);
}

#contact-form input:focus,
#contact-form textarea:focus {
    outline: 0;
    background: var(--contact-fields-focus);
}

#contact-form textarea {
    height: 150px;
    resize: none
}

#contact-form button {
    display: block;
    width: 100%;
    transition: background-color var(--color-mode-transition);
    background: var(--contact-send-bg);
    border-radius: 5px;
    padding: 5px 10px;
    transition: color var(--color-mode-transition);
    color: var(--contact-send-text);
    font-weight: 700;
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.15);
    transition: .5s ease all !important
}

/*
#contact-form button:hover {
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19)
}*/

.optional-section {
    padding: 50px 15px;
    text-align: center;
    border-top: 1px solid var(--section-border)
}

.optional-section h2 {
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

.optional-section-block {
    max-width: 700px;
    margin: 0 auto 30px auto;
    padding: 15px;
    transition: border-color var(--color-mode-transition);
    border: 1px solid var(--section-border);
    background: #fff;
    text-align: left
}

.optional-section-block h3 {
    font-weight: 500;
    margin: 0 0 15px 0;
    transition: color var(--color-mode-transition);
    color: var(--section-heading)
}

.optional-section-block h4 {
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    clear: both;
    font-weight: 500;
    margin: 0 0 15px 0
}

.optional-section-block p,
.optional-section-block ul {
    margin: 0 0 15px 0;
    transition: color var(--color-mode-transition);
    color: var(--paragraph-text);
    font-size: .9em
}

.optional-section-block ul {
    padding: 0 0 0 15px
}

@media only screen and (max-width: 750px) {

    #experience-timeline:after,
    #experience-timeline:before {
        left: 23px
    }

    .vtimeline-date {
        width: auto;
        text-align: left;
        position: relative;
        margin-bottom: 15px;
        display: block;
        margin-left: 70px
    }

    .vtimeline-icon {
        margin-left: 0
    }

    .vtimeline-content {
        margin-left: 70px
    }
}

@media only screen and (max-width: 992px) {
    #lead {        
        min-height: auto;
        max-height: auto;
        padding: 100px 15px
    }

    #lead-content {
        position: relative;
        transform: none;
        left: auto;
        top: auto
    }

    #lead-content h1 {
        font-size: 3em
    }

    #lead-content h2 {
        font-size: 1.75em
    }
    
    #lead2 {        
        min-height: auto;
        max-height: auto;
        padding: 100px 15px
    }

    #about {
        text-align: justify
    }

    #about p {
        text-align: justify;
        padding-left: 0px;
        padding-right: 0px;
    }

    .services  {
        display: block;
    }

    .timeline  {
        display: block;
    }

    .education-block {
        max-width: 100%;
    }

    .left-block {
        max-width: 100%;
    }
}

.menu-links {
    display: none
}

.menu-links2 {
    justify-content: center;
    align-items: center;
    flex-direction: row
}

.menu-links2 a {
    width: 50px
}

.menu-links2 a i {
    font-size: 18px
}

@media only screen and (max-width: 768px) {
    header {
        position: fixed;
        display: none;
        z-index: 999;
        animation: none;
        bottom: 0;
        height: 100%;
    }

    #mobile-menu-close,
    #mobile-menu-open {
        display: block
    }

    #menu {
        height: 100%;
        overflow-y: auto;
        box-shadow: none;
        border-radius: 0;
        width: 100%
    }

    #menu li {
        display: block;
        margin-bottom: 6px
    }

    .menu-links {
        display: flex !important;
        justify-content: center;
        align-items: center;
        flex-direction: row
    }

    .menu-links a {
        width: 50px
    }

    .menu-links a i {
        font-size: 18px
    }

    #lead-content h1 {
        font-size: 3em
    }

    #lead-content h2 {
        font-size: 2.2em
    }

    #lead-content a {
        padding: 10px 20px
    }

    .profile-picture {
        width: 220px;
        height: 140px
    }

    #lead-down {
        display: none
    }

    .education-block h3,
    .education-block span {
        float: none
    }

    .project-image {
        display: none
    }

    .project-info {
        position: relative;
        margin: 0;
        padding: 30px 15px;
        top: auto;
        transform: none;
    }
}

@media only screen and (max-width: 350px) {
    #lead-content h1 {
        font-size: 2em !important
    }

    #lead-content h2 {
        font-size: 1.2em !important
    }

    .profile-picture {
        width: 210px !important;
        height: 210px !important
    }
}

@media only screen and (max-width: 480px) {
    #lead-content h1 {
        font-size: 2.5em
    }

    #lead-content h2 {
        font-size: 1.7em
    }

    #lead-content a {
        font-size: 1em;
        padding: 8px 16px
    }
}

@media only screen and (min-width: 769px) {
    .profile-picture {
        width: 250px;
        height: 250px
    }
}

.profile-picture {
    margin-bottom: 20px;
    border-radius: 50%;
    -webkit-box-shadow: 0 5px 5px 0 rgba(0, 0, 0, .4);
    -moz-box-shadow: 0 5px 5px 0 rgba(0, 0, 0, .4);
    box-shadow: 0 5px 5px 0 rgba(0, 0, 0, .4);
    transition: .5s ease all !important
}

/*
.profile-picture:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .19), 0 6px 6px rgba(0, 0, 0, .23)
}*/

.g-recaptcha {
    display: inline-block;
    margin-bottom: 10px
}

.contact-msg {
    display: inline-block;
    margin-top: 30px;
    font-size: 1.5em
}

.about-summary {
    max-width: 900px;
    margin: 0 10px
}

#to-top {
    -webkit-transition: -webkit-transform .2s ease-in-out !important;
    -moz-transition: -moz-transform .2s ease-in-out !important;
    -o-transition: -o-transform .2s ease-in-out !important;
    -ms-transition: -ms-transform .2s ease-in-out !important;
    transition: transform .2s ease-in-out !important
}

#to-top:hover {
    -webkit-transform: rotate(360deg) scale(1.12);
    -moz-transform: rotate(360deg) scale(1.12);
    -o-transform: rotate(360deg) scale(1.12);
    -ms-transform: rotate(360deg) scale(1.12);
    transform: rotate(360deg) scale(1.12)
}

#to-top i {
    animation: pulsate 1.5s ease;
    animation-iteration-count: infinite;
    vertical-align: top;
    padding-top: 5px
}

@keyframes pulsate {
    0% {
        transform: scale(1, 1)
    }

    50% {
        transform: scale(1.2, 1.2)
    }

    100% {
        transform: scale(1, 1)
    }
}

.company-logo img {
    width: 100%;
    height: 100%;
    transition: transform .2s !important
}

.company-logo img:hover {
    /*transform: scale(1.06);*/
    cursor: pointer
}

.schera-logo {
    width: 161px;
    height: 63px;
    flex-shrink: 0;
    margin-top: 8px;
    margin-right: 15px
}

.foru-logo {
    width: 161px;
    height: 161px;
    flex-shrink: 0;
    margin-top: 8px;
    margin-right: 15px
}



.oriani-logo,
.unibo-logo {
    width: 150px;
    height: 150px;
    flex-shrink: 0;
    margin-right: 15px
}

.experience-block {
    transition: .5s ease all !important;
    /*box-shadow: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24)*/
    border: 1px solid rgba(0, 0, 0, 0.15);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.06);
}

.experience-block h3 {
    font-weight: 500
}

.experience-block h4 {
    margin: 0 !important
}

.experience-block p {
    text-align: justify;
}

.experience-block i {
    margin-right: 6px
}

.location {
    margin: 4px 0 15px 0 !important
}

/*
.experience-block:hover {
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}*/

.section-card {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    border-radius: 5px;
    max-width: 1100px;
    margin: 40px auto;
    padding: 50px 25px;
    text-align: center;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
    border: 1px solid rgba(0, 0, 0, 0.15);
}

.section-card h1 {
    color: var(--paragraph-text)
}

.section-card2 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    margin: 40px auto;
    padding: 50px 25px;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
    /*border: 1px solid rgba(0, 0, 0, 0.15);*/
}

.section-card3 {
    display: flow-root;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    transition: background-color var(--color-mode-transition);
    background: var(--section);
    color: var(--paragraph-text);
    /*margin-top: 20px;*/
    padding-top: 20px;
    padding-bottom: 20px;
    transition: .5s ease all;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
    /*border: 1px solid rgba(0, 0, 0, 0.15);*/
}


@media (min-width: 1024px) {

    .education-block,
    .experience-block {
        display: flex;
        flex-direction: row
    }

    .company-logo {
        margin-right: 30px;
    }
    
}

@media (max-width: 1023px) {

    .education-block,
    .experience-block {
        display: flex;
        flex-direction: column;
        align-items: center
    }

    .ima-logo,
    .oriani-logo,
    .unibo-logo {
        margin-right: 0 !important;
        margin-bottom: 15px
    }

    .reply-logo {
        margin-right: 0 !important;
        margin-bottom: 20px
    }

    .container {
        width: 350px;
    }

    .area {
        clear: both;
        margin-bottom: 20px;
    }
    .left-block {
        width: 80%;
    }
}

.lang-flag {
    position: absolute;
    top: 10px;
    left: 15px;
    width: 34px;
    z-index: 11
}

.lang-flag img {
    transition: .3s ease all !important;
    border-radius: 50%;
    box-shadow: 0 3px 6px rgba(0, 0, 0, .08), 0 3px 6px rgba(0, 0, 0, .15)
}


.lang-flag img:hover {
    /*transform: scale(1.05);*/
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}

.menu-flag img {
    height: 20px
}

.menu-flag a {
    display: flex;
    vertical-align: middle;
    justify-content: center;
    align-items: center;
    width: 50px
}

.menu-flag {
    margin-bottom: 50px !important
}

.dark-mode-button {
    margin: 0 auto;
    position: absolute;
    top: 10px;
    right: 15px;
    width: 70px;
    height: 34px;
    z-index: 11;
    transition: .3s ease all !important;
    border-radius: 25px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, .08), 0 3px 6px rgba(0, 0, 0, .15)
}

@media only screen and (max-width: 768px) {
    .dark-mode-button {
        margin: 0 auto;
        position: absolute;
        top: 10px;
        left: 75px !important;
        right: auto !important;
        width: 70px;
        height: 34px;
        z-index: 11;
        transition: .3s ease all !important;
        border-radius: 25px
    }
    
}

.dark-mode-button:hover {
    /*transform: scale(1.05);*/
    box-shadow: 0 5px 10px rgba(0, 0, 0, .19), 0 5px 5px rgba(0, 0, 0, .23)
}

.dark-mode-switch {
    display: flex;
    align-items: center;
    height: 34px;
    position: relative;
    width: 70px;
    cursor: pointer
}

.dark-mode-switch input {
    display: none
}

.slider {
    background-color: #fff;
    border: 0 solid #000;
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transition: .4s
}

.slider:before {
    background-color: var(--dark-switch);
    border: 1px solid #000;
    bottom: 4px;
    content: "";
    height: 26px;
    left: 4px;
    position: absolute;
    transition: .4s;
    width: 26px;
    z-index: 421
}

input:checked+.slider {
    background-color: var(--dark-switch)
}

input:checked+.slider:before {
    border-color: #cfcfcf;
    background-color: #efefef;
    transform: translateX(34px)
}

.slider.round {
    border-radius: 34px
}

.slider.round:before {
    border-radius: 50%
}

.toggle-moon,
.toggle-sun {
    width: 50%;
    text-align: center;
    padding: .25em;
    position: relative;
    z-index: 420
}

.toggle-moon i {
    color: #fff
}

.toggle-sun i {
    color: var(--dark-switch)
}

.acknowledgements-link {
    font-size: 14px
}

.acknowledgements-link:hover {
    cursor: pointer
}

.acknowledgements-wrapper {
    display: none;
    position: fixed;
    width: calc(100% - 40px);
    background: var(--acknowledgements-bg);
    opacity: 1;
    border-radius: 5px;
    z-index: 100;
    max-width: 400px;
    max-height: 90%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--paragraph-text);
    overflow: auto;
    border: 2px solid #3498db
}

.acknowledgements-wrapper h2 {
    font-size: 2em;
    color: var(--paragraph-heading)
}

@media only screen and (max-width: 350px) {
    .acknowledgements-wrapper h2 {
        font-size: 1.7em !important
    }
}

.acknowledgements-wrapper.show {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column
}

.acknowledgements-wrapper.show h2 {
    text-align: center !important;
    margin: 0 !important
}

.acknowledgements-inner {
    padding: 40px;
    height: 100%;
    width: 100%;
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: column;
    text-align: center
}

.acknowledgements-exit {
    display: none;
    position: absolute;
    font-size: 1.5em;
    color: #3498db;
    z-index: 100
}

.acknowledgements-exit span {
    font-size: .5em;
    text-transform: uppercase
}

.acknowledgements-exit i {
    vertical-align: middle
}

.acknowledgements-exit.show {
    display: flex;
    align-items: center;
    flex-direction: column;
    transition: transform .2s !important;
    padding: 0;
    margin: 0;
    top: 2px;
    right: 14px
}

.acknowledgements-exit.show:hover {
    cursor: pointer;
    opacity: 1;
    transform: scale(1.1);
    transition: transform .2s !important
}

.acknowledgements-overlay {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    background: var(--bg-color);
    opacity: .5;
    z-index: 99;
    top: 0;
    left: 0
}

.acknowledgements-overlay.show {
    display: flex;
    align-items: center;
    flex-direction: column
}

.acknowledgements-disclaimer {
    margin: 20px 0
}

.acknowledgements-list {
    display: inline-flex;
    flex-direction: column;
    text-align: left
}

.with-grade {
    margin: 0 !important
}

.final-grade {
    margin: 4px 0 15px 0 !important
}

#telegram-button:hover {
    background-color: #0066a1;
    transition: background-color 0.3s;
}

.scroll-container {
    width: 100%; /* Larghezza piena della pagina */
    overflow-x: scroll; /* Abilita lo scorrimento orizzontale */
    white-space: nowrap; /* Evita che gli elementi vadano a capo */
    padding: 10px;
}

/* Stile per gli elementi interni */
.scroll-item {
    display: inline-block; /* Dispone gli elementi in linea */
    height: 150px;
    margin-right: 20px; /* Spazio tra gli elementi */
    color: white;
    text-align: center;
    line-height: 150px;
    font-size: 20px;
    border-radius: 10px;
}