/********************************
********************************
C O M M O N   C S S
******************/
@font-face {
    font-family: 'SF UI Text';
    src: url('../fonts/SFUIText-Regular.woff');
    font-weight: 400;
}

@font-face {
    font-family: 'SF UI Text';
    src: url('../fonts/SFUIText-Medium.woff');
    font-weight: 500;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/Roboto-Thin.ttf');
    font-weight: 100;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/Roboto-Regular.ttf');
    font-weight: 400;
}

html,
body,
div,
applet,
object,
iframe,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

body {
    margin: 0;
    min-height: 100%;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    text-align: left;
    background-color: #fff;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden;
    font-family: 'SF UI Text', sans-serif;
}

*,
::after,
::before {
    box-sizing: border-box;
}

.reset-style {
    all: unset;
}

a {
    text-decoration: none;
    background-color: transparent;
}

img {
    border-style: none;
    border: 0;
    font-style: italic;
    height: auto;
    max-width: 100%;
    vertical-align: middle;
}

#page {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

#topbar {
    position: fixed;
    z-index: 610;
    width: 100%;
    transition: width .2s;
    box-shadow: 0 1px 0 0 rgba(139, 141, 157, .05), 0 0 1px 0 rgba(65, 71, 108, .15);
    background-color: #ffffff;
    padding: 0 10px;
    display: block;
}

#topbar.has-scrolled {
    box-shadow: 0 1px 0 0 rgb(139 141 157 / 5%), 0 5px 10px 0 rgb(65 71 108 / 15%);
}

#topbar-wrapper {
    align-items: center;
    justify-content: space-between;
    height: 76px;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
    display: flex;
}

#site-logo {
    display: flex;
    align-items: center;
    height: 76px;
    min-width: 60px;
    padding-right: 30px;
    transition: all linear .1s;
}

/* Stile per il logo */
.logo-img {
    height: 100px; /* Altezza aumentata */
    width: auto; /* Larghezza proporzionale */
    max-width: 250px; /* Larghezza massima aumentata */
    object-fit: contain; /* Mantiene le proporzioni */
    margin: 10px 0; /* Margini aumentati */
}

.skillscloud-logo {
    max-height: 76px;
    min-height: 60px;
    width: 180px;
    position: relative;
    z-index: 1;
    padding: 10px 0;
    -o-object-fit: contain;
    object-fit: contain;
}

#topbar-cta {
    flex-shrink: 0;
    pointer-events: auto;
}

.button {
    border-radius: 100px;
    margin-left: .625rem;
    /* min-width: 110px; RIMOSSO per permettere larghezza flessibile */
    font-size: 1rem; /* TEST: cambiato da 1em a 1rem */
    white-space: nowrap; /* Assicura che il testo rimanga su una riga */
    /* min-height: 34px; RIMOSSO temporaneamente per valutare l'altezza naturale */
    padding: 6px 20px;
    background-color: #344f70;
    color: #fff;
    font-weight: 500;
    font-style: normal;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    display: inline-block;
    line-height: normal; /* Modificato per centraggio verticale */
    border: 1px solid transparent;
    outline: 0;
    vertical-align: middle;
    -webkit-appearance: none;
    appearance: none;
    -webkit-font-smoothing: antialiased;
    transition: all linear .2s;
}

.button:hover {
    background-color: #40628c;
}

footer {
    background-color: #ffffff;
    color: #A3A5A9;
    -webkit-box-flex: 1;
    flex: 1;
    background: #fff;
    font-size: 13px;
    padding: 30px 10px;
    display: block;
}

#footer-wrapper {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.footer-bottom-left {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

.footer-bottom-right {
    padding-left: 20px;
    margin-left: auto;
}

#footer-menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style: none;
}

#footer-menu li a {
    padding: 0;
    font-size: 14px;
    color: #122b46;
    letter-spacing: .5px;
    text-transform: uppercase;
    margin-right: 30px;
}

.copyright {
    font-size: 14px;
    letter-spacing: -.24px;
    line-height: 1.4;
    margin-top: 16px;
    margin-right: 30px;
}

#footer-socials {
    list-style-type: none;
}

#footer-socials li {
    display: inline-block;
    margin: 0 5px;
}

/* Servizi Grid */
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin: 2rem 0;
}

.service-item {
    background: #fff;
    padding: 1.5rem;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.service-item i,
.service-item .fa,
.service-item .fas,
.service-item .far,
.service-item .fab,
.service-card .service-icon i,
.service-card .service-icon .fa,
.service-card .benefit-icon i,
.service-card .benefit-icon .fa,
.benefit-item .benefit-icon i,
.benefit-item .benefit-icon .fa,
.benefit-icon i,
.benefit-icon .fa,
.service-icon i,
.service-icon .fa,
.service-icon .fas,
.service-icon .far,
.service-icon .fab,
.benefit-icon .fas,
.benefit-icon .far,
.benefit-icon .fab {
font-size: 5rem !important;
color: inherit !important;
margin-bottom: 1.25rem;
display: block;
background: none !important;
border: none !important;
border-radius: 0 !important;
padding: 0 !important;
box-shadow: none !important;
}

.service-item:hover {
    /* Nessun effetto hover sulle icone */
}

.service-item h3 {
    color: #2c3e50;
    margin-bottom: 0.75rem;
    font-size: 1.25rem;
}

.service-item p {
    color: #666;
    line-height: 1.5;
}

/* Sezione Servizi */
.services-section {
    padding: 4rem 2rem;
    background: #f9fafc;
}

.services-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 3.5rem 4rem;
    max-width: 1400px;
    margin: 0 auto;
    padding: 2rem 2rem 4rem;
    align-items: stretch;
}

.service-card {
    background: white;
    border-radius: 16px;
    padding: 3.5rem 2.5rem;
    box-shadow: 0 8px 30px rgba(0,0,0,0.06);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 420px;
    border: 1px solid rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
}

.service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.service-icon {
    font-size: 2.8rem;
    color: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 2rem;
    transition: all 0.3s ease;
}

.service-card:hover .service-icon {
    /* Nessun effetto hover sulle icone */
}

.service-card h3 {
    color: #2c3e50;
    margin-bottom: 1rem;
    font-size: 1.4rem;
    font-weight: 600;
}

.service-card p {
    color: #666;
    line-height: 1.6;
    margin-bottom: 1.5rem;
    flex-grow: 1;
}

.service-link {
    color: #3498db;
    text-decoration: none;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    transition: color 0.3s ease;
    margin-top: auto;
}

.service-link:hover {
    color: #2980b9;
}

.service-link::after {
    content: '→';
    margin-left: 0.5rem;
    transition: transform 0.3s ease;
}

.service-link:hover::after {
    transform: translateX(4px);
}

/* Responsive Design */
@media (max-width: 1200px) {
    .services-container {
        gap: 3rem;
    }
}

