:root{
  --green-900:#0a6050;
  --green-700:#3b9167;
  --green-950:#0f3939;
  --ink:#3b524c;
  --muted:#4a6a62;
  --neutral:#cbe2e0;
  --bg:#f7fbfa;
  --white:#fff;
  --cta:#ff8400;
  --shadow:0 12px 30px rgba(16,54,46,.08);
  --radius:16px;
  --radius-lg:22px;
  --space:clamp(16px,2.5vw,28px);
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  scroll-padding-top:70px;
}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#ffffff,var(--bg));
}
img{max-width:100%;display:block}
img.social-icon{max-width:none;}
a{color:inherit;text-decoration:none}
.container{width:min(1160px,92%);margin:0 auto}
.grid{display:grid;gap:clamp(14px,2vw,22px)}

.btn{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:1rem 1.25rem;
  border-radius:14px;
  border:2px solid transparent;
  font-weight:700;
  cursor:pointer;
  transition:.2s transform,.25s box-shadow,.25s background-color,.25s color,.25s border-color;
}
.btn:focus-visible{outline:3px solid #0002}
.btn--cta{
  background:var(--cta);
  color:#1b1204;
  box-shadow:0 10px 20px rgba(255,132,0,.25);
}
.btn--cta:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 26px rgba(255,132,0,.33);
}
.btn--ghost{
  background:transparent;
  border-color:var(--green-900);
  color:var(--green-900);
}
/* DESTAQUE MAIS FORTE NO HOVER DOS BOTÕES GHOST
    (Conheça nossas soluções, Ver detalhes..., Ler no LinkedIn, Saiba mais...) */
.btn--ghost:hover{
  background:var(--green-900);
  color:#ffffff;
  box-shadow:0 12px 26px rgba(10,96,80,.32);
  transform:translateY(-2px);
  border-color:var(--green-900);
}

/* CTA Ghost Invertido – exclusivo para diagnóstico */
.btn--ghost-invert{
  background: var(--green-900);
  border: 1px solid var(--green-900);
  color: #ffffff;

  box-shadow: none;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, transform .2s ease;
}

/* Hover invertido: branco com borda verde */
.btn--ghost-invert:hover{
  background: #ffffff;
  color: var(--green-900);
  border-color: var(--green-900);

  box-shadow: 0 12px 26px rgba(10,96,80,.22);
  transform: translateY(-2px);
}

/* Botão padrão WhatsApp ("Chame no WhatsApp") */
.btn--whats{
  background:#25d366;
  color:#05210f;
  box-shadow:0 10px 22px rgba(37,211,102,.35);
  border-radius:999px;
  padding:.9rem 1.2rem;
}
.btn--whats:hover{
  background:#1ebe5c;
  box-shadow:0 14px 30px rgba(37,211,102,.45);
  transform:translateY(-2px);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  background:var(--neutral);
  color:var(--green-900);
  padding:.45rem .9rem;
  border-radius:999px;
  font-weight:700;
  font-size:.85rem;
}
.section{padding:calc(var(--space)*2) 0}
.section--tight{padding:calc(var(--space)*1.5) 0}
/* Sessões com conteúdo dentro de um "cartão" */
.section-surface .container{
  background:#ffffff;
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:clamp(24px,3vw,40px);
}

/* Dá um respiro extra em cima e embaixo da sessão */
.section-surface{
  padding:calc(var(--space)*2.2) 0;
}

.section-soft::before,
.section-soft::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:32px;             /* altura da faixa de transição */
  pointer-events:none;
  z-index:-1;              /* fica atrás do conteúdo, mas acima do body */
}

