:root {
  --rail-max: 1280px;
  --rail-radius: 32px;
  --rail-gap: 2rem;
  --leaf-stroke: #5a8612;
}

html { scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 1100;
  background: var(--verdee);
  color: #fff;
  padding: 0.75rem 1.25rem;
  border-radius: 0 0 8px 0;
  font-weight: 700;
  text-decoration: none;
}
.skip-link:focus {
  left: 0;
  outline: 3px solid var(--verdec);
  outline-offset: 2px;
}

#hero, #cartao, #produtos, #cooperar, #app {
  background-image: url(https://www.sicoob.com.br/documents/d/guest/fundo_macro);
  background-repeat: repeat;
  background-size: auto; 
  background-position: top center;
  background-color: var(--turq);
  position: relative;
  overflow: hidden;
}

#como-funciona, #cartao, #faq {
  background-image: url(https://www.sicoob.com.br/documents/d/guest/campo-fundo);
  background-repeat: repeat;
  background-size: auto; 
  background-position: top center;
  background-color: var(--turq);
  position: relative;
  overflow: hidden;
  min-height: 520px;
}

#coopera {  background-color: var(--verdee);}

.pagina-goleada::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    radial-gradient(circle at 8% 12%, rgba(255, 255, 255, 0.05) 0 8px, transparent 9px),
    radial-gradient(circle at 92% 22%, rgba(255, 255, 255, 0.05) 0 6px, transparent 7px),
    radial-gradient(circle at 5% 78%, rgba(255, 255, 255, 0.04) 0 10px, transparent 11px),
    radial-gradient(circle at 95% 88%, rgba(255, 255, 255, 0.05) 0 7px, transparent 8px);
  pointer-events: none;
  z-index: 0;
}

.reveal {
  opacity: 0;
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
.reveal[data-reveal="fade-up"]    { transform: translateY(40px); }
.reveal[data-reveal="fade-right"] { transform: translateX(-40px); }
.reveal[data-reveal="fade-left"]  { transform: translateX(40px); }
.reveal[data-reveal="fade-in"]    { transform: none; }
.reveal.is-visible {
  opacity: 1;
  transform: translate(0, 0);
}

.gol-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 1.35rem 0;
  background-color: var(--verdee);
  transition: background-color 0.3s ease, padding 0.3s ease, box-shadow 0.3s ease;
}
.gol-header.is-scrolled {
  background-color: var(--verdee);
  padding: 0.9rem 0;
  box-shadow: 0 6px 24px rgba(0, 30, 36, 0.18);
}

.gol-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.gol-logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: #fff;
  line-height: 1.1;
}
.gol-logo:hover { text-decoration: none; color: #fff; }
.gol-logo-text strong {
  display: block;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.5px;
}
.gol-logo-text span {
  display: block;
  font-size: 0.75rem;
  opacity: 0.85;
}

.gol-nav-menu {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin: 0;
  padding: 0;
}
.gol-nav-menu a {
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  position: relative;
  padding: 0.25rem 0;
  transition: color 0.2s ease;
}
.gol-nav-menu a:not(.gol-nav-cta)::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  height: 2px;
  background-color: var(--verdec);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.3s ease;
}
.gol-nav-menu a:not(.gol-nav-cta):hover,
.gol-nav-menu a.is-active { color: var(--verdec); }
.gol-nav-menu a:not(.gol-nav-cta):hover::after,
.gol-nav-menu a.is-active::after { transform: scaleX(1); }

.gol-nav-cta {
  padding: 0.5rem 1.1rem !important;
  border-radius: 1000px;
  font-size: 0.85rem !important;
}