@media (max-width: 1024px) {
    .services-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 2.5rem;
        padding: 0 2rem;
    }
    
    .service-card {
        min-height: 380px;
    }
}

@media (max-width: 768px) {
    .services-container {
        grid-template-columns: 1fr;
        max-width: 500px;
        gap: 2.5rem;
        padding: 0 1.5rem;
    }
    
    .service-card {
        padding: 3rem 2rem;
        min-height: auto;
    }
    
    .service-icon {
        width: 70px;
        height: 70px;
        font-size: 2.2rem;
    }
}

.service-card h3 {
    color: #2c3e50;
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

.service-card p {
    color: #666;
    line-height: 1.5;
}

.section-title {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 600;
    margin: 2rem 0 1rem;
    color: #2c3e50;
    text-transform: uppercase;
    letter-spacing: 2px;
}

#footer-socials a img {
    width: 1.25rem;
}

#cookies-consent-box {
    line-height: 1.5;
    font-size: 0.9rem;
    z-index: 9999;
    font-weight: 400;
    padding: 2rem;
    background-color: rgb(53, 80, 114);
    color: rgb(255, 255, 255);
    font-family: inherit;
    width: 300px;
    bottom: 1rem;
    right: 1rem;
    position: fixed;
    box-shadow: 0 1px 0 0 rgb(139 141 157 / 5%), 0 5px 10px 0 rgb(65 71 108 / 15%) !important;
    opacity: 1;
    transition: opacity 500ms;
}

    #cookies-consent-box.hidden {
        opacity: 0;
        pointer-events: none;
    }

    #cookies-consent-box p {
        margin: 0;
    }

#cookies-buttons {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin-top: 1rem;
}

#cookies-policy-cta {
    text-decoration: underline;
    color: #ffffff;
    /*margin-right: 1rem;*/
    cursor: pointer;
}

    #cookies-policy-cta:hover {
        text-decoration: none;
    }

#cookies-privacy-cta {
    text-decoration: underline;
    color: #ffffff;
    /*margin-right: 1rem;*/
    cursor: pointer;
}

    #cookies-privacy-cta:hover {
        text-decoration: none;
    }

#cookies-policy-wrapper {
    min-width: 100vw;
    min-height: 100vh;
    position: fixed;
    z-index: 9999;
    background-color: rgba(0, 0, 0, 0.5);
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(3px);
    transition: opacity 300ms;
}

    #cookies-policy-wrapper.hidden {
        opacity: 0;
        pointer-events: none;
    }

#cookies-policy-box {
    background-color: #ffffff;
    max-width: 645px;
    border-radius: 0.2rem;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    transform: scale(1);
    opacity: 1;
    transition: all 500ms;
}

#cookies-policy-wrapper.hidden #cookies-policy-box {
    transform: scale(0);
    opacity: 0;
}

#cookies-policy-box h4 {
    color: #122B46;
    font-weight: 500;
    font-size: 1.1rem;
    margin: 0;
}

#cookies-policy-box p {
    color: #000000;
    font-size: 0.9rem;
}

#cookies-save {
    align-self: flex-end;
    text-transform: uppercase;
}

#close-cookies-box {
    position: absolute;
    align-self: flex-end;
    font-weight: bold;
    color: #000000;
    font-size: 1.5rem;
    margin-top: -0.5rem;
    cursor: pointer;
}

#cookies-privacy-wrapper.hidden {
    opacity: 0;
    pointer-events: none;
}

#cookies-privacy-wrapper {
    min-width: 100vw;
    min-height: 100vh;
    position: fixed;
    z-index: 9999;
    background-color: rgba(0, 0, 0, 0.5);
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(3px);
    transition: opacity 300ms;
}

#cookies-privacy-box {
    background-color: #ffffff;
    max-width: 645px;
    border-radius: 0.2rem;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    transform: scale(1);
    opacity: 1;
    transition: all 500ms;
}

#cookies-privacy-wrapper.hidden #cookies-privacy-box {
    transform: scale(0);
    opacity: 0;
}

#cookies-privacy-box h4 {
    color: #122B46;
    font-weight: 500;
    font-size: 1.1rem;
    margin: 0;
}

#cookies-privacy-box p {
    color: #000000;
    font-size: 0.9rem;
}

#privacy-save {
    align-self: flex-end;
    text-transform: uppercase;
}

#close-privacy-box {
    position: absolute;
    align-self: flex-end;
    font-weight: bold;
    color: #000000;
    font-size: 1.5rem;
    margin-top: -0.5rem;
    cursor: pointer;
}

/********************************
********************************
H O M E P A G E   C S S
**********************/
#skillscloud-home-slider {
    width: 100%;
    height: calc(100vh - 76px);
    margin-top: 76px;
}

#skillscloud-home-slider .glide__track,
#skillscloud-home-slider .glide__slides {
    margin: 0;
    height: 100%;
}

li.glide__slide {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.slide-content-wrapper {
    font-family: 'Roboto', sans-serif;
    height: 100%;
    margin: 0 auto;
    padding: 30px;
    color: #FFFFFF;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.slide-content-wrapper.left-align {
    align-items: flex-start;
}

.slide-content-wrapper.center-align {
    align-items: center;
}

.slide-content-wrapper.right-align {
    align-items: flex-end;
}

.slide-content-wrapper .title {
    font-weight: 400;
    text-transform: uppercase;
    font-size: 2.2rem;
    line-height: 1.2em;
    margin: 0;
}

.slide-content-wrapper .subtitle {
    font-weight: 100;
    font-size: 1.2rem;
    line-height: 1.2em;
    margin: 1em 0;
}

.glide__slide .subtitle strong {
    font-weight: 400;
}

.glide__slide .slide-cta {
    border-radius: 100px;
    font-size: 1.3rem;
    padding: 0.5em 1em;
    margin: 0.5em 0;
    background-color: #344f70;
    color: #fff;
    font-style: normal;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    display: inline-block;
    line-height: 1.3;
    border: 1px solid transparent;
    outline: 0;
    vertical-align: middle;
    -webkit-appearance: none;
    appearance: none;
    -webkit-font-smoothing: antialiased;
    transition: all linear .2s;
}

.glide__slide .slide-cta:hover {
    background-color: #40628c;
}

#slogan-wrapper,
#who-we-are,
#job-space {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 80px;
    padding-bottom: 80px;
    background-color: #fafbfd;
}

#job-space {
    background-color: #f4f4f4;
}

.slogan-heading h1,
.who-we-are-heading h1,
.job-space-heading h1 {
    padding: 0;
    margin: 0;
    padding-bottom: 30px;
    color: #344F70;
    font-size: 2.5rem;
    font-weight: 400;
    line-height: 1;
    text-align: center;
    font-family: 'SF UI Text', sans-serif;
}

