/* ====== Hero Section ====== */
.hero-section {
  display: flex;
  justify-content: center;
  padding: 9.12rem 4.38rem 3.12rem; /* 120px = 7.5rem, 70px = 4.375rem */
  background: linear-gradient(86deg, #4D74FE 13.28%, #334DA9 55.88%, #253271 82.53%);
  overflow: hidden;
  box-sizing: border-box;
}

/* Wrapper interno centrato e limitato */
.hero-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 68.75rem; /* 1100px */
  gap: 0.625rem; /* 10px */
}

/* Titolo */
.tf-hero-secondary {
  color: #FFF !important;
  text-align: center;
  width: 100%;
}

/* Sottotitolo */
.tf-subtitle-regular {
  color: #FFF;
  text-align: center;
  width: 100%;
}

/* CTA */
.hero-cta {
  margin: 1.25rem 0; /* 20px */
}

/* Video placeholder */
.hero-video {
  display: flex;
  width: 100%;
  max-width: 39.625rem; /* 634px */
  aspect-ratio: 634 / 357;
  background: var(--Neutri-Grey-4);
  border-radius: 0.625rem; /* 10px */
  position: relative;
  justify-content: center;
  align-items: center;
}

/* Play icon */
.hero-video .play-icon {
  width: 2.25rem; /* 36px */
  height: 2.25rem;
  border: 1px solid var(--Blue-Blue-Strong);
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero-video .play-icon::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-left: 0.5rem solid var(--Blue-Blue-Strong); /* 8px */
  border-top: 0.3125rem solid transparent; /* 5px */
  border-bottom: 0.3125rem solid transparent;
  margin-left: 0.125rem; /* 2px */
}

/* ====== Testimonials ====== */
.testimonials {
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.25rem;
  width: 100%;
  max-width: 68.75rem; /* 1100px */
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.testimonial-card {
  display: flex;
  align-items: flex-start;
  width: 100%;
  max-width: 24.25rem; /* 388px */
  padding: 2.1875rem 2.8125rem; /* 35px 45px */
  gap: 1.25rem;
  border-radius: 1.25rem; /* 20px */
  border: 0.125rem solid var(--Neutri-White); /* 2px */
  background: transparent;
  box-sizing: border-box;
}

.testimonial-logo {
  width: 5.3125rem; /* 85px */
  height: 1rem; /* 16px */
}

.tf-body-small-regular {
  flex: 1;
  color: var(--Neutri-White);
  margin: 0;
}

/* ===== Responsive: max-width 1024px ===== */
@media (max-width: 1040px) {
  .hero-section {
padding: 7.5rem 1rem 4.375rem 1rem;
  }

  .hero-content {
    gap: 1.25rem; /* 20px */
  }

  .hero-video {
    max-width: 100%;
  }

  .testimonials {
    gap: 1.875rem;
    padding: 0;
  }

  .testimonial-card {
    flex: 1 1 calc(50% - 1.25rem);
    max-width: none;
  }
}

/* ===== Responsive: max-width 768px ===== */
@media (max-width: 768px) {
  .hero-section {
padding: 7.5rem 1rem 4.375rem 1rem;
  }

  .hero-content {
    gap: 0.62rem; /* 12px */
  }

  .hero-video {
    margin-top: 0.9375rem; /* 15px */
  }

  .testimonials {
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
    padding: 0;
  }

  .testimonial-card {
    width: 100%;
    max-width: 100%;
    text-align: left;
  }
    .testimonial-card:not(:first-of-type) {
    display: none;
  }
}
}

/* ===== Responsive: max-width 480px ===== */
@media (max-width: 480px) {
  .hero-section {
padding: 7.5rem 1rem 4.375rem 1rem;
  }

  .hero-content {
    gap: 0.625rem;
  }

  .hero-video {
    margin-top: 0.75rem; /* 12px */
  }

  .testimonials {
    gap: 1.25rem;
    margin-top: 1.25rem;
    padding: 0;
  }

  .testimonial-card {
    padding: 2.81rem;
  }
}