.gol-nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  background-color: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
}
.gol-nav-toggle-bar {
  display: block;
  width: 26px;
  height: 2px;
  background-color: #fff;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

@media (max-width: 991.98px) {
  .gol-nav-toggle { display: inline-flex; }
  /* Quando o menu está aberto, o header ganha fundo para o conjunto
     ficar coeso e não exibir uma faixa verde escura solta sobre o banner. */
  .gol-header.is-menu-open,
  .gol-header:has(.gol-nav-menu.is-open) {
    background-color: var(--verdee);
    box-shadow: 0 6px 24px rgba(0, 30, 36, 0.18);
  }
  .gol-nav-menu {
    position: absolute;
    top: 100%;
    right: 0;
    left: 0;
    background-color: var(--verdee);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0.5rem 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }
  .gol-nav-menu.is-open { max-height: 80vh; }
  .gol-nav-menu li { width: 100%; }
  .gol-nav-menu a {
    display: block;
    padding: 0.85rem 1.5rem;
    text-align: left;
  }
  .gol-nav-menu a:not(.gol-nav-cta)::after { display: none; }
  .gol-nav-cta {
    margin: 0.5rem 1.5rem 0;
    text-align: center;
  }
}

main { position: relative; z-index: 1; }
main section[id] { scroll-margin-top: 90px; }

.rail {
  position: relative;
}


.rail-inner {
  position: relative;
  max-width: var(--rail-max);
  margin: 0 auto;
  background-color: var(--turq);
  padding: 3.5rem 3rem;
  overflow: hidden;
}
.rail-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.rail-inner > * { position: relative; z-index: 1; }

@media (max-width: 767.98px) {

  .rail-inner { padding: 2.25rem 1.5rem;}
}

.imagem-placeholder {
  width: 100%;
  background-color: rgba(255, 255, 255, 0.08);
  border: 2px dashed rgba(255, 255, 255, 0.25);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.9rem;
  text-align: center;
  margin: 0;
  min-height: 320px;
}
.placeholder-jogador { min-height: 420px; }
.placeholder-cartao  { min-height: 420px; }
.placeholder-coopera { min-height: 360px; }
.placeholder-celular { min-height: 480px; margin-bottom: 1.5rem; }

.titulo-principal {
  font-size: clamp(1.875rem, 1.4rem + 1.6vw, 2.75rem);
  line-height: 1.15;
  font-weight: 700;
  color: var(--verdee);
  margin: 0 0 1.5rem;
}
.titulo-principal .cursiva { font-weight: 400; }
.titulo-principal .acento-claro { color: var(--verdec); }

.titulo-cursiva {
  font-family: var(--font-script, 'Caveat', cursive);
  font-size: clamp(2rem, 1.5rem + 1.2vw, 3rem);
  line-height: 1;
  font-weight: 700;
  margin: 0 0 0.25rem;
  color: #fff;
}
.titulo-cursiva.acento-claro { color: var(--verdec); }
.titulo-cursiva .acento { color: var(--verdec); }

.subtitulo-cursiva {
  font-family: var(--font-script, 'Caveat', cursive);
  font-size: clamp(1.35rem, 1.1rem + 0.8vw, 1.85rem);
  text-align: center;
  color: var(--verdec);
  margin: 0 0 2rem;
  font-weight: 700;
}

.texto-intro {
  color: #fff;
  font-size: 0.95rem;
  line-height: 1.5;
  margin-bottom: 1.5rem;
  max-width: 480px;
}
.texto-intro strong { font-weight: 700; }
.titulo-produtos {font-size: 4rem; line-height: 1.0;}

.btn-cta-primary {
  display: inline-block;
  background-color: var(--verdee);
  color: #fff;
  padding: 0.85rem 1.85rem;
  border-radius: 10px;
  font-size: 1.0rem;
  text-decoration: none;
  border: none;
  transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 8px 20px -8px rgba(0, 30, 36, 0.4);
}
.btn-cta-primary:hover {
  background-color: var(--verdee-500);
  color: #fff;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 12px 26px -10px rgba(0, 30, 36, 0.55);
}

.btn-cta-link {
  display: inline-block;
  margin-top: 0.5rem;
  color: #fff;
  font-size: 1.0rem;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.btn-cta-link:hover { color: var(--verdec); text-decoration: underline; }

.hero-logotipo {
  width: 100%;
  max-width: 580px;
  height: auto;
  display: block;
  margin-bottom: 1.5rem;
  filter: drop-shadow(0 8px 18px rgba(0, 30, 36, 0.25));
}

.hero-ctas { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }

.hero-figura {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 380px;
}
.hero-personagem {
  width: 100%;
  max-width: 750px;
  height: auto;
  display: block;
  filter: drop-shadow(0 18px 30px rgba(0, 30, 36, 0.35));
}

@media (max-width: 767.98px) {
  .hero-ctas { align-items: center; }
  .col-12.col-md-6 { text-align: center; }
  .hero-figura { min-height: 0; }
}

.produtos-inner { padding-top: 3rem; padding-bottom: 3rem; }

.produtos-titulo { margin-bottom: 1rem; }

.produtos-desc {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.5;
  margin: 0 0 1.5rem;
}

.produtos-carrossel { margin: 0 auto 1.75rem; max-width: 880px; }

.produtos-slide {
  position: relative;
  padding: 1rem;
}

.produtos-rodape {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 1.5rem;
}
.produtos-aviso {
  margin: 0;
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.00rem;
  font-style: italic;
  text-align: center;
}

.passos-goleada { list-style: none; padding: 0; margin: 0; }
.card-passo {
  background-color: var(--verdee);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  color: #fff;
}
.card-passo .numero {
  color: var(--turq);
  font-size: 3rem;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
  min-width: 28px;
}
.card-passo .texto {
  font-size: 1.2rem;
  line-height: 1.4;
  font-weight: 600;
}
.card-passo .texto .destaque { color: var(--verdec); }

.lista-vantagens { list-style: none; padding: 0; margin: 0 0 2rem; }
.lista-vantagens li {
  background-color: var(--verdec);
  color:var(--verdee);
  padding: 0.85rem 1.5rem;
  margin-bottom: 0.85rem;
  border-radius: 10px;
  font-weight: 600;
     text-align: right;
  font-size: 1.2rem;
  line-height: 1.3;
  width: 100%;
  transition: transform 0.2s ease;
}
.lista-vantagens li:hover { transform: translateX(6px); }

.coopera-inner {
  background-color: var(--verdee);
  color: #fff;
}

.coopera-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}
.coopera-content > img:first-child { width: 166px; height: auto; }
.coopera-title {
  color: var(--verdem);
  line-height: 1.2;
  margin: 0;
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  font-weight: 700;
}
.coopera-desc {
  color: #fff;
  line-height: 1.5;
  margin: 0;
}
.coopera-stores {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.coopera-stores img { transition: transform 0.2s ease; }
.coopera-stores a:hover img { transform: translateY(-3px); }

@media (max-width: 991.98px) {
  .coopera-content { align-items: center; text-align: center; }
}

.frase-app {
  color: #fff;
  font-size: 1.8rem;
  line-height: 1.3;
  margin: 0 0 1rem;
  font-family: var(--font-script, 'Caveat', cursive);
}
.frase-app .acento-claro { color: var(--verdec); font-weight: 700; }

.lista-stores { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.btn-store {
  background-color: var(--verdee);
  color: #fff;
  padding: 0.6rem 1.25rem;
  border-radius: 1000px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.85rem;
  font-weight: 600;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.btn-store:hover {
  background-color: var(--verdee-500);
  color: #fff;
  text-decoration: none;
  transform: translateY(-2px);
}
.btn-store .icone { font-size: 1.4rem; line-height: 1; }
.btn-store .label small {
  display: block;
  font-size: 0.7rem;
  font-weight: 400;
  opacity: 0.85;
  line-height: 1;
  margin-bottom: 2px;
}

.lista-passos-app { list-style: none; padding: 0; margin: 0; }
.card-passo-app {
  background-color: #fff;
  border-radius: 12px;
  padding: 1rem 1.25rem;
  margin-bottom: 0.75rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  box-shadow: 0 2px 8px rgba(0, 30, 36, 0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.card-passo-app:hover {
  transform: translateX(6px);
  box-shadow: 0 6px 16px rgba(0, 30, 36, 0.12);
}
.card-passo-app .numero {
  color: var(--verdee);
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
  min-width: 38px;
}
.card-passo-app .conteudo .titulo {
  color: var(--turq);
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0 0 0.25rem;
}
.card-passo-app .conteudo .descricao {
  color: var(--verdee);
  font-size: 0.85rem;
  line-height: 1.4;
  margin: 0;
  opacity: 0.85;
}

.titulo-faq {
  font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2.25rem);
  line-height: 1.2;
  font-weight: 700;
  text-align: center;
  margin: 0 0 2.5rem;
  color: #fff;
}
.titulo-faq .acento-claro { color: var(--verdec); font-weight: 400; }

.accordion-sicoob { max-width: 900px; margin: 0 auto; }
.accordion-sicoob .item-faq {
  background-color: var(--verdem);
  border-radius: 14px;
  margin-bottom: 0.75rem;
  overflow: hidden;
  transition: background-color 0.2s ease, transform 0.2s ease;
  border: 3px solid var(--verdee)
}
.accordion-sicoob .item-faq:hover { transform: translateX(4px); }
.accordion-sicoob .item-faq-heading { margin: 0; }
.accordion-sicoob .item-faq .btn-pergunta {
  width: 100%;
  background: transparent;
  border: none;
  padding: 1rem 1.5rem;
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
}

.accordion-sicoob .item-faq .btn-pergunta .icone {
  width: 24px;
  height: 24px;
  position: relative;
  flex-shrink: 0;
}
.accordion-sicoob .item-faq .btn-pergunta .icone::before,
.accordion-sicoob .item-faq .btn-pergunta .icone::after {
  content: '';
  position: absolute;
  background-color: #fff;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.accordion-sicoob .item-faq .btn-pergunta .icone::before {
  top: 50%; left: 0; right: 0;
  height: 2px;
  transform: translateY(-50%);
}
.accordion-sicoob .item-faq .btn-pergunta .icone::after {
  left: 50%; top: 0; bottom: 0;
  width: 2px;
  transform: translateX(-50%);
  opacity: 1;
}
.accordion-sicoob .item-faq .btn-pergunta[aria-expanded="true"] .icone::after { opacity: 0; }
.accordion-sicoob .item-faq .corpo-resposta {
  padding: 0 1.5rem 1.25rem;
  color: #fff;
  font-size: 0.9rem;
  line-height: 1.5;
}

/* FAQ — controle "Ver mais" */
.accordion-sicoob .item-faq.is-faq-hidden { display: none; }
.accordion-sicoob.is-faq-expanded .item-faq.is-faq-hidden { display: block; }

.faq-more-wrap {
  max-width: 900px;
  margin: 1.5rem auto 0;
  text-align: center;
}
.btn-faq-more {
  display: inline-block;
  background-color: var(--verdec);
  color: var(--verdee);
  border: none;
  padding: 0.75rem 2rem;
  border-radius: 1000px;
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 8px 20px -8px rgba(0, 30, 36, 0.4);
}
.btn-faq-more:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px -10px rgba(0, 30, 36, 0.55);
}
.btn-faq-more:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 2px;
}

.cooperado-inner {
  text-align: center;
}

.cooperado-inner .titulo-cursiva {
  color: #fff;
  margin-bottom: 0.25rem;
}
.cooperado-inner .titulo-cursiva strong {
  font-weight: 700;
  font-style: normal;
}
.cooperado-inner .titulo-cursiva em {
  font-weight: 400;
  font-style: italic;
}

.cooperado-inner .subtitulo-cursiva {
  color: #fff;
  font-style: italic;
  margin-bottom: 2.25rem;
}
.cards-cooperado {
  margin: 0 -1rem;  
}

.card-passo-mini {
  background-color: #fff;
  border-radius: 16px;
  padding: 1.25rem 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  box-shadow: 0 4px 12px rgba(0, 30, 36, 0.08);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  text-align: center;
  position: relative;
}
.card-passo-mini:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 30, 36, 0.15);
}

.card-passo-mini .numero-box {
  background-color: var(--turq);
  color: var(--branco);
  border: 2px solid var(--branco);
  width: 50px;
  height: 50px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  font-weight: 700;
  flex-shrink: 0;
  position: absolute;
  left: -20px;
  top: 50%;
  transform: translateY(-50%);
}

.card-passo-mini .texto {
  color: var(--turq);
  font-size: 1.0rem;
  font-weight: 700;
  line-height: 1.25;
  padding-left: 30px; 
}

.coopera-inner {padding: 3.5rem 3rem 0 3rem !important;}
#app .rail-inner {padding: 3.5rem 3rem 3.5rem 0 !important;}

.btn-pergunta .question {color: var(--verdee);}

.baixar { display: none; gap: var(--size-2); }
.baixar { display: flex; }
.baixar .playstore-button { --app-color-1: var(--branco); --app-color-2: var(--verdee); display: inline-flex; align-items: center; justify-content: center; border: 2px solid var(--app-color-2); border-radius: 999px; padding: 0.5rem 1.25rem; text-align: center; transition: var(--transition-1); text-decoration: none; min-width: 150px; background-color: var(--app-color-2); color: var(--app-color-1); }
.baixar .playstore-button:hover { background-color: transparent; color: var(--app-color-2); }
.baixar .playstore-button .icon { height: 1.5rem; width: 1.5rem; }
.baixar .playstore-button .texts { margin-left: 0.75rem; display: flex; text-wrap: nowrap; flex-direction: column; align-items: flex-start; line-height: 1; }
.baixar .playstore-button .text-1 { font-size: var(--font-size-xs); }
.baixar .playstore-button .text-2 { font-size: var(--font-size-sm); font-weight: 600; }

#footer-padrao {
  background: var(--verdee);
  fill: var(--branco);
  padding: 0px !important;
  margin: 0px !important;
  overflow: hidden;
}
#footer-padrao .smaller {
  font-size: 0.75rem !important;
}
#footer-padrao .social {
  display: flex;
  justify-content: flex-end;
  padding-bottom: 3rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 768px) {
  #footer-padrao .social {
    justify-content: center;
  }
}
#footer-padrao .social a {
  display: block;
}
#footer-padrao .c-rodape {
  color: var(--branco) !important;
}
#footer-padrao.bg-branco {
  background: var(--branco);
  fill: var(--verdee);
}
#footer-padrao.bg-branco .c-rodape {
  color: var(--verdee) !important;
}
#footer-padrao.bg-branco .social {
  padding-bottom: 0rem;
  margin-bottom: 1.5rem;
}