.slogan-text p,
.who-we-are-text p,
.job-space-text p {
    width: 55%;
    margin: 20px auto 0px auto;
    font-family: 'Roboto', sans-serif;
    color: #344F70;
    font-size: 1.5em;
    font-weight: 100;
    text-align: center;
    line-height: 1.5;
}

.slogan-text strong,
.who-we-are-text strong,
.job-space-text strong {
    font-weight: 400;
}

.who-we-are-highlights ul {
    list-style: none;
    margin-top: 15px;
    padding: 0;
}

.who-we-are-highlights li {
    display: flex;
    align-items: center;
    margin: 15px;
    color: #344F70;
    font-size: 0.9rem;
}

.who-we-are-highlights li img {
    height: 1.3em;
    width: 1.3em;
    order: 1;
    margin-left: 5px;
}

.job-space-subtext {
    width: 60%;
    margin-top: 40px;
    color: #344F70;
    font-family: "Roboto", Sans-serif;
    font-weight: 400;
    line-height: 1.4em;
    text-align: center;
    font-size: 0.85em;
}

.job-space-subtext p {
    margin: 0;
}

#skillscloud-home-carousel {
    width: 100%;
}

#skillscloud-home-carousel .glide__track,
#skillscloud-home-carousel .glide__slides {
    margin: 0;
}

#skillscloud-home-carousel li.glide__slide {
    max-width: 10%;
}

#skillscloud-home-carousel li.glide__slide img {
    width: 100%;
    height: auto;
}

#work-with-us-wrapper {
    width: 100%;
    background-image: url('../images/bg_parallax-1.jpg');
    background-attachment: fixed;
    background-repeat: none;
    background-size: cover;
}

#work-with-us {
    display: flex;
    margin: 0 auto;
    padding: 90px 30px;
    align-content: center;
    justify-content: space-around;
}

#work-with-us-text {
    color: #FFFFFF;
    font-family: 'Roboto', sans-serif;
    font-weight: 100;
    text-transform: uppercase;
    font-size: 2.2rem;
    line-height: 1.2em;
    margin: 0;
}

#PosizioniAperte {
    align-self: center; /* Centra solo il bottone verticalmente all'interno del flex container */
}

#prefooter {
    display: flex;
}

#skillscloud-prefooter-gallery {
    width: 50%;
}

#skillscloud-prefooter-gallery .glide__track,
#skillscloud-prefooter-gallery .glide__slides {
    margin: 0;
}

#skillscloud-prefooter-gallery li.glide__slide img {
    width: 100%;
    max-height: 60vh;
    object-fit: cover;
    object-position: center;
}

#prefooter-map {
    width: 50%;
    max-height: 60vh;
    background-image: url("../images/mappa_pin.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

/********************************
********************************
J O B L I S T   C S S
**********************/
#joblist-content {
    background-color: #fafbfd;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#jobs-wrapper {
    display: flex;
    flex-direction: column;
    margin-top: 76px;
    width: 100%;
    padding: 0 15px;
    min-height: 80vh;
}

#jobs-wrapper h1 {
    text-transform: uppercase;
    padding: 0;
    font-size: 1.3rem;
    line-height: 1.5rem;
    margin: 1.5em 0 1.5rem 0;
    color: #344f70;
    font-family: 'SF UI Text', sans-serif;
    font-weight: bold;
}

#search-a-job {
    display: flex;
    flex-direction: row;
    width: 100%;
    margin-bottom: 3.5rem;
}

#where,
#filter {
    height: 2.5rem;
    flex-basis: min-content;
    flex-grow: 1;
    outline: 0;
    margin-right: 1em;
    vertical-align: middle;
    background-color: #fff;
    border: 1px solid #dedfe2;
    box-shadow: none;
    padding: 0 0.75rem 0 0.75rem;
    color: #4D5C6D;
    border-radius: 4px;
    display: flex;
    flex-direction: row;
    align-items: center;
}

#where select,
#filter select {
    all: unset;
    width: 100%;
}

#search-a-job img {
    max-height: 1.125rem;
    margin-right: 0.75rem;
}

#job-search-button {
    flex-shrink: 0;
    flex-basis: auto;
}

#job-list-dashboard {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.job-card {
    width: calc(33.3% - 1rem);
    display: flex;
    flex-direction: column;
    margin: 0.5rem;
    padding: 1.5em 1em;
    background-color: #fff;
    border: 1px solid #dedfe2;
    border-radius: 4px;
    transition: box-shadow 500ms;
}

.job-card:hover {
    box-shadow: 0 1px 0 0 rgb(139 141 157 / 5%), 0 5px 10px 0 rgb(65 71 108 / 15%);
}

.job-card-title {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
}

.job-card-title img {
    max-width: 20%;
}

.job-card-title h3 {
    margin: 0 0 0.5em 0.5em;
    color: #122B46;
    font-size: 1.3rem;
    line-height: 1em;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 500;
}

.job-card-place {
    display: flex;
    flex-direction: row;
    align-items: center;
    color: #4D5C6D;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 400;
    font-size: 0.85rem;
}

.job-card-place img {
    height: 1em;
    margin-right: 0.5em;
}

.job-card-contract-type,
.job-card-publication-date {
    font-family: 'SF UI Text', sans-serif;
    font-weight: 400;
    font-size: 0.7rem;
}

.job-card-contract-type {
    color: #f08d3c;
}

.job-card-publication-date {
    color: #A3A5A9;
}

.disabled {
    pointer-events: none;
    background-color: #ededed;
    filter: grayscale(1);
}

#joblist-content .slide-cta {
    border-radius: 100px;
    margin-bottom: 2rem;
    min-width: 110px;
    font-size: 1em;
    min-height: 34px;
    padding: 6px 20px;
    background-color: #344f70;
    color: #fff;
    font-weight: 500;
    font-style: normal;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    display: inline-block;
    line-height: 1.3;
    border: 1px solid transparent;
    outline: 0;
    vertical-align: middle;
    -webkit-appearance: none;
    appearance: none;
    -webkit-font-smoothing: antialiased;
    transition: all linear .2s;
}

#joblist-content .slide-cta:hover {
    background-color: #40628c;
}

/********************************
********************************
S I N G L E   J O B   C S S
**************************/
#job-offer-subitle-details {
    display: flex;
    flex-direction: row;
}

#job-offer-subitle-details div {
    display: flex;
    flex-direction: row;
    align-items: center;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 400;
    font-size: 0.9rem;
    color: #344f70;
    margin-right: 2rem;
}

#job-offer-subitle-details p {
    margin: 0;
}

#job-offer-subitle-details img {
    height: 1em;
    margin-right: 1em;
}

#job-offer-details-wrapper {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
}

#job-offer-competences {
    width: calc(70% - 0.5rem);
    margin-top: 1rem;
    margin-bottom: 3.5rem;
}