/* Degradê da sessão anterior para esta */
.section-soft::before{
  top:-32px;
  background:linear-gradient(to bottom, transparent, #f7faf9);
}

/* Degradê desta sessão para a próxima */
.section-soft::after{
  bottom:-32px;
  background:linear-gradient(to top, transparent, #f7faf9);
}
/* Fundo levemente mais claro (ideal para sessão de conteúdos na home) */
.section--light {
  background:#f5faf8;
}
.card{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:clamp(16px,2.2vw,22px);
}
.muted{color:var(--muted)}
.kicker{
  color:var(--green-700);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
  font-size:.85rem;
}

/* Header */
.nav{
  position:sticky;
  top:0;
  z-index:60;
  background:#ffffff;
  border-bottom:1px solid #e7efec;
}
.nav__bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:.8rem 0;
}

.nav__left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* Ações do header nas landings: redes + home + CTA + menu sempre em linha */
.nav--landing .nav__actions{
  display:flex;
  align-items:center;
  gap:0.75rem;
  margin-left:auto;
}

.brand{
  display:flex;
  align-items:center;
  gap:.7rem;
  font-weight:900;
  color:var(--green-900);
}
.brand__img{
  width:auto;
  max-height:64px
}

.nav__links{
  display:flex;
  align-items:center;
  gap:1rem;
}
.nav__links a{
  padding:0.35rem 0;
  font-size:0.95rem;
  line-height:1.2;
  border-radius:10px;
}
.nav__links a:hover{background:#0a60500d}

.nav__toggle{display:none}

/* Social icons – proporção correta + cores originais */
.social-icon{
  height:22px;
  width:auto;
  aspect-ratio:1 / 1;
  display:block;
  opacity:.9;
  transition:.25s ease;
}
.social-icon--lg{
  height:28px;
  width:auto;
  aspect-ratio:1 / 1;
}
/* Efeito de "subir" nos ícones de redes sociais (header e footer) + ícone Home */
.nav__links .social-icon:hover,
.footer__social .social-icon:hover,
.nav__actions .social-icon:hover,
.nav__home-icon img:hover {
  opacity: 1;
  transform: translateY(-3px);
}


/* Hero */
.hero{
  padding:clamp(38px,7vw,88px) 0;
  position:relative;
  overflow:hidden;
  background:radial-gradient(circle at top left,#e3f4ef,#ffffff 50%), radial-gradient(circle at 120% 120%,#cbe2e0,#ffffff 40%);
}
.hero__wrap{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:center;
}
.hero h1{
  font-size:clamp(28px,3.6vw,46px);
  line-height:1.08;
  margin:.4rem 0;
  color:var(--green-950);
}
.hero p{font-size:clamp(16px,1.25vw,18px)}
.hero__art{position:relative}
.hero__panel{
  background:var(--white);
  border:1px solid #e7efec;
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow);
  animation:float 7s ease-in-out infinite;
  will-change:transform;
}
.tick{
  display:flex;
  align-items:flex-start;
  gap:.6rem;
  padding:.55rem .6rem;
  border-radius:12px;
  background:#f1f8f6;
  border:1px solid #e3eeec;
}
.tick + .tick{margin-top:10px}
.tick i{
  width:22px;
  height:22px;
  display:inline-grid;
  place-items:center;
  border-radius:50%;
  background:var(--green-700);
  color:#fff;
  font-style:normal;
  font-size:.9rem;
}
.hero__buttons{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:10px;
}
/* Desktop: esconde CTA da hero, deixa só “Conheça nossas soluções” */
.hero__buttons .btn--cta{
  display:none;
}

/* Soluções */
.solutions__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:20px;
}
.solutions__card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.solutions__card h3{margin:.2rem 0 .5rem}
.solutions__card p{margin:0}
.solutions__actions{margin-top:12px}
.solutions__actions .btn{
  width:100%;
  justify-content:center;
  text-align:center;
  white-space:normal;
}

/* Método */
.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.step{
  background:var(--white);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:18px;
  position:relative;
}
.badge{
  position:absolute;
  top:-12px;
  left:18px;
  background:var(--green-900);
  color:#fff;
  border-radius:12px;
  padding:.25rem .55rem;
  font-size:.85rem;
  font-weight:800;
}

/* Resultados – marquee */
.logo-marquee{
  margin-top:10px;
  overflow:hidden;
  position:relative;
  padding:10px 0;
  border-radius:0;              /* 1. tira o “oblongo” */
  border:none;
  background:transparent;
}
/* 2. Fade nas laterais */
.logo-marquee::before,
.logo-marquee::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:64px;                   /* largura da faixa de fade */
  pointer-events:none;
  z-index:2;
}
.logo-marquee::before{
  left:0;
  background:linear-gradient(to right, var(--bg) 0%, transparent 100%);
}
.logo-marquee::after{
  right:0;
  background:linear-gradient(to left, var(--bg) 0%, transparent 100%);
}
.logos-marquee__item{
  flex:0 0 auto;
  width:180px;
  height:70px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.logos-marquee__item img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  filter:none;
  opacity:1;
  transform:translateY(0);
  transition:transform .25s ease, opacity .25s ease, filter .25s ease;
}
/* efeito leve no hover */
.logos-marquee__item:hover img{
  transform:translateY(-2px);
}
.logo-marquee__track{
  display:inline-flex;
  align-items:center;
  gap:40px;                     /* 3. dobro (mais espaço entre logos) */
  white-space:nowrap;
  animation:logo-scroll 40s linear infinite; /* 4. mais lento ~70% da velocidade (antes era 28s) */
  padding-inline:40px;
  will-change:transform;
}

