.elementor-kit-6{--e-global-color-primary:#111111;--e-global-color-secondary:#585858;--e-global-color-text:#111111;--e-global-color-accent:#585858;--e-global-color-e16b3ea:#EBF0F2;--e-global-color-f3fbd02:#6D6D6D;--e-global-color-056dd2b:#FFFFFF;--e-global-typography-primary-font-family:"Mulish";--e-global-typography-primary-font-weight:700;--e-global-typography-secondary-font-family:"Mulish";--e-global-typography-secondary-font-weight:800;--e-global-typography-text-font-family:"Inter";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Inter";--e-global-typography-accent-font-weight:500;font-family:"Inter", Sans-serif;}.elementor-kit-6 h1{font-family:"Mulish", Sans-serif;font-weight:800;}.elementor-kit-6 h2{font-family:"Mulish", Sans-serif;font-weight:800;}.elementor-kit-6 h3{font-family:"Mulish", Sans-serif;font-weight:800;}.elementor-kit-6 h4{font-family:"Mulish", Sans-serif;}.elementor-kit-6 h5{font-family:"Mulish", Sans-serif;}.elementor-kit-6 h6{font-family:"Mulish", Sans-serif;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){--kit-widget-spacing:1rem;}.elementor-element{--widgets-spacing:1rem 1rem;--widgets-spacing-row:1rem;--widgets-spacing-column:1rem;}{}h1.entry-title{display:var(--page-title-display);}.elementor-kit-6 e-page-transition{background-color:#FFBC7D;}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}:root { --black:#111; --dark-grey:#585858; --light-grey:#ececec; --medium-grey:#6d6d6d; --space-sm:1.5rem; --space-md:2.5rem; --space-lg:3rem; --gap-md:1.25rem; --gap-sm:1rem; --gap-lg:2rem; --white:#ffffff; --gap-xsm:0.5rem; --border-xsm:1px; --border-sm:2px; --ff-primary:Mulish; --ff-secondary:Inter; --gap-xl:2.5rem; --space-xlg:5rem; --gap-xxl:3rem; --shadow-light:rgba(0, 0, 0, .16); --lm-grey:#ccc; }
/* Start custom CSS *//* =========================================================
   TOKENS
   ========================================================= */

:root {
  /* Breakpoints */
  --bp-sm: 768px;
  --bp-md: 1024px;
  --bp-lg: 1240px;

  /* Spacing */
  --space-section-sm: 1.5rem;
  --space-section-md: 2.5rem;
  --space-section-lg: 3rem;
  --space-list-bottom: 1.5rem;
  --space-fluid-bottom: clamp(1.5rem, 2vh, 4rem);

  /* Typography */
  --fs-h1: clamp(2.5rem, 2rem + 1.2vw, 3.5rem);      /* 40px -> 56px */
  --fs-h2: clamp(1.75rem, 1.35rem + 0.9vw, 2.25rem);  /* 28px -> 40px */
  --fs-h3: clamp(1.375rem, 1.125rem + 0.6vw, 1.75rem);  /* 22px -> 32px */
  --fs-h4: clamp(1.125rem, 1rem + 0.35vw, 1.5rem);   /* 18px -> 24px */

  --fs-copy-lg: clamp(1.0625rem, 1.02rem + 0.2vw, 1.1875rem); /* 17px -> 19px */
  --fs-copy-xl: clamp(1.1875rem, 1.1rem + 0.35vw, 1.375rem);  /* 19px -> 22px */

  /* Line heights */
  --lh-h1: 1;
  --lh-title: 1.125;
  --lh-tight: 1.15;
  --lh-copy: 1.45;
  --lh-copy-xl: 1.4;

  /* Layout */
  --max-width-sm: 800px;
  --max-width-md: 1000px;
  --max-width-lg: 1140px;

  /* Radius */
  --radius-image: 0.125rem;

  /* Shadow */
  --shadow-image: 0 24px 32px -24px rgba(0, 0, 0, 0.24);
}

/* =========================================================
   TYPOGRAPHY
   ========================================================= */

h1,
.title-h1 {
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
}

h2,
.title-h2 {
  font-size: var(--fs-h2);
  line-height: var(--lh-title);
}

h3,
.title-h3 {
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
}

h4,
.title-h4 {
  font-size: var(--fs-h4);
  line-height: 1.2;
}

.text-lg {
  font-size: var(--fs-copy-lg);
  line-height: var(--lh-copy);
  text-wrap: balance;
}

.text-xl {
  font-size: var(--fs-copy-xl);
  line-height: var(--lh-copy-xl);
  text-wrap: balance;
}

.text-balance {
  text-wrap: balance;
}

.no-p-margin p {
  margin-bottom: 0;
}

/* =========================================================
   LAYOUT / CONTAINERS
   ========================================================= */

.section {
  padding: var(--space-section-sm);
}

.section-lg {
  padding: var(--space-section-sm);
}

.section-xl {
  padding: var(--space-section-md);
}

.container-sm {
  max-width: var(--max-width-sm);
  margin-left: auto;
  margin-right: auto;
}

.container-md {
  max-width: var(--max-width-md);
  margin-left: auto;
  margin-right: auto;
}

.container-lg {
  max-width: var(--max-width-lg);
  margin-left: auto;
  margin-right: auto;
}

.pad-x-page {
  padding-left: var(--space-section-sm);
  padding-right: var(--space-section-sm);
}

.pad-t-section {
  padding-top: var(--space-section-sm);
}

.pad-b-section {
  padding-bottom: var(--space-section-sm);
}

.space-t-section {
  margin-top: var(--space-section-sm);
}

.space-b-section {
  margin-bottom: var(--space-section-sm);
}

.space-b-fluid {
  margin-bottom: var(--space-fluid-bottom) !important;
}

.mt-auto {
  margin-top: auto;
}

@media (min-width: 768px) {
  .section,
  .section-lg {
    padding: var(--space-section-md);
  }

  .section-xl {
    padding: var(--space-section-md);
  }

  .pad-x-page {
    padding-left: var(--space-section-md);
    padding-right: var(--space-section-md);
  }

  .pad-t-section {
    padding-top: var(--space-section-md);
  }

  .pad-b-section {
    padding-bottom: var(--space-section-md);
  }

  .space-t-section {
    margin-top: var(--space-section-md);
  }

  .space-b-section {
    margin-bottom: var(--space-section-md);
  }
}

@media (min-width: 1024px) {
  .section,
  .section-lg {
    padding: var(--space-section-lg);
  }

  .section-xl {
    padding: var(--space-section-lg);
  }

  .pad-x-page {
    padding-left: var(--space-section-lg);
    padding-right: var(--space-section-lg);
  }

  .pad-t-section {
    padding-top: var(--space-section-lg);
  }

  .pad-b-section {
    padding-bottom: var(--space-section-lg);
  }

  .space-t-section {
    margin-top: var(--space-section-lg);
  }

  .space-b-section {
    margin-bottom: var(--space-section-lg);
  }
}

/* =========================================================
   CONTENT FIXES
   ========================================================= */

.br-desktop br {
  display: none;
}

@media (min-width: 1024px) {
  .br-desktop br {
    display: inline;
  }
}

.content ul,
.content ol,
.list-content {
  margin-bottom: var(--space-list-bottom);
}

/* =========================================================
   IMAGE STYLES
   ========================================================= */

.img-box img {
  border-radius: var(--radius-image);
  box-shadow: var(--shadow-image);
}

/* =========================================================
   BOX ICONA SETTORI - Template Portfolio
   ========================================================= */
   
.portfolio-settore-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
}