#job-offer-competences h3 {
    margin: 0 0 0.7rem 0;
}

#tagskills-wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.tagskills {
    color: #FFFFFF;
    background-color: #334E82;
    margin: 0.2rem;
    padding: 0.7rem;
    font-size: 0.8rem;
}

#job-offer-content {
    width: calc(70% - 0.5rem);
    margin: 1.5rem 0.5rem 0 0;
    padding: 0.6em 1em;
    background-color: #fff;
    border: 1px solid #dedfe2;
    border-radius: 4px;
}

#job-offer-candidate-box {
    width: calc(30% - 0.5rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #4D5C6D;
    margin: 1.5rem 0 0 0.5rem;
    background-color: #fff;
    border: 1px solid #dedfe2;
    border-radius: 4px;
}

#candidate-image {
    width: 100%;
    background-color: #f1f1f1;
    padding: 1rem;
}

#job-offer-candidate-box img {
    max-width: 40%;
    display: block;
    margin: 0 auto;
}

#candidate-cta {
    width: calc(100% - 1.5rem);
    margin: 1.5rem 0;
}

#related-jobs-wrapper {
    margin: 1.25rem 0;
    border-top: solid 1px #f1f1f1;
}

#related-jobs-wrapper h2 {
    text-transform: uppercase;
    padding: 0;
    font-size: 1rem;
    line-height: 1rem;
    margin: 1.5em 0 1.5rem 0;
    color: #344f70;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 500;
}

.related-offer-card {
    width: 100%;
    display: flex;
    flex-direction: row;
    padding: 1rem;
    background-color: #ffffff;
    transition: box-shadow 500ms;
}

.related-offer-card:hover {
    z-index: 3;
    box-shadow: 0 1px 0 0 rgb(139 141 157 / 5%), 0 5px 10px 0 rgb(65 71 108 / 15%);
}

.related-offer-card img {
    max-height: 3rem;
}

.related-offer-card h4 {
    flex-grow: 1;
    min-width: calc(55% - 3rem);
    padding: 0 1rem 0 3rem;
    margin: 0;
    color: #344f70;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 500;
    font-size: 1rem;
}

.related-offer-place {
    width: 25%;
    flex-shrink: 0;
    margin: 0;
    padding: 0 0.5rem;
    color: #A3A5A9;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 400;
    font-size: 0.85em;
    line-height: 1.3em;
}

.related-offer-place img {
    max-height: 1.1em;
    margin-right: 0.5em;
}

.related-offer-job-type {
    flex-basis: auto;
    flex-shrink: 0;
    margin: 0;
    padding: 0 0.5rem;
    color: #f08d3c;
    font-family: 'SF UI Text', sans-serif;
    font-weight: 500;
    font-size: 0.7em;
}

/********************************
********************************
P R I V A C Y   C S S
**********************/
#privacy-content {
    background-color: #fafbfd;
    color: #4D5C6D;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#privacy-wrapper {
    display: flex;
    flex-direction: column;
    margin-top: 76px;
    width: 100%;
    padding: 0 15px;
    min-height: 80vh;
}

#privacy-wrapper h1 {
    text-transform: uppercase;
    padding: 0;
    font-size: 1.3rem;
    line-height: 1.5rem;
    margin: 1.5em 0 1.5rem 0;
    color: #344f70;
    font-family: 'SF UI Text', sans-serif;
    font-weight: bold;
}

/************************
************************
C A R E E R   C S S
**********************/
html {
    scroll-behavior: smooth;
}

.page-career #topbar {
    background-color: transparent;
    padding: 20px 10px;
    box-shadow: unset;
}

.page-career #topbar.has-scrolled {
    box-shadow: none !important;
    pointer-events: none;
}

.page-career #topbar.has-scrolled #site-logo {
    opacity: 0;
    transition: all 500ms;
    pointer-events: none;
}

.page-career .button {
    background-color: #07aba5;
    box-shadow: 0px 8px 15px rgb(0 0 0 / 10%);
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}

.page-career .button img {
    height: 1.1em;
    margin-right: 0.6em;
}

.page-career .button.big {
    text-shadow: 1px 1px 1px #0000001a;
    padding: 0.9em 1.8em;
}

.page-career .button:hover {
    background-color: #334e70;
}

#hey-developer {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-image: url('../images/career-hero-bg.jpg');
    background-position: center;
    background-size: cover;
}

#hey-developer-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    padding: 0 15px;
    margin-top: 116px;
    min-height: calc(100vh - 116px);
}

#hey-developer-wrapper .title {
    font-size: 3rem;
    font-weight: bold;
    color: #ffffff;
    margin: 0;
}

#hey-developer-wrapper .subtitle {
    color: #ffffff;
    font-size: 1.2rem;
    max-width: 30rem;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

.frosted {
    background-color: rgba(255, 255, 255, 0.25);
    padding: 0.05em 0.3em;
    border-radius: 0.25em;
    font-weight: bold;
}

#hey-developer-wrapper .hero-cta,
#free-employee-wrapper .free-employee-cta {
    width: max-content;
    padding: 0.9em 1.8em;
    margin: 0;
}

.color-green {
    color: #07aba5 !important;
}

#free-employee {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 100px 0px;
}

#free-employee-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

#free-employee-wrapper .title {
    font-size: 2rem;
    font-weight: bold;
    color: #334e70;
    margin: 0;
}

#free-employee-dipendenti .title {
    font-size: 1.5rem;
    margin-top: 30px;
    margin-bottom: -10px;
}

#free-employee-wrapper .subtitle {
    color: #334e70;
    font-size: 1.2rem;
    margin-top: 1.5em;
    margin-bottom: 1em;
    text-align: center;
}

#free-employee-wrapper .text {
    color: #334e70;
    font-size: 1rem;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

#free-employee-feature {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
}

#free-employee-feature h3 {
    width: 33.3%;
    padding: 1.5rem;
    text-align: center;
    color: #07aba5;
}

#our-projects {
    width: 100%;
    background-color: #f8f8f8;
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#our-projects-wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
}

#our-projects-content,
#our-projects-image {
    width: 50%;
    padding: 0 15px;
    display: flex;
    flex-direction: column;
    align-items: baseline;
}

#our-projects-content .title {
    font-size: 2rem;
    font-weight: bold;
    color: #334e70;
    margin: 0;
}

#our-projects-content .text {
    color: #334e70;
    font-size: 1.2rem;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

#our-projects-content a {
    margin-top: 1rem;
}

#our-projects-image {
    font-size: 1.1rem;
    font-weight: bold;
    color: #334e70;
}

#our-projects-image img {
    box-shadow: 0 7px 27px 5px #2222220d;
}

#our-devs {
    width: 100%;
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#our-devs-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#our-devs-header {
    width: 100%;
    display: flex;
    flex-direction: column;
}