.logo-marquee:hover .logo-marquee__track{
  animation-play-state:paused;
}
@media (max-width:768px){
  .logos-marquee__item{
    width:150px;
    height:60px;
  }
}

/* Footer */
footer{
  background:#0a6050;
  border-top:1px solid #064136;
  color:#f5fbf8;
}
footer .muted{
  color:#cde9e1;
}
footer a{
  color:#f5fbf8;
  transition:.2s color,.2s opacity,.2s text-decoration;
}
/* HOVER MAIS MARCADO NO RODAPÉ */
footer a:hover{
  opacity:1;
  color:#ffffff;
  text-decoration:underline;
}
.footer__social{
  display:flex;
  gap:12px;
  margin-top:6px;
}

.reveal{opacity:0;transform:translateY(14px);transition:.6s ease}
.reveal.is-visible{opacity:1;transform:none}
.divider{
  height:1px;
  background:linear-gradient(90deg,transparent,#cee4df,transparent);
  margin:var(--space) 0;
}

/* Floats */
.float-whats{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
}
.float-whats a{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  /* resto de aparência vem de .btn--whats */
  position:relative;
  overflow:hidden;
}
.float-whats a::after{
  content:"";
  position:absolute;
  inset:-30%;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.45);
  opacity:0;
  animation:whats-pulse 2.6s ease-out infinite;
  pointer-events:none;
}
.to-top{
  position:fixed;
  right:18px;
  bottom:80px;
  background:#ffffffcc;
  border:1px solid #dfe9e6;
  color:var(--green-900);
  padding:.6rem .7rem;
  border-radius:12px;
  box-shadow:var(--shadow);
  display:none;
}
.to-top.is-show{display:inline-flex}

@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
@keyframes whats-pulse{0%{transform:scale(.5);opacity:.6;}100%{transform:scale(1.2);opacity:0;}}
@keyframes logo-scroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* Responsive */
@media (max-width: 980px){
  .hero__wrap{grid-template-columns:1fr}
  .solutions__grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}

  .nav__toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:40px;
    height:40px;
    border-radius:10px;
    border:1px solid #dbe7e4;
  }

  .nav__links{
    position:fixed;
    inset:60px 14px auto 14px;
    background:#ffffffee;
    border:1px solid #e5efec;
    border-radius:14px;
    padding:8px;
    gap:0.45rem;
    display:none;
    flex-direction:column;
  }
  .nav__links.is-open{display:flex}

  .nav__cta{display:none;}
  .section-about__grid{
    grid-template-columns:1fr;
  }
  .section-about__logo{
    display:none;
  }
}