.portfolio-settore-badge__icon-wrap {
  width: 100%;
  max-width: 10rem;
  aspect-ratio: 1 / 1;
  border: 2px solid var(--light-grey);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: #fff;
}

.portfolio-settore-badge__img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  display: block;
  object-fit: contain;
}

.portfolio-settore-badge__label {
  font-size: 1rem;
  line-height: 1.05;
  font-weight: 700;
  text-align: center;
  color: #111;
}


/* =========================================================
   MENU VISIBILITY
   ========================================================= */

.menu-desktop,
.menu-social-desktop {
  display: none !important;
}

.menu-mobile {
  display: block !important;
}

/* Togli stile bottone dal wrapper dell'icona */
button.e-image-link-base {
  background: transparent !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* (Opzionale) rimuovi eventuale outline al focus */
button.e-image-link-base:focus {
  outline: none !important;
}

@media (min-width: 1240px) {
  .menu-desktop,
  .menu-social-desktop {
    display: block !important;
  }

  .menu-mobile {
    display: none !important;
  }
}

/* =========================================================
   HEADER - Animazione fondo con scroll
   ========================================================= */

.js-header-fade {
  --header-bg-opacity: 0;
  background-color: rgba(17, 17, 17, var(--header-bg-opacity)) !important;
  transition: background-color 0.12s linear;
}
.js-header-fade,
.js-header-fade a,
.js-header-fade svg,
.js-header-fade .elementor-button,
.js-header-fade .elementor-icon {
  transition: color 0.2s ease, fill 0.2s ease, stroke 0.2s ease;
}/* End custom CSS */