.trusted-section {
  display: flex;
  justify-content: center;
  padding: 1.875rem 0;                             /* 30px 0 */
  background-color: var(--Blue-Blue-Extra-Dark);   /* #253271 */
}

/* Wrapper interno limitato */
.trusted-content {
  width: 100%;
  max-width: 110rem;                               /* 1440px */
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* === Titolo === */
.trusted-header {
  width: 100%;
  padding-bottom: 1.875rem;                       /* 30px */
  display: flex;
  justify-content: center;
}

.tf-body-small-uppercase {
  margin: 0;
  text-align: center;
}

.tf-body-small-uppercase-white {
  color: #FFF;
}

/* === Slider “marquee” === */
.trusted-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 0 3.125rem;                            /* 50px interno */
}
.slider-track {
  display: flex;
  width: calc(2 * (7 * 6.42088rem + 6 * 3.125rem)); /* 7 loghi e 6 gap per set, duplica */
  animation: scroll 70s linear infinite;
}
@keyframes scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Ogni slide */
.trusted-slide {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 3.125rem;                        /* gap */
}

.repubblica img {
width: 7.91013rem;
height: 1.6875rem;
}

.sole24ore img {
width: 7.48825rem;
height: 1.6875rem;
}

.corriere img {
width: 7.66306rem;
height: 2.5rem;
}

.startupitalia img {
width: 9.675rem;
height: 1.6875rem;
}

.techedu img {
width: 3.33331rem;
height: 2.5rem;
}

.trusted-slide:last-child {
  margin-right: 0;
}
.trusted-slide img {
  object-fit: contain;
}

/* Facoltativo: nascondi scrollbar WebKit */
.trusted-slider::-webkit-scrollbar {
  display: none;
}

/* === Responsive === */
@media (max-width: 64rem) {                       /* ≤1024px */
  .slider-track {
    animation-duration: 25s;
  }
  .trusted-slide {
    margin-right: 2rem;                           /* 32px */
  }
}

@media (max-width: 30rem) {                       /* ≤480px */
  .slider-track {
    animation-duration: 30s;
  }
  .trusted-slide {
    margin-right: 1rem;                           /* 16px */
  }
}


/* timeflow-reasons.css */

/* Sezione generale */
.reasons-section {
  display: flex;
  padding: 9.375rem 0 4.6875rem 0;
  justify-content: center;
  background: #fff;
}

/* Wrapper centrato fino a 1440px */
.reasons-content {
  width: 100%;
    max-width: 75rem;                    /* 1440px */
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Header */
.reasons-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 5rem;            /* 50px */
  gap: 0.625rem;                        /* 10px tra title e subtitle */
  width: 100%;
}
.tf-title-page-secondary {
  text-align: center;
  max-width: 75rem;
}

.tf-title-page-secondary-white {
  color: #FFF;
}

.reasons-subtitle {
  margin: 0;
}

/* Cards wrapper */
.reasons-cards {
  display: flex;
  gap: 2.5rem;                         /* 40px tra le card */
  width: 100%;
  justify-content: space-between;
}

/* Singola card */
.reason-card {
  display: flex;
  gap: 1.25rem;                        /* 20px tra icona e testo */
  flex: 1 1 0;
  align-items: flex-start;
}

/* Icona */
.reason-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reason-icon img {
  display: block;
  width: 1.875rem;                     /* 30px */
  height: auto;
}

/* Testo interno */
.reason-text {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;                       /* 10px tra titolo e descrizione */
  flex: 1 1 0;
}

/* Titolo card */
.reason-title {
  line-height: 1.4rem;
  margin: 0;
}

/* Descrizione card */
.reason-description {
  margin: 0;
}

/* Responsive adjustments – side padding, text scaling, cards stacked */

/* Tablet & small desktop: ≤1024px (64rem) */
@media (max-width: 64rem) {
  .reasons-section {
    /* meno padding laterale e verticale */
padding: 6.25rem 1rem 1.875rem 1rem;
  }
  .reasons-content {
    max-width: 90rem;         /* rimane 1440px ma con padding più stretto */
  }
  .reasons-header {
    padding-bottom: 3.13rem;     /* 32px */
  }
  .reasons-cards {
    flex-direction: column;   /* tutte le card in colonna */
    gap: 1.25rem;                /* 32px tra le card */
    align-items: stretch;
  }
  .reason-card {
    flex: none;
    width: 100%;
    max-width: none;
    margin-bottom: 1.25rem;
  }
}