/* Trilho horizontal de soluções na home */
/* O wrapper agora é o elemento que faz o scroll */
.solutions-rail-wrapper{
  position:relative;
  overflow-x:auto;
  overflow-y:visible;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
/* Trilho horizontal de soluções na home */
.solutions-rail-wrapper{
  position:relative;
  overflow-x:auto;
  overflow-y:visible;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  margin-bottom:4px;
}

/* Linha com os 5 cards */
.solutions__rail{
  display:inline-flex;
  gap:16px;
  padding-bottom:4px;
  min-width:max-content;
}

/* Esconde scrollbar em todos os navegadores principais */
.solutions-rail-wrapper::-webkit-scrollbar{
  display:none;
}
.solutions-rail-wrapper{
  scrollbar-width:none;
}

/* Cada card com largura fixa para sobrar um pedaço do último (PGRSS) */
.solutions__rail .solutions__card{
  flex:0 0 260px; 
  max-width:260px;
}

/* PGRSS um pouco menos protagonista */
.solutions__card--pgrss{
  opacity:0.9;
}

/* Controles em oblongos abaixo dos cards */
.solutions__controls{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top:8px;
}

.solutions__control{
  min-width:44px;
  padding:6px 14px;
  border-radius:999px;
  border:1px solid #dbe7e4;
  background:#f4faf8;
  color:var(--green-900);
  font-size:.9rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:.2s background,.2s box-shadow,.2s transform;
}

.solutions__control span{
  font-size:1.2rem;
  line-height:1;
}

.solutions__control:hover{
  background:#e3f0ec;
  box-shadow:0 6px 12px rgba(16,54,46,.16);
  transform:translateY(-1px);
}

/* Se quiser esconder os oblongos no mobile, descomente:
@media (max-width: 767px){
  .solutions__controls{
    display:none;
  }
}
*/

/* Header específico das landings (com classe .nav--landing) em telas grandes */
@media (min-width: 981px){

  .nav--landing .nav__bar{
    align-items:center;
  }

  .nav--landing .nav__actions{
    display:flex;
    align-items:center;
    gap:0.75rem;
    margin-left:auto;
  }

  .nav--landing .nav__links{
    display:none;
    position:absolute;
    top:80px;
    right:16px;
    flex-direction:column;
    gap:0.35rem;
    padding:0.6rem 0.7rem;
    background:#ffffff;
    border-radius:12px;
    box-shadow:var(--shadow);
    border:1px solid #e5efec;
    z-index:1000;
  }

  .nav--landing .nav__links a{
    padding:0.25rem 0;
    font-size:0.9rem;
    line-height:1.2;
    border-radius:6px;
  }

  .nav--landing .nav__links a:hover{
    background:#0a60500d;
  }

  .nav--landing .nav__links.is-open{
    display:flex;
  }

  .nav--landing .nav__toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:40px;
    height:40px;
    border-radius:999px;
    border:1px solid #dbe7e4;
    background:#ffffff;
    cursor:pointer;
    margin-left:0.75rem;
  }
}

