/* Respiro vertical da seção conforme frame desktop I938:5271;938:5081. */
.opinion-section {
  padding: 122px 0 136px;
}

/* Shell centralizado: coluna única com todos os elementos centrados. */
.opinion-shell {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
}

/* Título gradiente centralizado. */
.opinion-title {
  width: min(100%, 662px);
  margin: 0;
  background: linear-gradient(171deg, #57d4ff 0%, #845cff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-family: "Muring Display", system-ui, sans-serif;
  font-size: 38px;
  font-weight: 700;
  line-height: 1.356;
  letter-spacing: 0.76px;
  text-align: center;
}

/* Parágrafo introdutório centralizado. */
.opinion-intro {
  width: min(100%, 758px);
  margin: 0;
  color: #64748b;
  font-family: "Muring Text", system-ui, sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.47;
  text-align: center;
}

/* Coluna de cards: largura que acomoda o conteúdo interno (822px + 30px padding × 2). */
.opinion-cards {
  width: min(100%, 882px);
  display: flex;
  flex-direction: column;
  gap: 13px;
}

/* Card individual: fundo branco com cantos generosos. */
.opinion-card {
  width: 100%;
  background: #ffffff;
  border-radius: 30px;
  padding: 30px;
  display: flex;
  flex-direction: column;
  gap: 25px;
}

/* Título do card em gradiente. */
.opinion-card__title {
  margin: 0;
  background: linear-gradient(173deg, #57d4ff 0%, #845cff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-family: "Muring Display", system-ui, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.47;
}

/* Corpo descritivo do card. */
.opinion-card__body {
  margin: 0;
  color: #64748b;
  font-family: "Muring Text", system-ui, sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.47;
}

/* CTA centralizado na seção. */
.opinion-cta {
  margin: 0 auto;
}

/* ---- Tablet: ajuste de fonte e espaçamentos. ---- */
@media (max-width: 1180px) {
  .opinion-section {
    padding: 96px 0 108px;
  }

  .opinion-shell {
    width: min(720px, calc(100% - 48px));
    gap: 24px;
  }

  .opinion-title {
    font-size: 42px;
    letter-spacing: 0.84px;
  }

  .opinion-intro,
  .opinion-card__body {
    font-size: 18px;
  }

  .opinion-cards {
    width: 100%;
  }
}

/* ---- Mobile: baseado no node 951:6779. ---- */
@media (max-width: 480px) {
  .opinion-section {
    padding: 86px 0 104px;
  }

  .opinion-shell {
    width: min(335px, calc(100% - 40px));
    gap: 25px;
  }

  .opinion-title {
    width: 299px;
    font-size: 28px;
    letter-spacing: 0.56px;
  }

  .opinion-intro {
    width: 335px;
    font-size: 16px;
    font-weight: 500;
  }

  .opinion-cards {
    width: 335px;
    gap: 13px;
  }

  .opinion-card {
    border-radius: 30px;
    padding: 30px;
    gap: 25px;
  }

  .opinion-card__title {
    font-size: 16px;
  }

  .opinion-card__body {
    width: 272px;
    font-size: 16px;
    font-weight: 500;
  }

  .opinion-cta {
    width: 272.308px;
  }
}