/* Smartphone: ≤480px (30rem) */
@media (max-width: 30rem) {
  .reasons-section {
padding: 6.25rem 1rem 1.875rem 1rem;
  }
  .reasons-header {
    padding-bottom: 3.13rem;   /* 24px */
  }
  .reason-icon img {
    width: 1.75rem;           /* 28px icona leggermente più piccola */
  }
}

.benefits-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4.6875rem 0 3.125rem;
  background: #FFF;
}

.benefits-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.625rem;
  padding-bottom: 5rem;
  align-self: stretch;
}

.benefit-block {
  display: flex;
  width: 62.5rem;
  gap: 1.875rem;
  align-items: center;
  margin-bottom: 6.25rem; /* Spazio tra i blocchi */
}


.benefit-image {
  width: 590px;
  height: 450px;
  border-radius: 0.625rem;
  flex-shrink: 0;
}

.benefit-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.88rem;
  flex: 1;
  color: #253271;
}

.benefit-text {
  margin: 0;
}


@media (max-width: 1060px) {
  .benefit-block {
    flex-direction: column;
    width: 100%;
    padding: 0 1.88rem;
    gap: 1.88rem;
    margin-bottom: 3.13rem;
    box-sizing: border-box;
  }
 

  .benefit-block.reverse {
    flex-direction: column-reverse;
  }

  .benefit-block .benefit-image {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
  }

  .benefit-text {
    width: 100%;
    gap: 1.25rem;
  }
}

@media (max-width: 600px) {
  .benefits-section {
padding: 3.125rem 1rem 0;
  }

.benefit-link {
margin-top: 0.62rem;
  }

  .benefits-heading {
    padding-bottom: 3.13rem;
  }

  .benefit-block {
    gap: 1.88rem;
    padding: 0;
  }
}


.kpi-section {
  width: 100%;
  background: #DEF7E8;
  padding: 6.25rem clamp(1.5rem, 5vw, 7.5rem) 5.77rem;
  box-sizing: border-box;
}

.kpi-container {
  max-width: 75rem; /* 1200px */
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.25rem;
  padding: 0;
  box-sizing: border-box;
}

.kpi-card {
  flex: 1 1 calc(25% - 1.25rem); /* 4 per riga */
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  min-width: 260px;
  box-sizing: border-box;
    align-items: flex-start; 
}

.kpi-logo {
  height: 24px;
  object-fit: contain;
}

.kpi-value {
  color: var(--Blue-Blue-Strong);
  margin: 0;
  text-align: left;
}

.kpi-label {
  color: var(--Blue-Blue-Strong);
  text-align: left;
  margin-top: -1.25rem;
}

.kpi-description {
  color: var(--Blue-Blue-Extra-Dark);
  margin: 0;
}

/* Fino a 1200px → 2 colonne */
@media (max-width: 1200px) {
  .kpi-card {
    flex: 1 1 calc(50% - 1.25rem);
  }
}