#our-devs-header .title {
    font-size: 2rem;
    font-weight: bold;
    color: #334e70;
    margin: 0;
}

#our-devs-header .text {
    font-size: 1.1rem;
    font-weight: bold;
    color: #334e70;
}

#our-devs-content {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    margin: 30px 0;
}

.our-devs-content-card {
    width: calc(33% - 15px);
    background-color: #f8f8f8;
    padding: 30px;
    margin: 7px;
}

.our-devs-content-card-header-wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
}

.our-devs-content-card-avatar {
    width: 20%;
    border-radius: 100px;
    overflow: hidden;
    border: 1px solid #ddd;
}

.our-devs-content-card-avatar img {
    width: 100%;
}

.our-devs-content-card-header {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    margin-left: 1rem;
}

.our-devs-content-card-header .name {
    font-size: 0.9rem;
    font-weight: bold;
    color: #334e70;
    margin: 0;
}

.our-devs-content-card-header .role {
    font-size: 0.8rem;
    color: #888;
    margin: 0;
}

.our-devs-content-card-text {
    color: #334e70;
    font-size: 1.1rem;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

.our-devs-content-card-skills {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.our-devs-content-card-skills span {
    background-color: #334e70;
    color: #ffffff;
    padding: 1em;
    margin: 0.5em 0.5em 0 0;
    font-size: 0.7rem;
}

#Cancellati {
    width: 100%;
    padding: 100px 0;
    background-image: url('../images/skills-section-bg.jpg');
    background-size: cover;
    background-attachment: fixed;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#Cancellati-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#Cancellati .title {
    font-size: 1.5rem;
    font-weight: bold;
    text-align: center;
    color: #ffffff;
    margin: 0;
}

#Cancellati .subtitle {
    color: #ffffff;
    font-size: 1rem;
    text-align: center;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

#Cancellati-form {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 767px;
}

#Cancellati-buttons {
    margin-top: 20px;
    display: flex;
    flex-direction: row;
    justify-content: center;
}

#Cancellati-fields {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    color: #ffffff;
    text-align: center;
}

#Cancellati-fields input {
    box-sizing: border-box;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 10px;
    font-size: 0.9rem;
    width: calc(50% - 15px);
    margin-bottom: 15px;
}

#Cancellati-fields input[type="radio"] {
    font-size: 0.9rem;
    width: 12px;
    margin-bottom: 15px;
}

#Cancellati-fields label {
    margin-left: 5px;
    margin-bottom: 15px;
}

#Consenso {
    width: 100%;
    padding: 100px 0;
    background-image: url('../images/skills-section-bg.jpg');
    background-size: cover;
    background-attachment: fixed;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#Consenso-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#Consenso .title {
    font-size: 1.5rem;
    font-weight: bold;
    text-align: center;
    color: #ffffff;
    margin: 0;
}

#Consenso .subtitle {
    color: #ffffff;
    font-size: 1rem;
    text-align: center;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

#Consenso-form {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 767px;
}

#Consenso-buttons {
    margin-top: 20px;
    display: flex;
    flex-direction: row;
    justify-content: center;
}

#Consenso-fields {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    color: #ffffff;
    text-align: center;
}

#Consenso-fields input {
    box-sizing: border-box;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 10px;
    font-size: 0.9rem;
    width: calc(50% - 15px);
    margin-bottom: 15px;
}

#Consenso-fields input[type="radio"] {
    font-size: 0.9rem;
    width: 12px;
    margin-bottom: 15px;
}

#Consenso-fields label {
    margin-left: 5px;
    margin-bottom: 15px;
}

#send-your-cv {
    width: 100%;
    padding: 100px 0;
    background-image: url('../images/skills-section-bg.jpg');
    background-size: cover;
    background-attachment: fixed;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#send-your-cv-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#send-your-cv .title,
#send-your-cv-thanks .title {
    font-size: 3rem;
    font-weight: bold;
    text-align: center;
    color: #ffffff;
    margin: 0;
}

#send-your-cv .subtitle,
#send-your-cv-thanks .subtitle {
    color: #ffffff;
    font-size: 1.2rem;
    text-align: center;
    margin-top: 1.5em;
    margin-bottom: 1em;
}

#send-your-cv-skills {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 767px;
    margin: 30px 0 50px 0;
}

#send-your-cv-skills .skill-selector {
    color: #FFFFFF;
    background-color: #07aba5;
    font-size: 1em;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
    padding: 5px;
    margin: 0.13rem;
    padding: 0.85rem;
    font-size: 0.8rem;
    cursor: pointer;
    transition: all 300ms;
}

#send-your-cv-skills .skill-selector.active {
    background: rgba(244, 244, 244, 0.2);
}

#send-your-cv-form {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 767px;
}

#fields-wrapper {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}

#send-your-cv-form ::-webkit-input-placeholder {
    /* Edge */
    color: #ffffff;
}

#send-your-cv-form :-ms-input-placeholder {
    /* Internet Explorer 10-11 */
    color: #ffffff;
}

#send-your-cv-form ::placeholder {
    color: #ffffff;
}

#fields-wrapper input {
    box-sizing: border-box;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 10px;
    font-size: 0.9rem;
    width: calc(25% - 15px);
    margin-bottom: 15px;
}

#fields-wrapper textarea {
    box-sizing: border-box;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 15px;
    font-size: 0.9rem;
    width: 100%;
}

#send-your-ansuer-form {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: left;
    width: 100%;
    max-width: 767px;
}

#fields-wrapper-ansuer {
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}

    #fields-wrapper-ansuer textarea {
        box-sizing: border-box;
        border: 1px solid #07aba5;
        color: #07aba5;
        padding: 15px;
        font-size: 0.9rem;
        width: 80%;
        display: flex;
    }

    #fields-wrapper-ansuer input {
        box-sizing: border-box;
        border: 1px solid #07aba5;
        color: #07aba5;
        padding: 15px;
        font-size: 0.9rem;
    }

        #fields-wrapper-ansuer input[type="number"] {
            width: 50%;
        }
        #fields-wrapper-ansuer input[type="text"] {
            width: 50%;
        }

#fields-linkedin {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    color: #ffffff;
    align-items: center;
}

#fields-linkedin input {
    box-sizing: border-box;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 10px;
    font-size: 0.9rem;
    width: calc(50% - 15px);
    margin-bottom: 15px;
}

#fields-linkedin input[type="checkbox"] {
    font-size: 0.9rem;
    width: 12px;
    margin-bottom: 15px;
}

#fields-linkedin label {
    margin-left: 5px;
    margin-bottom: 15px;
}

#send-your-cv-form .privacy {
    width: 100%;
    font-size: 0.9rem;
    color: #ffffff;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    margin-top: 50px;
}

.privacy label {
    margin-left: 5px;
}

