.elementor-18 .elementor-element.elementor-element-767dfa2{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--overlay-opacity:0.5;}.elementor-18 .elementor-element.elementor-element-767dfa2:not(.elementor-motion-effects-element-type-background), .elementor-18 .elementor-element.elementor-element-767dfa2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://babolin.info/wp-content/uploads/2025/09/Service-Strumentale-Babolin.png");background-position:center center;background-repeat:no-repeat;background-size:auto;}.elementor-18 .elementor-element.elementor-element-767dfa2::before, .elementor-18 .elementor-element.elementor-element-767dfa2 > .elementor-background-video-container::before, .elementor-18 .elementor-element.elementor-element-767dfa2 > .e-con-inner > .elementor-background-video-container::before, .elementor-18 .elementor-element.elementor-element-767dfa2 > .elementor-background-slideshow::before, .elementor-18 .elementor-element.elementor-element-767dfa2 > .e-con-inner > .elementor-background-slideshow::before, .elementor-18 .elementor-element.elementor-element-767dfa2 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:#000000;--background-overlay:'';}.elementor-18 .elementor-element.elementor-element-2ee0da9{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-650ca7f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-650ca7f:not(.elementor-motion-effects-element-type-background), .elementor-18 .elementor-element.elementor-element-650ca7f > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-18 .elementor-element.elementor-element-5628d55{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-197bef1{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-197bef1:not(.elementor-motion-effects-element-type-background), .elementor-18 .elementor-element.elementor-element-197bef1 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-18 .elementor-element.elementor-element-3bb694e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-2574876{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-57c4671{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-02c10fe{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-02c10fe:not(.elementor-motion-effects-element-type-background), .elementor-18 .elementor-element.elementor-element-02c10fe > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-18 .elementor-element.elementor-element-ad22e60{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-18 .elementor-element.elementor-element-ad22e60.e-con{--align-self:center;}.elementor-18 .elementor-element.elementor-element-19f9c05{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-18 .elementor-element.elementor-element-7ada42b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-form .elementor-field-group > label, .elementor-widget-form .elementor-field-subgroup label{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group > label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-type-html{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-group .elementor-field{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group .elementor-field, .elementor-widget-form .elementor-field-subgroup label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-button{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form .e-form__buttons__wrapper__button-next{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-button[type="submit"]{background-color:var( --e-global-color-accent );}.elementor-widget-form .e-form__buttons__wrapper__button-previous{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-message{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .e-form__indicators__indicator, .elementor-widget-form .e-form__indicators__indicator__label{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form{--e-form-steps-indicator-inactive-primary-color:var( --e-global-color-text );--e-form-steps-indicator-active-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-completed-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-background-color:var( --e-global-color-text );--e-form-steps-indicator-progress-meter-color:var( --e-global-color-text );}.elementor-widget-form .e-form__indicators__indicator__progress__meter{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-type-html{padding-bottom:0px;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .e-form__buttons__wrapper__button-next{background-color:#E31C24;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-button[type="submit"]{background-color:#E31C24;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .e-form__buttons__wrapper__button-previous{background-color:#E31C24;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .e-form__buttons__wrapper__button-next:hover{background-color:#B51518;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-button[type="submit"]:hover{background-color:#B51518;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473 .e-form__buttons__wrapper__button-previous:hover{background-color:#B51518;color:#ffffff;}.elementor-18 .elementor-element.elementor-element-8ab1473{--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-indicator-completed-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-18 .elementor-element.elementor-element-19f9c05{--width:50%;}.elementor-18 .elementor-element.elementor-element-7ada42b{--width:50%;}}@media(min-width:1025px){.elementor-18 .elementor-element.elementor-element-767dfa2:not(.elementor-motion-effects-element-type-background), .elementor-18 .elementor-element.elementor-element-767dfa2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-attachment:fixed;}}/* Start custom CSS for container, class: .elementor-element-767dfa2 *//* =========================================================
   HERO – SERVICE STRUMENTALE
   ========================================================= */
.hero-service{
  position:relative;
  min-height:55vh;                     /* compatto come le altre hero */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  overflow:hidden;
}

.hero-service__content{
  position:relative;
  z-index:2;
  max-width:780px;
  padding:0 1rem;
}