/* Fino a 768px → 1 colonna */
@media (max-width: 768px) {
  .kpi-container {
    gap: 3.13rem;
  }
  
  .kpi-card {
    flex: 1 1 100%;
  }

  .kpi-section {
padding: 6.25rem 1rem;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .kpi-section {
padding: 6.25rem 1rem;
  }
}



.industries-section {
  padding: 9.375rem clamp(1.5rem, 6vw, 7.5rem); /* da 1.5rem mobile a 7.5rem desktop */
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  max-width: 86rem;
  margin: 0 auto;
  box-sizing: border-box;
}

.industries-header {
  text-align: center;
}

.industries-title {
  margin: 0 0 0.625rem;
}

.industries-subtitle {
  color: #253271;
  margin: 0;
}

.industries-cards-row,
.industries-bottom-row {
  display: flex;
  gap: 1.25rem;
  width: 100%;
}

/* Card comune */
.industries-card {
  flex: 1;
  padding: 2.8125rem;
  border-radius: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-sizing: border-box;
}

.industries-card-inner {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
}

.industries-icon {
  width: 1.875rem;
  height: 1.875rem;
  object-fit: contain;
}


.industrie-sub-title {
  margin-bottom: 4.375rem !important;
}

@media (max-width: 768px) {
  .industrie-sub-title {
    margin-bottom: 3.13rem !important;
  }
}

.industries-card-text {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.industries-card-title {
  margin: 0;
}

.industries-card-description {
  margin: 0;
}

.industries-card-link {
  margin-top: 1.25rem;
}

/* Proporzioni 40/60 */
.industries-construction-card {
  flex: 0 0 40%;
}

.industries-cta-large {
  flex: 0 0 60%;
}

/* CTA finale */
.industries-cta-banner {
  width: 100%;
  border-radius: 1.25rem;
  background: linear-gradient(87deg, #4D74FE 44.65%, #334DA9 74.43%, #253271 92.72%);
  padding: 2.8125rem;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--Neutri-White);
  font-family: "Mulish", sans-serif;
}

.industries-cta-inner-wrapper {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  gap: 2rem;
}

.industries-cta-content-block {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  flex: 1;
}

.industries-cta-heading {
  text-align: left;
  color: var(--Neutri-White);
  margin: 0;
}

.industries-cta-subheading {
  margin: 0;
  color: var(--Neutri-White);
}

.industries-cta-button-container {
  display: flex;
  justify-content: flex-end;
  padding-top: 1rem;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 960px) {
  .industries-section {
padding: 3.125rem 1rem 6.25rem 1rem;
    gap: 2rem;
  }

  .industries-cards-row,
  .industries-bottom-row {
    flex-direction: column;
    gap: 1.25rem;
  }

  .industries-cards-row {
    margin-top: -2rem;
  }

  .industries-construction-card,
  .industries-cta-large {
    flex: 1 1 100%;
  }

  .industries-cta-inner-wrapper {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .industries-cta-heading,
  .industries-cta-subheading {
    text-align: center;
  }
  

  .industries-cta-button-container {
    justify-content: center;
    padding-top: 0.62rem;
  }
}

@media (max-width: 480px) {
  .industries-section {
padding: 3.125rem 1rem 6.25rem 1rem;
  }

  .industries-card {
    padding: 2rem;
  }

  .industries-cta-banner {
    padding: 2.81rem;
  }

  .industries-cta-button-container {
    padding-top: 0.62rem;
  }
}

/* ===== Pricing Section ===== */
.pricing-section {
  width: 100%;
  background: linear-gradient(33deg, #4D74FE 28.82%, #334DA9 67.83%, #253271 91.89%);
  padding: 9.375rem 0;
  display: flex;
  justify-content: center;
  box-sizing: border-box;
}

/* ===== Container ===== */
.pricing-container {
  width: 100%;
  max-width: 90rem;
  padding: 0 3rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.88rem;
  box-sizing: border-box;
}

/* ===== Heading ===== */
.pricing-heading {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pricing-title,
.pricing-subtitle {
  margin: 0;
}

/* ===== Tabs Selector ===== */
.tabs-wrapper {
  display: flex;
  justify-content: center;
  overflow-x: hidden;
  padding: 0 2rem;
  max-width: 40rem;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  background: transparent;
}

.top-bar-tabs {
  display: inline-flex;
  gap: 6px;
  padding: 10px 20px;
  background-color: #F5F8FF;
  border-radius: 100px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  white-space: nowrap;
  margin-top: 1.87rem;
}

.tab {
  padding: 10px 22px;
  border-radius: 100px;
  background: transparent;
  cursor: pointer;
  transition: background-color 0.2s, color 0.2s;
  flex-shrink: 0;
  white-space: nowrap;
}

.tab-active,
.tab:hover,
.tab-active:hover {
  background-color: #4D74FE;
  color: #fff;
}

/* ===== Pricing Card (Tab Content) ===== */
.wm-container {
  max-width: 62.5rem;
  margin: 0 auto;
  padding: 4.375rem;
  background: #F5F8FF;
  border-radius: 1.25rem;
  box-sizing: border-box;
}

.wm-header {
  display: flex;
  flex-wrap: wrap;
  gap: 4.375rem;
  margin-bottom: 4.38rem;
}

.wm-title-block {
  max-width: 18.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.62rem;
}

.wm-title-block .btn {
  width: fit-content;
  align-self: flex-start; /* opzionale ma spesso necessario */
}

.wm-title-block h2 {
  color: #4D74FE;
  margin: 0;
}

.wm-title-block p {
  color: var(--Blue-Blue-Extra-Dark);
  margin: 0;
}

.wm-price  {
  margin-top: 1.88rem;
  margin-bottom: 0.63rem;
}

.wm-price-amount {
margin-top: 0.62rem;
color: var(--Blue-Blue-Strong, #4D74FE);
}

.wm-mese {
color: var(--Blue-Blue-Extra-Dark, #253271);
}

.wm-price-sub {
color: var(--Blue-Blue-Extra-Dark, #253271); 
}

.wm-cta {
  background: #4D74FE;
  color: #fff;
  border: 0;
  padding: 10px 20px;
  border-radius: 100px;
  font: 800 14px 'Mulish', sans-serif;
  cursor: pointer;
}

/* ===== Accordion ===== */
.box-accordion {
  flex: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
  color: #253271;
}

.accordion-item {
  width: 100%;
  display: flex;
  align-items: center;
  padding: 16px 0;
  border-bottom: 2px solid #253271;
}

.accordion-title {
  display: flex;
  justify-content: space-between;
  width: 100%;
  gap: 8px;
}

.icon-title {
  display: flex;
  gap: 10px;
  flex: 1;
}

.icon-left,
.chevron-down {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.chevron-down {
  display: flex;
  align-items: center;
  justify-content: center;
}

.chevron-down .icon {
  width: 80%;
  height: auto;
}

/* ===== Features ===== */
.wm-features {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 40px;
  width: 100%;
  box-sizing: border-box;
}

.feature-box {
  flex: 0 0 calc((100% - 80px) / 3);
  max-width: calc((100% - 80px) / 3);
  display: flex;
  gap: 20px;
  align-items: flex-start;
  box-sizing: border-box;
}

.feature-box h3 {
  color: #253271;
}

.feature-box p {
  color: #253271;
}

.feature-box img {
  width: 30px;
  height: auto;
  flex-shrink: 0;
}

/* ===== Tab Content Toggle ===== */
.tab-content {
  display: none;
}

.tab-content.tab-content-active {
  display: block;
}

/* ===== Responsive Breakpoints ===== */
@media (max-width: 900px) {
  /* Sezione e padding */
  .pricing-section {
padding: 6.25rem 1rem;
  }

  /* Tabs scrollabili */
  .tabs-wrapper {
    overflow-x: auto;
    justify-content: flex-start;
    scroll-behavior: smooth;
    background: #F5F8FF;
    border-radius: 1050px;
    padding: 0 0.5rem;
    max-width: 100%;
  }
  .tabs-wrapper::-webkit-scrollbar { display: none; }
  .top-bar-tabs {
    width: max-content;
    padding: 10px 3px;
    background: none;
    margin-top: 0;
  }

  /* Pricing card full‑width */
  .wm-container {
    width: 100%;
    max-width: none;
padding: 3.125rem 2.8125rem;
    border-radius: 1.25rem;
  }

  /* 🔄 Feature boxes: 1 colonna */
  .feature-box {
    flex: 0 0 100%;
    max-width: 100%;
  }

  /* Header ridotto */
  .wm-header { gap: 30px; margin-bottom: 30px;
}

/* Extra riduzione testo su schermi molto stretti */
@media (max-width:720px) {
  .pricing-container { padding: 0; }
}
  
.wm-features {
  margin-top: 3.12rem;
  gap: 1.25rem;
  }

.pricing-heading  {
  margin-bottom: 1.25rem;
  }

 .wm-price-amount  {
  margin-top: 0;
  }
  
.wm-price  {
  margin-top: 1.25rem;
}
  
 } 
.authority-section {
  width: 100%;
  background: #E5EEF9;
  padding: 6.25rem 7.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.125rem;
}

.authority-content {
  max-width: 75rem;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.87rem;
  text-align: center;
}

.authority-logos {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  align-items: center;
  width: 100%;
}

   .auth-sub {
margin-top: -1.25rem;
  } 

@media (max-width: 900px) {
  .auth-sub {
margin-top: -0.62rem;
  } 
  } 

.logo-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
  flex-wrap: wrap;
  padding: 0 3.125rem;
}

.logo-row img {
  max-height: 5rem;
  height: auto;
  max-width: 100%;
}

.trustpilot-row {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.trustpilot-stars {
  height: 2rem;
}

.trustpilot-logo {
  height: 2rem;
}

@media (max-width: 768px) {
  .authority-section {
padding: 6.25rem 1rem;
  }

  .authority-content {
    gap: 1.25rem;
  }
  
.authority-subtitle {
 margin-bottom: 0.63rem;
  }
  
  .logo-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    justify-items: center;
    padding: 0 1rem;
  }

  .logo-row img {
    max-width: 100%;
    max-height: 4rem;
    height: auto;
  }

  .trustpilot-stars,
  .trustpilot-logo {
    height: 1.5rem;
  }
}

.case-study-section {
  width: 100%;
  background: #fff; /* oppure #DEF7E8 */
  padding: 9.375rem 7.5rem; /* 150px vertical, 24px horizontal */
  display: flex;
  justify-content: center;
  box-sizing: border-box;
}

.case-study-container {
  width: 100%;
  max-width: 75rem; /* 1200px */
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  border-radius: 1.25rem;
  overflow: hidden;
  background: var(--Green-Green-Light, #DEF7E8);
}

/* Contenitore immagine */
.case-study-image {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.case-study-image img {
  width: 36.875rem;       /* 590px */
  max-height: 36.25rem;   /* 580px */
  height: auto;
  object-fit: cover;
  border-radius: 1.25rem 0 0 1.25rem;
}

/* Testo */
.case-study-text-box {
  flex: 1;
  background: #DEF7E8;
  padding: 4.375rem;
  display: flex;
  align-items: center;
  border-radius: 0 1.25rem 1.25rem 0;
  box-sizing: border-box;
}

.case-study-content {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 32rem;
}

.case-study-logo {
  height: 1.875rem;
  object-fit: contain;
}

.case-study-number h3,
.case-study-description p,
.case-study-name {
  margin: 0;
  text-align: left;
}

.case-study-number h3 {
  color: var(--Blue-Blue-Strong) !important;
}

.case-study-subtitle {
  color: var(--Blue-Blue-Strong);
}

.case-study-description p {
  color: var(--Blue-Blue-Extra-Dark);
}

/* ====== Responsive ====== */

/* Tablet (≤1024px) */
@media (max-width: 1210px) {
  .case-study-section {
    padding: 5rem 2rem; /* 80px vertical, 32px horizontal */
  }

  .case-study-container {
    flex-direction: column;
    border-radius: 1.25rem;
  }

  .case-study-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    border-radius: 1.25rem 1.25rem 0 0;
  }

  .case-study-text-box {
    border-radius: 0 0 1.25rem 1.25rem;
    padding: 3rem 2rem;
    justify-content: center;
  }

  .case-study-content {
    max-width: 100%;
  }
}

/* Smartphone (≤480px) */
@media (max-width: 480px) {
  .case-study-section {
padding: 3.125rem 1rem;
  }
.case-study-content {
  gap: 1.25rem;
  }
  
  .case-study-text-box {
  padding: 4.375rem 2.8125rem;
  }

  .case-study-image img {
    aspect-ratio: 3 / 2;
  }

  .case-study-logo {
    height: 1.5rem;
  }
}


.slider-container {
  overflow: hidden;
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 0 1.5rem 6.25rem;
  box-sizing: border-box;
}

.slider-track {
  display: flex;
  gap: 4.38rem;
  /* Durata aumentata per un'animazione più gradevole con il doppio delle card */
  animation: scroll 40s linear infinite;
  box-sizing: border-box;
}

/* Regola di pausa: L'animazione si ferma solo quando JavaScript aggiunge la classe .paused */
.slider-container.paused .slider-track {
  animation-play-state: paused;
}

.review-card {
  flex: 0 0 auto;
  width: 24.25rem;
  padding: 2.2rem 2.8rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.25rem;
  border-radius: 1.25rem;
  border: 2px solid #253271;
  background: white;
  box-sizing: border-box;
}

.avatar {
  width: 58.27px;
  height: 58.27px;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.review-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.62rem;
  width: 100%;
  box-sizing: border-box;
}

.text {
  color: var(--Blue-Blue-Extra-Dark);
  font-size: 1rem;
  text-align: left;
}

.author {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
}

.name {
  color: var(--Blue-Blue-Strong);
}

.title {
  color: var(--Blue-Blue-Strong);
}

/* Animazione di scorrimento per il loop infinito */
@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* ========== RESPONSIVE ========== */

/* Tablet (≤768px) */
@media (max-width: 768px) {
  .slider-container {
    padding-bottom: 6.25rem;
  }
  .slider-track {
    gap: 4.38rem;
  }
  .review-card {
    width: 22.5625rem;
  }
  .text {
    font-size: 0.9375rem;
  }
}

/* Smartphone (≤480px) */
@media (max-width: 480px) {
  .slider-container {
    padding-bottom: 6.25rem;
  }
  .slider-track {
    gap: 4.35rem;
  }
  .review-card {
    padding: 2.1875rem 2.8125rem;
    gap: 1.25rem;
  }
  .text {
    font-size: 0.875rem;
  }
  .name {
    font-size: 1rem;
  }
  .title {
    font-size: 0.8125rem;
  }
}

/* ===== CTA Final Banner ===== */
.cta-final-banner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 9.37rem 3rem 3rem; /* padding laterale per layout responsive */
  box-sizing: border-box;
  width: 100%;
}

/* ===== Responsive: mobile < 768px ===== */
@media (max-width: 768px) {
  .cta-final-banner {
    flex-direction: column;
padding: 3.125rem 1rem;
    text-align: center;
  }
}

@media (max-width: 480px) {
    .cta-final-banner {
        flex-direction: column;
padding: 3.125rem 1rem;
        text-align: center;
    }
}

.cta-inline-banner {
  width: 100%;
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0 2rem 6.25rem 2rem;
  box-sizing: border-box;
}

.cta-inline-content {
  display: flex;
  width: 100%;
  max-width: 62.25rem; /* 996px */
  padding: 3.125rem; /* 50px */
  justify-content: space-between;
  align-items: center;
  border-radius: 1.25rem;
  background: linear-gradient(87deg, #4D74FE 44.65%, #334DA9 74.43%, #253271 92.72%);
  gap: 1.87rem;
  box-sizing: border-box;
}

.cta-inline-text {
  color: var(--Neutri-White);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  flex: 1;
}

.cta-inline-text h2 {
  margin: 0;
  text-align: left;
  color: var(--Neutri-White);
}

.cta-inline-text p {
  margin: 0;
  color: var(--Neutri-White);
  max-width: 40rem;
  text-align: left;
}

.cta-button {
  flex-shrink: 0;
}

/* ===========================
   BREAKPOINT TABLET ≤1060px
=========================== */
@media (max-width: 1060px) {
  .cta-inline-banner {
    padding: 0 1.5rem 3rem;
  }

  .cta-inline-content {
    flex-direction: column;
    text-align: center;
    align-items: center;
    gap: 2rem;
  }

  .cta-inline-text h2,
  .cta-inline-text p {
    text-align: center;
  }

  .cta-button {
    align-self: center;
  }
}

/* ===========================
   BREAKPOINT MOBILE ≤768px
=========================== */
@media (max-width: 768px) {
  .cta-inline-content {
    padding: 2.81rem;
        gap: 1.25rem;
  }

  .cta-inline-banner {
    padding: 0 0 3.13rem;
  }
  .cta-inline-text h2,
  .cta-inline-text p {
    text-align: center;
  }

  .cta-button {
    width: 100%;
    justify-content: center;
    display: flex;
  }
   }