.privacy a {
    color: #ffffff !important;
    font-weight: bold;
    text-decoration: underline;
}

#send-your-cv-buttons {
    margin-top: 20px;
    display: flex;
    flex-direction: row;
    justify-content: center;
}

#tags {
    display: none;
}

#file-attach-trigger {
    background: transparent;
    color: #ffffff;
    border: 1px solid #ffffff;
}

#send-your-cv-notifications {
    width: 100%;
}

#attachment-success,
#skills-error {
    display: none;
    color: #FFFFFF;
    font-size: 1em;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
    padding: 5px;
}

#attachment-success {
    background-color: #07aba5;
}

#skills-error {
    background-color: #e62260;
}

#send-your-cv-thanks {
    display: none;
}

/* S E R V I Z I   H O M E */

.map-container iframe {
    width: 100%;
    display: block;
    border: 0;
    max-width: 100%;
}

.service-card .service-icon i,
.service-card .service-icon .fa,
.service-card .benefit-icon i,
.service-card .benefit-icon .fa,
.benefit-item .benefit-icon i,
.benefit-item .benefit-icon .fa,
.benefit-icon i,
.benefit-icon .fa,
.service-icon i,
.service-icon .fa,
.service-icon .fas,
.service-icon .far,
.service-icon .fab,
.benefit-icon .fas,
.benefit-icon .far,
.benefit-icon .fab {
    font-size: 5rem !important;
    color: inherit !important;
    margin-bottom: var(--spacing-md, 1.25rem);
    display: block;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
}


.services-section {
    padding: 5rem 0;
    background-color: #f9fafc;
    margin-bottom: 4rem; /* Ripristinato spazio inferiore */
}

.section-title {
    text-align: center;
    font-size: 2.2rem;
    color: #2c3e50;
    margin-bottom: 3rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.services-section {
    padding: 0 20px;
}

.glide_service_cards {
    max-width: 1200px; /* Larghezza massima del carosello */
    margin: 0 auto;   /* Centra il carosello */
}

.glide_service_cards .glide__slide {
    height: auto; /* Permette alla card di definire l'altezza */
    display: flex;
    align-items: stretch; /* Assicura che le card si estendano se necessario */
    justify-content: center;
}

.services-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2rem;
}

.service-card {
    background: white;
    border-radius: 10px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12); /* Ombra normale resa più visibile */
    padding: 3rem 2.5rem; /* Aumentato padding interno */
    width: 100%;
    max-width: 350px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.glide_service_cards .service-card {
    width: 100%;
    max-width: 350px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.service-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
}

.service-icon {
    font-size: 1.25rem; /* Consistent with .service-item h3 */
    color: #2c3e50;    /* Consistent with .service-item h3 */
    margin-bottom: 1.5rem;
    transition: transform 0.3s ease;
}

.service-card:hover .service-icon {
    transform: scale(1.1);
}

.service-card h3 {
    color: #2c3e50;
    font-size: 1.5rem;
    margin-bottom: 1rem;
    font-weight: 600;
}

.service-card p {
    color: #7f8c8d;
    line-height: 1.6;
    margin-bottom: 1.5rem;
    font-size: 1rem;
}

.service-link {
    display: inline-block;
    color: #3498db;
    font-weight: 600;
    text-decoration: none;
    padding: 0.7rem 1.5rem;
    border: 2px solid #3498db;
    border-radius: 50px;
    transition: all 0.3s ease;
    margin-top: 1rem;
}

.service-link:hover {
    background-color: #3498db;
    color: white;
}

/* Responsive */
@media (max-width: 1200px) {
    .services-container {
        max-width: 1100px;
    }
    
    .service-card {
        max-width: calc(50% - 2rem);
    }
}

@media (max-width: 768px) {
    .services-section {
        padding: 0 10px;
    }
    .services-container {
        padding: 0 1.5rem;
    }
    
    .service-card {
        /* max-width: 100%; */
        margin-bottom: 1.5rem;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
}

/* W O R K   W I T H   U S */

@media (max-width: 576px) {

    #topbar-wrapper,
    #footer-wrapper,
    .slide-content-wrapper,
    #work-with-us,
    #jobs-wrapper,
    #privacy-wrapper,
    #hey-developer-wrapper,
    #free-employee-wrapper,
    #our-projects-wrapper,
    #our-devs-wrapper,
    #send-your-cv-wrapper {
        max-width: 540px;
    }

    .glide__arrow {
        display: none !important;
    }

    .slide-content-wrapper.right-align {
        align-items: flex-start;
    }

    .slogan-text p,
    .who-we-are-text p,
    .job-space-text p {
        width: 95%;
    }

    #slogan-wrapper {
        padding-bottom: 40px;
    }

    #work-with-us {
        flex-direction: column;
    }

    #work-with-us-text {
        margin-bottom: 20px;
    }

    .who-we-are-highlights ul {
        display: flex;
        flex-direction: column;
        margin-top: 30px;
    }

    .job-space-subtext {
        width: 80%;
    }

    #prefooter {
        flex-direction: column;
    }

    #skillscloud-prefooter-gallery,
    #prefooter-map {
        width: 100%;
    }

    #prefooter-map {
        height: 100vw;
    }

    #footer-wrapper {
        flex-direction: column;
    }

    #footer-menu {
        flex-direction: column;
    }

    #footer-menu li {
        margin-bottom: 10px;
    }

    .copyright {
        margin-right: 0;
    }

    .footer-bottom-right {
        width: 100%;
        padding-left: 0;
        margin-top: 10px;
        display: flex;
        justify-content: center;
    }

    #footer-socials {
        padding-left: 0;
    }

    #footer-socials li {
        margin: 0 15px;
    }

    #cookies-consent-box {
        right: 50%;
        transform: translateX(50%);
    }

    #cookies-policy-box {
        width: 90%;
    }

    #search-a-job {
        flex-wrap: wrap;
        justify-content: center;
    }

    #where,
    #filter {
        width: 100%;
        flex-basis: auto;
        margin: 0 0.5rem 1.2rem 0.5rem;
    }

    #job-search-button {
        width: calc(100% - 1rem);
        margin: 0 0.5rem 1rem 0.5rem;
    }

    .job-card {
        width: calc(100% - 1rem);
    }

    #job-offer-subitle-details {
        flex-direction: column;
    }

    #job-offer-subitle-details div {
        font-size: 0.8rem;
        margin-bottom: 0.3rem;
    }

    #job-offer-details-wrapper {
        flex-direction: column;
    }

    #job-offer-content,
    #job-offer-candidate-box,
    #job-offer-competences {
        width: 100%;
        margin: 1rem 0;
    }

    #job-offer-candidate-box {
        order: 3;
    }

    .related-offer-card {
        flex-wrap: wrap;
    }

    .related-offer-card h4 {
        min-width: initial;
        max-width: calc(100% - 3rem);
        padding: 0 0.5rem 0 0.5rem;
    }

    .related-offer-place {
        width: 100%;
        padding-left: 3.5rem;
        margin-top: 0.2rem;
    }

    .related-offer-job-type {
        width: 100%;
        padding-left: 3.5rem;
        margin-top: 0.2rem;
    }

    #hey-developer-wrapper {
        padding: 0 20px;
    }

    #free-employee-wrapper {
        padding: 0 20px;
    }

    #free-employee-feature h3 {
        width: 80%;
    }

    #our-projects-content,
    #our-projects-image {
        width: calc(100% - 40px);
    }

    #our-devs-wrapper {
        padding: 0 20px;
    }

    .our-devs-content-card {
        width: 100%;
    }

    #send-your-cv-wrapper {
        padding: 0 20px;
    }

    #send-your-cv .title,
    #send-your-cv-thanks .title {
        font-size: 2.5rem;
    }

    #fields-wrapper input {
        width: 100%;
    }

    #fields-linkedin input {
        width: 100%;
    }

    #send-your-cv-buttons {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    #send-your-cv-buttons .button {
        margin-top: 20px;
    }
}