.somoscoop img {width:120px;}

#app .img-fluid  {padding-left: 80px;
    padding-bottom: 2rem;
}

@media (max-width: 991.98px) {
    .gol-nav-menu {padding: 0 !important;}
}

@media (max-width: 767.98px) {

  #app .row {
    text-align: center !important;
  }

  #app .titulo-principal,
  #app .texto-intro,
  #app .frase-app {
    text-align: center !important;
  }

  #app .lista-passos-app {
    padding-left: 0 !important;
  }

  #app .card-passo-app {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
  }

  #app .card-passo-app .numero {
    margin-bottom: 15px !important;
  }

  #app .card-passo-app .conteudo {
    width: 100% !important;
  }

  #app .baixar,
  #app .lista-stores {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
  }
  
 .escrita, .script, .cursive, .cursiva, .pacifico, .frase-app {
	    font-family: var(--font-sans) !important;}
		
		.gol-nav-menu {padding: 0 !important;}
		
		#como-funciona .order-2 img, #app .frase-app {padding-top: 3rem !important;}
		
 #app .rail-inner {padding: 0 !important;}
 #app .titulo-principal {padding-top: 3rem !important;}
 #app .img-fluid  {padding-left: 0px !important;
 padding-bottom: 0rem !important;}
  #app .img-fluid  {max-height: 50dvh; padding-top: 3rem;}
  
 #como-funciona .card-passo .texto br {
    display: none;
}

#como-funciona .card-passo .texto {
   text-align: left !important;
}
  
  
}