@media (max-width: 640px){
  .blog__grid{grid-template-columns:1fr}
  .solutions__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
}
.section-about{
  padding:56px 0;
  background:#f7faf9;
}
.section-about__kicker{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-weight:600;
  color:#1d9389;
  margin-bottom:8px;
}
.section-about__title{
  font-size:24px;
  line-height:1.2;
  font-weight:700;
  color:#053846;
  margin:0 0 12px;
}
.section-about__subtitle{
  font-size:14px;
  color:#6b778c;
  max-width:620px;
  margin-bottom:20px;
}
.section-about__text{
  font-size:15px;
  color:#374151;
  max-width:760px;
}
.section-about__text p{
  margin:0 0 10px;
}
.section-about__cta{
  margin-top:18px;
}
.section-about__cta-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  font-weight:600;
  color:#1d9389;
  text-decoration:none;
  padding-bottom:2px;
  border-bottom:1px solid rgba(29,147,137,.35);
  transition:.2s ease;
}
.section-about__cta-link:hover{
  color:#147368;
  border-bottom-color:#147368;
  transform:translateY(-1px);
}
.section-about__grid{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr); /* texto maior que a logo */
  gap:32px;
  align-items:center;
}
.section-about__content{
  max-width:760px;
}
.section-about__logo{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.section-about__logo img{
  max-width:260px;   /* ajuste fino aqui se quiser maior/menor */
  height:auto;
}
/* Padrão reutilizável: foto acompanha a altura do texto */
.section-about--photo .section-about__grid{
  align-items: stretch;
}

/* O container vira a "máscara" com a altura do texto */
.section-about--photo .section-about__logo{
  position: relative;
  align-items: stretch;
  height: 100%;
  overflow: hidden;
  border-radius: 24px;
}

/* A imagem preenche o container */
.section-about--photo .section-about__logo img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 20%;
  max-width: none;
}
/* Ajuste específico de enquadramento – PGRSS */
.section-about--photo.is-pgrss img{
  object-position: 50% 10%;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.mt-14{margin-top:14px;}
.mt-27{margin-top:27px;}

.footer-grid{
  padding:22px 0;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:18px;
}
@media (max-width:980px){
  .grid-3{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
}
@media (max-width:768px){
  .logos-grid{
    gap:20px;
  }
  .logos-grid__item{
    width:150px;
    height:60px;
  }
}
.blog-grid {
  display: grid;
  gap: 32px;
  margin-top: 40px;
}

/* Mobile / tablets pequenos: empilha */
@media (max-width: 767px) {
  .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* Tablet / notebooks menores: 2 colunas */
@media (min-width: 768px) and (max-width: 1199px) {
  .blog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Desktop: 4 colunas fixas */
@media (min-width: 1200px) {
  .blog-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}


.blog-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--shadow);
}

.blog-card__tag {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--green-700);
}

.blog-card__title {
  margin: 12px 0 8px;
  font-size: 1.25rem;
  font-weight: 700;
}

.blog-card__excerpt {
  margin-bottom: 20px;
  color: var(--muted);
  line-height: 1.5;
}

.blog-footer {
  text-align: center;
  margin-top: 40px;
}

/* Tag de categoria no artigo individual */
.blog-tag {
  background-color: var(--green-900);
  color: #ffffff;
  font-size: 0.80rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  text-transform: uppercase;
  display: inline-block;
  margin-bottom: 12px;
  letter-spacing: 0.5px;
}

/* Versão otimizada para mobile */
@media (max-width: 480px) {
  .blog-tag {
    font-size: 0.70rem;
    padding: 3px 8px;
    border-radius: 3px;
    letter-spacing: 0.4px;
    margin-bottom: 10px;
  }
}

.blog-back-link:hover {
  text-decoration: underline;
}

.btn--cta-orange:hover {
  background-color: #e86c00;
}

/* Ajuste do espaçamento acima do CTA nos artigos do blog */
.section-cta-article {
  padding-top: 8px !important;   /* aproxima o CTA da conclusão */
  padding-bottom: 32px;           /* mantém um respiro embaixo */
}

/* Ajuste do espaçamento da section principal dos artigos do blog */
.section-article {
  padding: 18px 0 4px !important; /* menos espaço em cima, quase igual ao lado do título */
}

/* Ícone Home igual aos ícones sociais */
.nav__home-icon .social-icon,
.nav__home-icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: inline-block;
  margin-right: 0.5rem;
  cursor: pointer;
}
/* HOVER DO HAMBURGUER (desktop) */
@media (min-width: 981px){
  .nav--landing .nav__toggle:hover {
    background:#e1f1ec;            /* tom coerente com sua paleta */
    border-color:#b7d7ce;
    cursor:pointer;
    transform: translateY(-2px);
    transition: .25s transform, .25s background-color, .25s border-color;
  }
}
/* Correção universal para ícones de check */
.check-icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
  aspect-ratio: 1 / 1;
  flex-shrink: 0;
}
/* Correção definitiva para ícones de check */
.check-icon {
  width: 20px;
  height: 20px;
  max-width: none;      /* impede que siga o max-width:100% global */
  object-fit: contain;
  aspect-ratio: 1 / 1;
  flex-shrink: 0;
  display: block;
}
/* Correção definitiva do ícone de check usando <i>✓</i> */
.tick i {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--green-700);
  color: #fff;
  font-style: normal;
  font-size: 0.9rem;
  line-height: 1;
  flex-shrink: 0;
}