@media (min-width:577px) AND (max-width: 767px) {

    #topbar-wrapper,
    #footer-wrapper,
    .slide-content-wrapper,
    #work-with-us,
    #jobs-wrapper,
    #privacy-wrapper,
    #hey-developer-wrapper,
    #free-employee-wrapper,
    #our-projects-wrapper,
    #our-devs-wrapper,
    #send-your-cv-wrapper {
        max-width: 720px;
    }

    .glide__arrow {
        display: none !important;
    }

    .slide-content-wrapper.right-align {
        align-items: flex-start;
    }

    .slogan-text p,
    .who-we-are-text p,
    .job-space-text p {
        width: 95%;
    }

    #slogan-wrapper {
        padding-bottom: 40px;
    }

    #work-with-us {
        flex-direction: column;
    }

    #work-with-us-text {
        margin-bottom: 20px;
    }

    .who-we-are-highlights ul {
        display: flex;
        flex-direction: column;
        margin-top: 30px;
    }

    .job-space-subtext {
        width: 80%;
    }

    #prefooter {
        flex-direction: column;
    }

    #skillscloud-prefooter-gallery,
    #prefooter-map {
        width: 100%;
    }

    #prefooter-map {
        height: 100vw;
    }

    #footer-wrapper {
        flex-direction: column;
    }

    #footer-menu {
        flex-direction: column;
    }

    #footer-menu li {
        margin-bottom: 10px;
    }

    .copyright {
        margin-right: 0;
    }

    .footer-bottom-right {
        width: 100%;
        padding-left: 0;
        margin-top: 10px;
        display: flex;
        justify-content: center;
    }

    #footer-socials {
        padding-left: 0;
    }

    #footer-socials li {
        margin: 0 15px;
    }

    #cookies-consent-box {
        right: 50%;
        transform: translateX(50%);
    }

    #cookies-policy-box {
        width: 90%;
    }

    #search-a-job {
        flex-wrap: wrap;
        justify-content: center;
    }

    #where,
    #filter {
        width: 100%;
        flex-basis: auto;
        margin: 0 0.5rem 1.2rem 0.5rem;
    }

    #job-search-button {
        width: calc(100% - 1rem);
        margin: 0 0.5rem 1rem 0.5rem;
    }

    .job-card {
        width: calc(100% - 1rem);
    }

    .related-offer-card {
        flex-wrap: wrap;
    }

    .related-offer-card h4 {
        min-width: initial;
        max-width: calc(100% - 3rem);
        padding: 0 0.5rem 0 0.5rem;
    }

    .related-offer-place {
        width: 100%;
        padding-left: 3rem;
        margin-top: 0.2rem;
    }

    .related-offer-job-type {
        width: 100%;
        padding-left: 3rem;
        margin-top: 0.2rem;
    }

    .our-devs-content-card-avatar {
        width: 15%;
    }

    #hey-developer-wrapper {
        padding: 0 20px;
    }

    #free-employee-wrapper {
        padding: 0 20px;
    }

    #free-employee-feature h3 {
        width: 80%;
    }

    #our-projects-content,
    #our-projects-image {
        width: calc(100% - 40px);
    }

    #our-devs-wrapper {
        padding: 0 20px;
    }

    .our-devs-content-card {
        width: 100%;
    }

    #send-your-cv-wrapper {
        padding: 0 20px;
    }

    #send-your-cv .title,
    #send-your-cv-thanks .title {
        font-size: 2.5rem;
    }

    #fields-wrapper input {
        width: 100%;
    }

    #fields-linkedin input {
        width: 100%;
    }

    #send-your-cv-buttons {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    #send-your-cv-buttons .button {
        margin-top: 20px;
    }
}

@media (min-width:768px) AND (max-width: 991px) {
    html {
        font-size: 130%;
    }

    #topbar-wrapper,
    #footer-wrapper,
    .slide-content-wrapper,
    #work-with-us,
    #jobs-wrapper,
    #privacy-wrapper,
    #hey-developer-wrapper,
    #free-employee-wrapper,
    #our-projects-wrapper,
    #our-devs-wrapper,
    #send-your-cv-wrapper {
        max-width: 960px;
    }

    #cookies-consent-box {
        width: 50%;
    }

    .glide__arrow {
        display: none !important;
    }

    #work-with-us {
        flex-direction: column;
        padding: 15%;
    }

    #work-with-us-text {
        margin-bottom: 30px;
    }

    .slogan-text p,
    .who-we-are-text p,
    .job-space-text p {
        width: 80%;
    }

    .who-we-are-highlights ul {
        display: flex;
        flex-direction: column;
        margin-top: 30px;
    }

    #search-a-job {
        flex-wrap: wrap;
        justify-content: flex-end;
    }

    #where,
    #filter {
        width: calc(50% - 1rem);
        margin: 0 0.5rem 1.2rem 0.5rem;
    }

    .job-card {
        width: calc(50% - 1rem);
    }

    #job-offer-subitle-details div {
        font-size: 0.8rem;
    }

    .related-offer-card {
        flex-wrap: wrap;
    }

    .related-offer-card h4 {
        max-width: calc(100% - 3rem);
    }

    .related-offer-place {
        width: 100%;
        padding-left: 6rem;
        margin-top: -1.3rem;
    }

    .related-offer-job-type {
        width: 100%;
        padding-left: 6rem;
        margin-top: 0.2rem;
    }

    #hey-developer-wrapper {
        padding: 0 50px;
    }

    #free-employee,
    #our-devs,
    #send-your-cv {
        padding: 100px 30px;
    }

    #our-projects-content,
    #our-projects-image,
    .our-devs-content-card {
        width: 80%;
    }

    #fields-wrapper input {
        width: calc(50% - 15px);
    }

    #fields-linkedin input {
        width: calc(50% - 15px);
    }
}