/* titolo */
.hero-service__title{
  font-family:"Montserrat",sans-serif;
  font-size:clamp(2.2rem,5vw + 1rem,3.4rem);
  font-weight:800;
  line-height:1.15;
  margin:0 0 1rem;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.hero-service__title em{
  font-style:normal;
  color:var(--color-accent);           /* rosso brand */
}

/* sottotitolo */
.hero-service__subtitle{
  font-size:clamp(1rem,1vw + .6rem,1.25rem);
  font-weight:500;
  margin:0 0 2rem;
}

/* CTA */
.hero-service__btn{
  display:inline-block;
  background:var(--color-accent);
  color:#fff;
  padding:.9rem 2.4rem;
  border-radius:4px;
  font-weight:600;
  text-decoration:none;
  transition:background .2s;
}
.hero-service__btn:hover{
  background:var(--color-accent-d);    /* rosso scuro */
}

/* mobile tweak */
@media(max-width:767px){
  .hero-service{min-height:50vh;}
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-2ee0da9 *//* =========================================================
   SERVIZI STRUMENTALI · FLIPBOX (front info · back spiegazione)
   ========================================================= */
.svc-flip{
  background:#fff;
  padding:3rem 1rem 3.2rem;
  text-align:center;
}
.svc-title{
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  letter-spacing:.4px;
  line-height:1.1;
  color:var(--color-primary, #0A4EA8);
  font-size:clamp(1.9rem, 2.2vw + 1rem, 2.6rem);
  margin:0 0 2rem;
}

/* griglia 4 → 2 → 1 */
.flip-grid{
  display:grid;
  gap:1.2rem;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  max-width:1200px;
  margin-inline:auto;
}
@media (min-width:1200px){
  .flip-grid{ grid-template-columns:repeat(4,1fr); }
}

/* struttura flip */
.flip-card{
  perspective:1000px;
  height:270px;                /* altezza card */
  cursor:pointer;
  transition:transform .22s;
  outline:0;                   /* gestito da focus ring sotto */
  border-radius:12px;          /* per un’ombra più morbida al volo */
}
.flip-card:hover{ transform:translateY(-4px); }
.flip-card:focus-visible{ box-shadow:0 0 0 3px rgba(227,28,36,.35); border-radius:14px; }

.flip-inner{
  width:100%; height:100%;
  transform-style:preserve-3d;
  transition:transform .6s;
}
.flip-card:hover .flip-inner,
.flip-card:focus-within .flip-inner{
  transform:rotateY(180deg);
}

/* facce */
.flip-face{
  position:absolute; inset:0;
  border-radius:12px;
  backface-visibility:hidden;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:1.2rem 1rem;
  text-align:center;
  box-shadow:0 3px 10px rgba(0,0,0,.06);
  border:1px solid var(--gray-300, #d6dbe3);
  overflow:hidden;
}

/* fronte: glass blu tenue su bianco */
.flip-front{
  background:rgba(10,78,168,.06);
  backdrop-filter:blur(6px) saturate(150%);
  -webkit-backdrop-filter:blur(6px) saturate(150%);
  color:var(--color-primary, #0A4EA8);
}

/* retro: blu pieno, testo bianco */
.flip-back{
  background:var(--color-primary, #0A4EA8);
  color:#fff;
  transform:rotateY(180deg);
  padding:1.2rem 1rem;
}

/* icone (immagine o emoji) */
.flip-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:82px; height:82px; margin-bottom:.5rem;
  font-size:62px; line-height:1;           /* fallback se rimane un’emoji */
}
.flip-icon img{ width:100%; height:100%; object-fit:contain; display:block; }

/* testi front */
.flip-head{
  font-size:1.05rem;
  font-weight:700;
  margin:0 0 .2rem;
}
.flip-tag{
  font-size:.9rem;
  color:var(--gray-700, #4a5568);
  margin:0;
}

/* testo retro (spiegazione breve) */
.flip-desc{
  margin:0;
  font-size:.96rem;
  line-height:1.5;
  max-width:92%;
}

/* accessibilità: focus ring rosso sulla card */
.flip-card:focus-within::after{
  content:""; position:absolute; inset:-4px;
  border:3px solid rgba(227,28,36,.35);
  border-radius:14px; pointer-events:none;
}

/* mobile */
@media (max-width:575px){
  .flip-card{ height:240px; }
  .flip-icon{ width:145px; height:145px; font-size:52px; }
  .flip-back{ padding:1rem .9rem; }
  .flip-desc{ font-size:.94rem; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-650ca7f *//* =========================================================
   RILIEVO 3D · LAYOUT FULL-WIDTH (bg grigio chiaro)
   ========================================================= */
.svc-3d-alt{
  background: var(--color-bg-alt, #f5f7fa);  /* grigio chiaro */
  padding: 3rem 1rem 3.5rem;
}
.svc3d-wrap{
  max-width: 1200px;
  margin-inline: auto;
}

/* Titolo lowercase + lead full-width */
.svc3d-head{ margin-bottom: 1.2rem; text-align: left; }
.svc3d-title{
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  text-transform: none;              /* lowercase */
  letter-spacing: .2px;
  line-height: 1.12;
  color: var(--color-primary, #0A4EA8);
  font-size: clamp(1.9rem, 2.2vw + 1rem, 2.6rem);
  margin: 0 0 .5rem;
}
.svc3d-lead{
  font-size: clamp(1rem, .4vw + 1rem, 1.12rem);
  color: var(--gray-800, #2d3748);
  margin: 0;
}

/* Due colonne */
.svc3d-rows{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 2.5vw, 2rem);
  margin: 1.2rem 0 1.6rem;
}
.svc3d-col{ background: #fff; border: 1px solid var(--gray-300, #d6dbe3);
  border-radius: 12px; padding: 1.1rem 1.2rem; box-shadow: 0 4px 12px rgba(0,0,0,.05);
}

/* Sottotitoli e bullet rossi */
.svc3d-sub{
  font-weight: 700; color: var(--color-primary, #0A4EA8);
  font-size: 1.05rem; margin: .1rem 0 .5rem;
}
.svc3d-feats{ list-style: none; margin: 0; padding: 0; }
.svc3d-feats li{
  position: relative; padding-left: 1.15rem;
  margin: .28rem 0; color: var(--gray-800, #2d3748);
  font-size: .95rem; line-height: 1.45;
}
.svc3d-feats li::before{
  content: ""; position: absolute; left: 0; top: .5em;
  width: .6rem; height: .6rem; border-radius: 2px;
  background: var(--color-accent, #E31C24);           /* accento rosso */
  box-shadow: 0 0 0 2px rgba(227,28,36,.12);
}

/* Media full-width */
.svc3d-figure{
  margin: 1rem 0 1.2rem;
  width: 100%; aspect-ratio: 16/10;
  border-radius: 12px; overflow: hidden;
  border: 1px solid var(--gray-300, #d6dbe3);
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.svc3d-figure img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.svc3d-caption{ font-size: .9rem; color: var(--gray-700, #4a5568); text-align: center; margin: .45rem 0 0; }

/* Settori full-width */
.svc3d-sectors{ margin-top: 1.2rem; }
.sector-title{ margin-bottom: .6rem; text-transform: none; }
.svc3d-tags{
  display: flex; flex-wrap: wrap; gap: .5rem .6rem;
  list-style: none; margin: 0; padding: 0;
}
.svc3d-tags .tag{
  font-size: .9rem; font-weight: 600;
  color: var(--color-primary, #0A4EA8);
  border: 1px solid var(--color-primary, #0A4EA8);
  background: #fff;
  padding: .38rem .65rem;
  border-radius: 999px;
  transition: background .2s, color .2s, border-color .2s, transform .2s;
}
.svc3d-tags .tag:hover{
  background: var(--color-primary, #0A4EA8);
  color: #fff; transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 992px){
  .svc3d-rows{ grid-template-columns: 1fr; }
}
@media (max-width: 575px){
  .svc-3d-alt{ padding: 2.4rem 1rem 3rem; }
  .svc3d-col{ padding: .95rem 1rem; }
  .svc3d-figure{ margin: .8rem 0 1rem; }
}
/* Sezione Rilievo 3D: centra titolo e lead */
.svc3d-head{ text-align:center; }
.svc3d-title{ margin:0 auto .5rem; }  /* per sicurezza *//* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-5628d55 *//* =========================================================
   SEZIONE 3 · SERVICE – 5 STEP
   ========================================================= */
.service-steps{
  padding:3.5rem 1rem 3rem;
  background:var(--color-bg);                 /* bianco */
  text-align:center;
}

.steps__title{
  font-family:"Montserrat",sans-serif;
  color:var(--color-primary);
  font-weight:800;
  font-size:clamp(1.7rem,2vw + 1rem,2.2rem);
  margin-bottom:2.5rem;
}

/* ----- wrapper ----- */
.steps-wrapper{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:2rem;
  max-width:1100px;
  margin-inline:auto;
}

/* ----- card ----- */
.step-card{
  flex:1 1 240px;                             /* 5 card / riga desktop */
  background:#fff;
  border:1px solid var(--gray-400);
  border-radius:12px;
  padding:2.2rem 1.5rem 2.6rem;
  position:relative;
  box-shadow:0 3px 10px rgba(0,0,0,.06);
  transition:transform .25s,box-shadow .25s;
}
.step-card:hover{
  transform:translateY(-4px);
  box-shadow:0 6px 18px rgba(0,0,0,.12);
}

/* numero cerchiato */
.step-number{
  position:absolute;
  top:-24px; left:50%; transform:translateX(-50%);
  width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  background:var(--color-primary);
  color:#fff;
  font-weight:700;
  font-size:1.25rem;
  border-radius:50%;
  border:4px solid #fff;
  box-shadow:0 2px 6px rgba(0,0,0,.15);
}

/* headline + testo */
.step-headline{
  margin:1.7rem 0 .6rem;
  font-size:1.05rem;
  font-weight:700;
  color:var(--color-primary);
}
.step-text{
  font-size:.95rem;
  color:var(--gray-700);
  line-height:1.55;
  margin:0;
}

/* mobile: card intere impilate */
@media(max-width:767px){
  .step-card{flex:1 1 100%;}
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-197bef1 *//* =========================================================
   PER CHI LAVORIAMO · PILLS
   ========================================================= */
.audience{
  background: var(--color-bg-alt, #f5f7fa);   /* grigio chiaro */
  padding: 3rem 1rem 3.2rem;
}
.aud-wrap{ max-width: 1200px; margin-inline: auto; }

/* Titolo lowercase e centrato */
.aud-title{
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  text-transform: none;                      /* lowercase */
  letter-spacing: .2px;
  line-height: 1.12;
  color: var(--color-primary, #0A4EA8);
  font-size: clamp(1.9rem, 2.2vw + 1rem, 2.6rem);
  text-align: center;
  margin: 0 0 1.2rem;
}

/* Lista pills responsive */
.aud-pills{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem .7rem;
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1100px;                         /* riga più leggibile */
}

/* Pill base */
.pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .42rem .7rem;
  border-radius: 999px;
  border: 1px solid var(--color-primary, #0A4EA8);
  color: var(--color-primary, #0A4EA8);
  background: #fff;
  font-weight: 600;
  font-size: .95rem;
  line-height: 1;
  transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s;
  cursor: default;                            /* non cliccabile (solo informativa) */
}

/* Hover (solo estetico) */
@media (hover:hover){
  .pill:hover{
    background: var(--color-primary, #0A4EA8);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0,0,0,.10);
  }
}

/* Focus (se un giorno diventano link) */
.pill:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(227,28,36,.35);  /* anello rosso */
}

/* Mobile tweak */
@media (max-width: 575px){
  .audience{ padding: 2.4rem 1rem 3rem; }
  .pill{ font-size: .92rem; padding: .38rem .65rem; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-3bb694e *//* =========================================================
   SEZIONE 5 · CASE STUDY – strip scroll-snap
   ========================================================= */
.case-section{
  padding:3rem 1rem;
  background:var(--color-bg);          /* bianco */
  text-align:center;
}

.case-title{
  font-family:"Montserrat",sans-serif;
  color:var(--color-primary);
  font-weight:700;
  font-size:clamp(1.7rem,2vw + 1rem,2.2rem);
  margin-bottom:2rem;
}

/* strip orizzontale mobile, griglia 2×2 desktop */
.case-strip{
  display:flex;
  gap:1.5rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:1rem;
}
.case-strip::-webkit-scrollbar{height:8px;}
.case-strip::-webkit-scrollbar-thumb{
  background:var(--gray-400);border-radius:4px;
}

/* card base */
.case-card{
  flex:0 0 320px;                   /* larghezza card mobile */
  scroll-snap-align:center;
  border-radius:12px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  box-shadow:0 3px 10px rgba(0,0,0,.06);
  transition:transform .25s,box-shadow .25s;
}
.case-card:hover{
  transform:translateY(-4px);
  box-shadow:0 6px 16px rgba(0,0,0,.12);
}

/* figure & overlay */
.case-figure{margin:0;position:relative;}
.case-figure img{width:100%;height:auto;display:block;}

.case-overlay{
  position:absolute;inset:0;
  background:rgba(10,78,168,.82);   /* blu + 82 % */
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:1.4rem;
  opacity:0;
  transition:opacity .25s;
}
.case-card:hover .case-overlay{opacity:1;}

.case-overlay h3{
  font-size:1.05rem;
  font-weight:700;
  margin:0 0 .4rem;
}
.case-meta{
  font-size:.9rem;
  line-height:1.4;
  margin:0 0 1rem;
}
.case-link{
  font-weight:600;
  text-decoration:underline;
}

/* desktop: 2×2 griglia */
@media(min-width:1024px){
  .case-strip{
    overflow:visible;
    flex-wrap:wrap;
    justify-content:center;
    padding-bottom:0;
  }
  .case-card{
    flex:0 0 calc(50% - 1.5rem);    /* 2 card per riga */
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-2574876 *//* =========================================================
   SEZIONE 6 · TECH STRIP (SERVICE)
   ========================================================= */
.tech-section{
  padding:3rem 1rem;
  background:var(--color-bg-alt);        /* grigio 100 */
  text-align:center;
}

.tech-title{
  font-family:"Montserrat",sans-serif;
  color:var(--color-primary);
  font-weight:700;
  font-size:clamp(1.7rem,2vw + 1rem,2.2rem);
  margin-bottom:2rem;
}

/* strip orizzontale mobile, griglia centrata desktop */
.tech-strip{
  display:flex;
  gap:2.5rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:1rem;
}
.tech-strip::-webkit-scrollbar{height:8px;}
.tech-strip::-webkit-scrollbar-thumb{
  background:var(--gray-400);border-radius:4px;
}

.tech-strip img{
  flex:0 0 160px;
  height:80px;
  object-fit:contain;
  opacity:.65;
  filter:grayscale(100%);
  scroll-snap-align:center;
  transition:opacity .2s,filter .2s,transform .2s;
}
.tech-strip img:hover{
  opacity:1;filter:none;transform:scale(1.06);
}

/* desktop: centrato senza overflow */
@media(min-width:1024px){
  .tech-strip{
    justify-content:center;
    overflow:visible;
    padding-bottom:0;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-57c4671 *//* =========================================================
   SEZIONE 6 · SERVICE – PACCHETTI PREZZO
   ========================================================= */
.pricing-service{
  padding:3.5rem 1rem 3rem;
  background:var(--color-bg);                /* bianco */
  text-align:center;
}

.pricing-serv__title{
  font-family:"Montserrat",sans-serif;
  color:var(--color-primary);
  font-weight:700;
  font-size:clamp(1.7rem,2vw + 1rem,2.2rem);
  margin-bottom:2.2rem;
}

/* -------- griglia ------- */
.pricing-card-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  max-width:1100px;
  margin-inline:auto;
}

/* -------- card ------- */
.price-card{
  background:#fff;
  border:2px solid var(--gray-300);
  border-radius:12px;
  padding:2rem 1.5rem 2.6rem;
  box-shadow:0 3px 10px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  align-items:center;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.price-card:hover{
  transform:translateY(-4px);
  box-shadow:0 6px 18px rgba(0,0,0,.12);
  border-color:var(--color-primary);
}

/* carta “Avanzato” evidenziata */
.price-card--highlight{
  border-color:var(--color-accent);
}

/* titolo + prezzo */
.price-name{
  font-size:1.15rem;
  font-weight:700;
  color:var(--color-primary);
  margin:0 0 .6rem;
}
.price-value{
  font-size:1.9rem;
  font-weight:800;
  color:var(--color-primary);
  margin:0 0 1rem;
}
.price-value span{color:var(--color-accent);}

/* elenco feature */
.price-features{
  list-style:none;
  padding:0;
  margin:0 0 1.6rem;
  text-align:left;
  width:100%;
}
.price-features li{
  position:relative;
  padding-left:1.2rem;
  font-size:.95rem;
  color:var(--gray-700);
  margin:.35rem 0;
}
.price-features li::before{
  content:"✓";
  position:absolute;left:0;top:0;
  color:var(--color-accent);
  font-weight:700;
}

/* bottone */
.price-btn{
  margin-top:auto;
  display:inline-block;
  background:var(--color-accent);
  color:#fff;
  font-weight:600;
  padding:.8rem 2.2rem;
  border-radius:4px;
  text-decoration:none;
  transition:background .2s;
}
.price-btn:hover{background:var(--color-accent-d);}

.pricing-note{
  font-size:.9rem;
  color:var(--gray-700);
  margin-top:1.8rem;
  max-width:700px;
  margin-inline:auto;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-02c10fe *//* =========================================================
   SEZIONE 8 · FAQ SERVICE – ACCORDION
   ========================================================= */
.faq-service{
  padding:3.5rem 1rem 3rem;
  background:var(--color-bg-alt);          /* grigio 100 */
  text-align:center;
}

.faq-service__title{
  font-family:"Montserrat",sans-serif;
  color:var(--color-primary);
  font-weight:700;
  font-size:clamp(1.7rem,2vw + 1rem,2.2rem);
  margin-bottom:2rem;
}

/* ---------- accordion wrapper ---------- */
.faq-service__accordion{
  max-width:800px;
  margin-inline:auto;
  text-align:left;
}

/* ---------- card ---------- */
.faq-service details{
  background:#fff;
  border:1px solid var(--gray-400);
  border-radius:8px;
  margin-bottom:1rem;
  padding:1rem 1.2rem;
  box-shadow:0 2px 6px rgba(0,0,0,.06);
  transition:box-shadow .25s;
}
.faq-service details[open]{box-shadow:0 4px 12px rgba(0,0,0,.09);}

.faq-service summary{
  cursor:pointer;
  list-style:none;
  font-weight:600;
  color:var(--color-primary);
  position:relative;
  padding-right:1.8rem;        /* spazio caret */
}
.faq-service summary::-webkit-details-marker{display:none;}

/* caret + / – */
.faq-service summary::after{
  content:"+";
  position:absolute;
  right:0; top:0;
  font-weight:700;
  color:var(--color-accent);
  transition:transform .25s;
}
.faq-service details[open] summary::after{
  content:"–";
  transform:rotate(180deg);
}

/* testo risposta */
.faq-service p{
  margin:1rem 0 0;
  font-size:.95rem;
  color:var(--gray-700);
  line-height:1.55;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-ad22e60 *//* =========================================================
   SEZIONE 9 · SERVICE – BANNER CONTATTO
   ========================================================= */
.service-banner{
  background:var(--color-primary);          /* blu brand */
  color:#fff;
  padding:3rem 1rem 3.2rem;
  display:flex;
  flex-wrap:wrap;
  gap:2rem;
  justify-content:center;
}

.service-copy{
  flex:0 0 380px;          /* colonna sinistra */
  max-width:420px;
}

.service-head{
  font-family:"Montserrat",sans-serif;
  font-size:clamp(1.9rem,2vw + 1rem,2.4rem);
  font-weight:800;
  text-transform:uppercase;
  margin:0 0 1rem;
}

.service-text{
  font-size:1.05rem;
  line-height:1.55;
  margin:0 0 1.3rem;
}

.service-bullets{
  list-style:disc inside;
  margin:0;
  padding-left:.5rem;
  font-size:.95rem;
}
.service-bullets li{margin:.25rem 0;}

@media(max-width:767px){
  .service-copy{flex:1 1 100%;}
}

/* ---------- FORM (classe extra "form-service") ---------- */
.form-service .elementor-field{
  border-radius:4px;
  border:1px solid var(--gray-400);
  padding:.75rem 1rem;
  font-size:.95rem;
}
.form-service .elementor-field:focus{
  border-color:var(--color-accent);
  box-shadow:0 0 0 2px rgba(227,28,36,.25);
}

.form-service .elementor-button{
  background:var(--color-accent);          /* rosso CTA */
  color:#fff;
  font-weight:600;
  border-radius:4px;
  padding:.9rem 2.4rem;
  width:100%;
  transition:background .2s;
}
.form-service .elementor-button:hover{
  background:var(--color-accent-d);
}/* End custom CSS */