@media (min-width: 1200px) {

    #topbar-wrapper,
    #footer-wrapper,
    .slide-content-wrapper,
    #work-with-us,
    #jobs-wrapper,
    #privacy-wrapper,
    #hey-developer-wrapper,
    #free-employee-wrapper,
    #our-projects-wrapper,
    #our-devs-wrapper,
    #send-your-cv-wrapper {
        max-width: 1140px;
    }
}

#submit-cv, #file-attach-trigger {
    cursor: pointer;
}

#submit-cv:disabled {
    background-color: gray !important;
}

.input-symbol-euro {
    position: relative;
}

    .input-symbol-euro input {
        padding-right: 18px;
    }

    .input-symbol-euro:after {
        padding: 15px;
        top: 0;
        content: "€";
        right: 100px;
        position: relative;
    }

/* Stili aggiunti per correggere le frecce duplicate del carosello principale */
/* e assicurare la visibilità su schermi grandi - AUMENTO SPECIFICITÀ */

body #skillscloud-home-slider.glide .glide__arrows .glide__arrow {
    border: none !important;
    background-color: transparent !important;
    padding: 11px 14px !important; /* Manteniamo un padding per l'area cliccabile del bottone */
    box-shadow: none !important;
    text-shadow: none !important;
    color: transparent !important; /* Nasconde il testo/contenuto originale del bottone */
    font-size: 0 !important; /* Nasconde il testo/contenuto originale del bottone */
    line-height: 0 !important; /* Nasconde il testo/contenuto originale del bottone */
}

body #skillscloud-home-slider.glide .glide__arrows .glide__arrow span {
    color: white !important;
    font-size: 1.8em !important; /* Dimensione esplicita e leggermente aumentata per lo span */
    line-height: 1 !important; /* Assicura che lo span sia allineato verticalmente */
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.7) !important; /* Ombra più marcata e !important per contrasto */
    display: inline-block !important; /* Per assicurare che padding/dimensioni dello span siano rispettate */
    padding: 5px !important; /* Padding interno allo span stesso, se necessario */
}

/* Rimuoviamo eventuali pseudo-elementi che potrebbero creare le "frecce duplicate" */
body #skillscloud-home-slider.glide .glide__arrows .glide__arrow::before,
body #skillscloud-home-slider.glide .glide__arrows .glide__arrow::after {
    content: none !important;
    display: none !important;
}

/* Media query con selettore ad alta specificità */
@media (min-width: 768px) { /* O il breakpoint rilevante per il tuo design */
    body #skillscloud-home-slider.glide .glide__arrows {
        display: block !important; 
    }
    body #skillscloud-home-slider.glide .glide__arrows .glide__arrow {
        display: flex !important; /* Usiamo flex per centrare lo span */
        align-items: center !important;
        justify-content: center !important;
        width: 44px !important; /* Dimensioni fisse per il bottone freccia */
        height: 44px !important;
        padding: 0 !important; /* Rimuoviamo il padding dal bottone se lo span è dimensionato e centrato */
    }
    body #skillscloud-home-slider.glide .glide__arrows .glide__arrow span {
        padding: 0 !important; /* Se il bottone è flex e centra, lo span non ha bisogno di padding aggiuntivo per il posizionamento */
        font-size: 24px !important; /* Dimensione fissa per l'icona span */
    }
}

/* Posizionamento specifico per le frecce del carosello SERVIZI */
.glide_service_cards {
    position: relative; /* Assicura un contesto di posizionamento per le frecce figlie assolute */
    /* Considera di aggiungere padding laterale se le frecce escono troppo e vengono tagliate:
    padding-left: 30px; 
    padding-right: 30px; 
    box-sizing: border-box; 
    */
}

.glide_service_cards .glide__arrow {
    top: 50% !important; 
    transform: translateY(-50%) !important;
    z-index: 3 !important; /* Assicura che siano sopra le card se si sovrappongono leggermente */

    /* Stili per frecce servizi: carattere freccia nero su sfondo bianco circolare */
    background-color: white !important;
    border: 1px solid #dddddd !important; 
    width: 36px !important; 
    height: 36px !important; 
    border-radius: 50% !important; 
    padding: 0 !important; 
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important; 
    
    /* Stili per il carattere '›' o '‹' dentro il bottone */
    color: #000000 !important;  /* NERO per il carattere freccia */
    font-size: 24px !important; /* Aumenta la dimensione del carattere. Regola se necessario. */
    line-height: 34px !important; /* Aggiustato per tentare un miglior centraggio verticale. Valore da testare. */
    text-align: center !important; /* Assicura che il carattere sia centrato orizzontalmente */
    font-weight: normal !important; /* O 'bold' se preferisci */
    /* font-family: 'Arial', sans-serif; /* Considera un font di fallback se il default non è buono */ */

/* Fix: forza il font-family corretto per le icone Font Awesome */
i.fas, i.far, i.fab, i.fal, i.fad, .fa, .fab, .fas, .far, .fal, .fad {
    font-family: "Font Awesome 5 Free" !important;
    font-weight: 900 !important;
}
.far {
    font-weight: 400 !important;
}
.fab {
    font-family: "Font Awesome 5 Brands" !important;
    font-weight: 400 !important;
}

}

/* La regola per .glide_service_cards .glide__arrow svg è rimossa perché non usiamo SVG qui */

/* Se Glide non usa SVG ma un font-icon, commentare la regola SVG sopra e decommentare/adattare una delle seguenti:
.glide_service_cards .glide__arrow [class*="icon-"], 
.glide_service_cards .glide__arrow [class*="fa-"], /* Esempio per FontAwesome */
/* .glide_service_cards .glide__arrow::before { /* Se usa pseudo-elementi con content per l'icona */
/*    color: #000000 !important; 
/*    font-size: 20px !important; /* Adatta la dimensione se necessario */
/*    line-height: 1 !important;
/* }
*/

.glide_service_cards .glide__arrow--left {
    left: -35px !important; /* Aumentata distanza dal bordo sinistro. Regolare se necessario. */
}

.glide_service_cards .glide__arrow--right {
    right: -35px !important; /* Aumentata distanza dal bordo destro. Regolare se necessario. */
}

/* Media Query per schermi piccoli per il carosello servizi */
@media (max-width: 767px) { /* Adatta per mobile/tablet piccoli */
    .glide_service_cards .glide__arrow--left {
        left: 5px !important; /* Più interne su schermi piccoli per evitare tagli */
    }
    .glide_service_cards .glide__arrow--right {
        right: 5px !important; /* Più interne su schermi piccoli per evitare tagli */
    }
    /* Considera di ridurre la dimensione/padding delle frecce qui se necessario */
}