.elementor-widget-container .eael-protected-content-message{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-container .protected-content-error-msg{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-2987 .elementor-element.elementor-element-76f591f4{--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-2987 .elementor-element.elementor-element-706b4b44{--display:flex;}.elementor-2987 .elementor-element.elementor-element-706b4b44:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-706b4b44 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#013358;}.elementor-2987 .elementor-element.elementor-element-41b52fbc{--display:flex;}.elementor-2987 .elementor-element.elementor-element-41b52fbc:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-41b52fbc > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-widget-html .eael-protected-content-message{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-html .protected-content-error-msg{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-button .eael-protected-content-message{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-button .protected-content-error-msg{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-2987 .elementor-element.elementor-element-417b8366 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;}.elementor-2987 .elementor-element.elementor-element-2fdfa522{--display:flex;}.elementor-2987 .elementor-element.elementor-element-6abb5b7c .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);}.elementor-2987 .elementor-element.elementor-element-197eecb9{--display:flex;}.elementor-2987 .elementor-element.elementor-element-197eecb9:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-197eecb9 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#013358;}.elementor-2987 .elementor-element.elementor-element-34a74a0a{--display:flex;}.elementor-2987 .elementor-element.elementor-element-34a74a0a:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-34a74a0a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-2987 .elementor-element.elementor-element-54cd5035 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;}.elementor-2987 .elementor-element.elementor-element-85170ac{--display:flex;}.elementor-2987 .elementor-element.elementor-element-ac88180 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);}.elementor-2987 .elementor-element.elementor-element-5918d855{--display:flex;}.elementor-2987 .elementor-element.elementor-element-5918d855:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-5918d855 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#013358;}.elementor-2987 .elementor-element.elementor-element-3d7101b9{--display:flex;}.elementor-2987 .elementor-element.elementor-element-3d7101b9:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-3d7101b9 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-2987 .elementor-element.elementor-element-2a195408 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;}.elementor-2987 .elementor-element.elementor-element-3c9ee3ad{--display:flex;}.elementor-2987 .elementor-element.elementor-element-62b2519 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);}.elementor-2987 .elementor-element.elementor-element-21bab720{--display:flex;}.elementor-2987 .elementor-element.elementor-element-21bab720:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-21bab720 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#013358;}.elementor-2987 .elementor-element.elementor-element-775abeff{--display:flex;}.elementor-2987 .elementor-element.elementor-element-775abeff:not(.elementor-motion-effects-element-type-background), .elementor-2987 .elementor-element.elementor-element-775abeff > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-2987 .elementor-element.elementor-element-720211d7 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;}.elementor-2987 .elementor-element.elementor-element-7e75f8b5{--display:flex;}.elementor-2987 .elementor-element.elementor-element-41483bc6 .elementor-button{background-color:#2961B2;font-family:"Roboto", Sans-serif;font-weight:400;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);}@media(max-width:767px){.elementor-2987 .elementor-element.elementor-element-76f591f4{--width:500px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2987 .elementor-element.elementor-element-706b4b44{--margin-top:0px;--margin-bottom:20px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2987 .elementor-element.elementor-element-41b52fbc{--min-height:40px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-2987 .elementor-element.elementor-element-7e2a004 > .elementor-widget-container{margin:0px 0px -5px 0px;}.elementor-2987 .elementor-element.elementor-element-3d0dd60e > .elementor-widget-container{margin:-20px -30px 0px -30px;padding:0px -30px 0px -30px;}.elementor-2987 .elementor-element.elementor-element-417b8366 > .elementor-widget-container{margin:-15px 0px 60px 0px;padding:0px 0px 0px 0px;}.elementor-2987 .elementor-element.elementor-element-417b8366 .elementor-button{border-radius:6px 6px 6px 6px;padding:8px 70px 8px 70px;}.elementor-2987 .elementor-element.elementor-element-2fdfa522{--margin-top:-105px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--z-index:25;}.elementor-2987 .elementor-element.elementor-element-6abb5b7c > .elementor-widget-container{margin:18px 0px 10px 0px;}.elementor-2987 .elementor-element.elementor-element-6abb5b7c .elementor-button{font-size:15px;border-radius:6px 6px 6px 6px;padding:8px 20px 8px 20px;}.elementor-2987 .elementor-element.elementor-element-197eecb9{--margin-top:-35px;--margin-bottom:20px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:20px;--padding-left:0px;--padding-right:0px;}.elementor-2987 .elementor-element.elementor-element-34a74a0a{--min-height:40px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-2987 .elementor-element.elementor-element-7aad7c1b > .elementor-widget-container{margin:0px 0px -5px 0px;}.elementor-2987 .elementor-element.elementor-element-30a3f7c3 > .elementor-widget-container{margin:-20px -30px 0px -30px;padding:0px -30px 0px -30px;}.elementor-2987 .elementor-element.elementor-element-54cd5035 > .elementor-widget-container{margin:-15px 0px 40px 0px;padding:0px 0px 0px 0px;}.elementor-2987 .elementor-element.elementor-element-54cd5035 .elementor-button{border-radius:6px 6px 6px 6px;padding:8px 70px 8px 70px;}.elementor-2987 .elementor-element.elementor-element-85170ac{--margin-top:-105px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--z-index:25;}.elementor-2987 .elementor-element.elementor-element-ac88180 > .elementor-widget-container{margin:18px 0px 10px 0px;}.elementor-2987 .elementor-element.elementor-element-ac88180 .elementor-button{font-size:15px;border-radius:6px 6px 6px 6px;padding:8px 20px 8px 20px;}.elementor-2987 .elementor-element.elementor-element-5918d855{--margin-top:-35px;--margin-bottom:20px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:20px;--padding-left:0px;--padding-right:0px;}.elementor-2987 .elementor-element.elementor-element-3d7101b9{--min-height:40px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-2987 .elementor-element.elementor-element-6d38e9fe > .elementor-widget-container{margin:0px 0px -5px 0px;}.elementor-2987 .elementor-element.elementor-element-5d036ed5 > .elementor-widget-container{margin:-20px -30px 0px -30px;padding:0px -30px 0px -30px;}.elementor-2987 .elementor-element.elementor-element-2a195408 > .elementor-widget-container{margin:-15px 0px 40px 0px;padding:0px 0px 0px 0px;}.elementor-2987 .elementor-element.elementor-element-2a195408 .elementor-button{border-radius:6px 6px 6px 6px;padding:8px 70px 8px 70px;}.elementor-2987 .elementor-element.elementor-element-3c9ee3ad{--margin-top:-105px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--z-index:25;}.elementor-2987 .elementor-element.elementor-element-62b2519 > .elementor-widget-container{margin:18px 0px 10px 0px;}.elementor-2987 .elementor-element.elementor-element-62b2519 .elementor-button{font-size:15px;border-radius:6px 6px 6px 6px;padding:8px 20px 8px 20px;}.elementor-2987 .elementor-element.elementor-element-21bab720{--margin-top:-35px;--margin-bottom:20px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:20px;--padding-left:0px;--padding-right:0px;}.elementor-2987 .elementor-element.elementor-element-775abeff{--min-height:40px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-2987 .elementor-element.elementor-element-3fb4596e > .elementor-widget-container{margin:0px 0px -5px 0px;}.elementor-2987 .elementor-element.elementor-element-1cb72be8 > .elementor-widget-container{margin:-20px -30px 0px -30px;padding:0px -30px 0px -30px;}.elementor-2987 .elementor-element.elementor-element-720211d7 > .elementor-widget-container{margin:-15px 0px 40px 0px;padding:0px 0px 0px 0px;}.elementor-2987 .elementor-element.elementor-element-720211d7 .elementor-button{border-radius:6px 6px 6px 6px;padding:8px 70px 8px 70px;}.elementor-2987 .elementor-element.elementor-element-7e75f8b5{--margin-top:-105px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--z-index:25;}.elementor-2987 .elementor-element.elementor-element-41483bc6 > .elementor-widget-container{margin:18px 0px 10px 0px;}.elementor-2987 .elementor-element.elementor-element-41483bc6 .elementor-button{font-size:15px;border-radius:6px 6px 6px 6px;padding:8px 20px 8px 20px;}}/* Start custom CSS for html, class: .elementor-element-7e2a004 */.aba-sanfona {
  display: flex;
  align-items: center; /* centraliza ícone e título verticalmente */
  cursor: pointer; /* deixa parecer clicável */
  margin-bottom: 0px;
  margin-left: -12px;
}

.aba-sanfona .icone {
  width: 40px;  /* ajuste do tamanho do ícone */
  height: 40px;
  margin-right: 10px; /* espaço entre ícone e título */
}

.aba-sanfona .titulo {
  font-family: 'Roboto', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: #2961B2; /* azul padrão */
}

.aba-sanfona .icone.aberto {
  display: none;
}

.aba-sanfona.ativa .icone.fechado {
  display: none;
}

.aba-sanfona.ativa .icone.aberto {
  display: inline-block;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3d0dd60e */.bloco-sanfona {
  max-width: 320px;
  margin: 0 auto 40px;
  position: relative;
}

/* Cabeçalho (ícone + caixa azul + texto) */
.bloco-sanfona .cabecalho {
  position: relative;
  margin-top: 15px;
  margin-bottom: -15px;
  height: 70px; /* altura do box azul */
  left: -11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 30px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Texto acima da caixa azul */
.bloco-sanfona .texto {
  position: absolute;
  top: 0;
  left: 50px; /* inicia depois do ícone */
  right: 50px;
  height: 65px;
  display: flex;
  align-items: center;
  padding-left: 25px;
  padding-right: 10px;
  color: white;
  font-family: 'Roboto', sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1.2;
  z-index: 2;
}

.bloco-sanfona .caixa-texto span {
  display: inline-block;   /* garante que o span tenha "peso" */
  width: 100%;             /* força cada linha a ocupar a largura toda */
  white-space: normal;     /* permite quebra de linha normal */
}

/* Caixa de texto à direita */
.bloco-sanfona.direita .texto {
  margin-left: auto;
  margin-right: -10px;
  padding-right: 35px;
  width: calc(100% - 65px);
  text-align: right;
  padding-left: 10px;
  justify-content: flex-end;

  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}

.bloco-sanfona.direita .texto strong {
    font-weight: 600;
}

.bloco-sanfona .texto strong {
    font-weight: 600;
}


/* Ícone alinhado na borda da imagem */
.bloco-sanfona .icone {
  position: absolute;
  top: -2%; 
  left: 0;
  width: 65px;
  height: auto;
  z-index: 15;
}

/* Ícone à direita */
.bloco-sanfona.direita .icone {
  left: auto;
  right: 0;
}

/* Cabeçalho invertido na direita */
.bloco-sanfona.direita .cabecalho {
  flex-direction: row-reverse;
  justify-content: flex-end;
  left: 11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona.direita .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 25px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Imagem sem legenda */
.bloco-sanfona .imagem {
  width: 87.5%;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
  border: 1.8px solid white;
  display: block;
  margin: 10px auto 0;
  position: relative;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

/* Wrapper de imagem + legenda */
.media-wrapper {
  width: 87.5%;
  max-width: 350px;
  margin: 10px auto 0;
  display: block;
  position: relative;
  z-index: 10;
}

.media-wrapper .imagem {
  width: 100%;
  height: auto;
  border-radius: 16px 16px 0 0;
  border: 1.8px solid white;
  margin-bottom: 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.media-wrapper .legenda {
  background: white;
  color: #2961B2;
  font-family: 'Roboto', sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
  border-radius: 0 0 12px 12px;
  padding: 10px 14px;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 40px;
  margin-top: -2px;
}

/* Ajustes de borda para encaixe com ícone */
.bloco-sanfona .imagem,
.bloco-sanfona .media-wrapper .imagem {
  border-top-left-radius: 0;
}

.bloco-sanfona.direita .imagem,
.bloco-sanfona.direita .media-wrapper .imagem {
  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-706b4b44 *//* Container da sanfona */
.container-sanfona {
  position: relative; /* necessário para o ::after */
  max-height: 150px;
  overflow: hidden;
  transition: max-height 0.6s ease, padding-bottom 0.6s ease; /* sincronizado */
}

/* Gradiente/desfoque no final */
.container-sanfona::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 62%;
  background: rgba(0, 0, 0, 0.2);
  z-index: 20;
  pointer-events: none;
  
  backdrop-filter: blur(1.5px);
  -webkit-backdrop-filter: blur(1.5px);

  transition: opacity 0.6s ease; /* mesmo tempo da sanfona */
}

/* Sanfona expandida */
.container-sanfona.expandir {
  max-height: 3000px; /* altura grande suficiente */
  padding-bottom: 40px; /* espaço extra no final */
}

.container-sanfona.expandir::after {
  opacity: 0; /* fade suave do gradiente */
}

/* Botão “Ver Mais/Ver Menos” */
.botao-sanfona {
  display: inline-block;
  transition: opacity 0.6s ease, visibility 0.6s ease; /* sincronizado com container */
}

/* Botão quando a sanfona está aberta */
.botao-sanfona.aberto {
  opacity: 0;
  visibility: hidden;
  position: absolute; /* não puxa conteúdo de baixo */
}/* End custom CSS */
/* Start custom CSS for button, class: .elementor-element-6abb5b7c */.botao-sanfona {
    display: block;
    transition: opacity 0.3s ease 0.5s, transform 0.3s ease 0.5s; /* delay para esperar a sanfona expandir */
    position: relative;
}

.botao-sanfona.aberto {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-20px);
    transition-delay: 0s; /* volta imediatamente quando fechando */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7aad7c1b */.aba-sanfona {
  display: flex;
  align-items: center; /* centraliza ícone e título verticalmente */
  cursor: pointer; /* deixa parecer clicável */
  margin-bottom: 0px;
  margin-left: -12px;
}

.aba-sanfona .icone {
  width: 40px;  /* ajuste do tamanho do ícone */
  height: 40px;
  margin-right: 10px; /* espaço entre ícone e título */
  margin-top: -5px;
}

.aba-sanfona .titulo {
  font-family: 'Roboto', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: #2961B2; /* azul padrão */
  height: 30px;
  margin-top: 0px;
}

.aba-sanfona .icone.aberto {
  display: none;
}

.aba-sanfona.ativa .icone.fechado {
  display: none;
}

.aba-sanfona.ativa .icone.aberto {
  display: inline-block;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-30a3f7c3 */.bloco-sanfona {
  max-width: 320px;
  margin: 0 auto 40px;
  position: relative;
}

/* Cabeçalho (ícone + caixa azul + texto) */
.bloco-sanfona .cabecalho {
  position: relative;
  margin-top: 15px;
  margin-bottom: -15px;
  height: 70px; /* altura do box azul */
  left: -11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 30px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Texto acima da caixa azul */
.bloco-sanfona .texto {
  position: absolute;
  top: 0;
  left: 50px; /* inicia depois do ícone */
  right: 50px;
  height: 65px;
  display: flex;
  align-items: center;
  padding-left: 25px;
  padding-right: 10px;
  color: white;
  font-family: 'Roboto', sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1.2;
  z-index: 2;
}

.bloco-sanfona .caixa-texto span {
  display: inline-block;   /* garante que o span tenha "peso" */
  width: 100%;             /* força cada linha a ocupar a largura toda */
  white-space: normal;     /* permite quebra de linha normal */
}

/* Caixa de texto à direita */
.bloco-sanfona.direita .texto {
  margin-left: auto;
  margin-right: -10px;
  padding-right: 35px;
  width: calc(100% - 65px);
  text-align: right;
  padding-left: 10px;
  justify-content: flex-end;

  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}

.bloco-sanfona.direita .texto strong {
    font-weight: 600;
}

.bloco-sanfona .texto strong {
    font-weight: 600;
}


/* Ícone alinhado na borda da imagem */
.bloco-sanfona .icone {
  position: absolute;
  top: -2%; 
  left: 0;
  width: 65px;
  height: auto;
  z-index: 15;
}

/* Ícone à direita */
.bloco-sanfona.direita .icone {
  left: auto;
  right: 0;
}

/* Cabeçalho invertido na direita */
.bloco-sanfona.direita .cabecalho {
  flex-direction: row-reverse;
  justify-content: flex-end;
  left: 11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona.direita .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 25px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Imagem sem legenda */
.bloco-sanfona .imagem {
  width: 87.5%;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
  border: 1.8px solid white;
  display: block;
  margin: 10px auto 0;
  position: relative;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

/* Wrapper de imagem + legenda */
.media-wrapper {
  width: 87.5%;
  max-width: 350px;
  margin: 10px auto 0;
  display: block;
  position: relative;
  z-index: 10;
}

.media-wrapper .imagem {
  width: 100%;
  height: auto;
  border-radius: 16px 16px 0 0;
  border: 1.8px solid white;
  margin-bottom: 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.media-wrapper .legenda {
  background: white;
  color: #2961B2;
  font-family: 'Roboto', sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
  border-radius: 0 0 12px 12px;
  padding: 10px 14px;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 40px;
  margin-top: -2px;
}

/* Ajustes de borda para encaixe com ícone */
.bloco-sanfona .imagem,
.bloco-sanfona .media-wrapper .imagem {
  border-top-left-radius: 0;
}

.bloco-sanfona.direita .imagem,
.bloco-sanfona.direita .media-wrapper .imagem {
  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-197eecb9 */.container-sanfona {
  position: relative; /* necessário pro ::after */
  max-height: 150px;
  overflow: hidden;
  transition: max-height 1s ease, padding-bottom 0.6s ease;
}

.container-sanfona::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 62%;
  background: rgba(0, 0, 0, 0.2);
  z-index: 20;
  pointer-events: none;
  
  /* efeito de desfoque atrás do gradiente */
  backdrop-filter: blur(1.5px);
  -webkit-backdrop-filter: blur(1.5px);

  transition: opacity 0.4s ease; /* deixa o fade mais suave */
}

.container-sanfona.expandir {
  max-height: 3000px; /* altura grande só pra garantir */
  padding-bottom: 40px; /* mais respiro */
}

.container-sanfona.expandir::after {
  opacity: 0; /* some suave */
}/* End custom CSS */
/* Start custom CSS for button, class: .elementor-element-ac88180 */.botao-sanfona {
    display: inline-block;
    transition: opacity 0.5s ease, visibility 0.5s ease; /* remove margin/padding da transição */
}

.botao-sanfona.aberto {
    opacity: 0;
    visibility: hidden;
    /* não animar margin-top ou padding, só some suavemente */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6d38e9fe */.aba-sanfona {
  display: flex;
  align-items: center; /* centraliza ícone e título verticalmente */
  cursor: pointer; /* deixa parecer clicável */
  margin-bottom: 0px;
  margin-left: -12px;
}

.aba-sanfona .icone {
  width: 40px;  /* ajuste do tamanho do ícone */
  height: 40px;
  margin-right: 10px; /* espaço entre ícone e título */
}

.aba-sanfona .titulo {
  font-family: 'Roboto', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: #2961B2; /* azul padrão */
}

.aba-sanfona .icone.aberto {
  display: none;
}

.aba-sanfona.ativa .icone.fechado {
  display: none;
}

.aba-sanfona.ativa .icone.aberto {
  display: inline-block;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-5d036ed5 */.bloco-sanfona {
  max-width: 320px;
  margin: 0 auto 40px;
  position: relative;
}

/* Cabeçalho (ícone + caixa azul + texto) */
.bloco-sanfona .cabecalho {
  position: relative;
  margin-top: 15px;
  margin-bottom: -15px;
  height: 70px; /* altura do box azul */
  left: -11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 30px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Texto acima da caixa azul */
.bloco-sanfona .texto {
  position: absolute;
  top: 0;
  left: 50px; /* inicia depois do ícone */
  right: 50px;
  height: 65px;
  display: flex;
  align-items: center;
  padding-left: 25px;
  padding-right: 10px;
  color: white;
  font-family: 'Roboto', sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1.2;
  z-index: 2;
}

.bloco-sanfona .caixa-texto span {
  display: inline-block;   /* garante que o span tenha "peso" */
  width: 100%;             /* força cada linha a ocupar a largura toda */
  white-space: normal;     /* permite quebra de linha normal */
}

/* Caixa de texto à direita */
.bloco-sanfona.direita .texto {
  margin-left: auto;
  margin-right: -10px;
  padding-right: 35px;
  width: calc(100% - 65px);
  text-align: right;
  padding-left: 10px;
  justify-content: flex-end;

  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}

.bloco-sanfona.direita .texto strong {
    font-weight: 600;
}

.bloco-sanfona .texto strong {
    font-weight: 600;
}


/* Ícone alinhado na borda da imagem */
.bloco-sanfona .icone {
  position: absolute;
  top: -2%; 
  left: 0;
  width: 65px;
  height: auto;
  z-index: 15;
}

/* Ícone à direita */
.bloco-sanfona.direita .icone {
  left: auto;
  right: 0;
}

/* Cabeçalho invertido na direita */
.bloco-sanfona.direita .cabecalho {
  flex-direction: row-reverse;
  justify-content: flex-end;
  left: 11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona.direita .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 25px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Imagem sem legenda */
.bloco-sanfona .imagem {
  width: 87.5%;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
  border: 1.8px solid white;
  display: block;
  margin: 10px auto 0;
  position: relative;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

/* Wrapper de imagem + legenda */
.media-wrapper {
  width: 87.5%;
  max-width: 350px;
  margin: 10px auto 0;
  display: block;
  position: relative;
  z-index: 10;
}

.media-wrapper .imagem {
  width: 100%;
  height: auto;
  border-radius: 16px 16px 0 0;
  border: 1.8px solid white;
  margin-bottom: 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.media-wrapper .legenda {
  background: white;
  color: #2961B2;
  font-family: 'Roboto', sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
  border-radius: 0 0 12px 12px;
  padding: 10px 14px;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 40px;
  margin-top: -2px;
}

/* Ajustes de borda para encaixe com ícone */
.bloco-sanfona .imagem,
.bloco-sanfona .media-wrapper .imagem {
  border-top-left-radius: 0;
}

.bloco-sanfona.direita .imagem,
.bloco-sanfona.direita .media-wrapper .imagem {
  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-5918d855 */.container-sanfona {
  position: relative; /* necessário pro ::after */
  max-height: 150px;
  overflow: hidden;
  transition: max-height 1s ease, padding-bottom 0.6s ease;
}

.container-sanfona::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 62%;
  background: rgba(0, 0, 0, 0.2);
  z-index: 20;
  pointer-events: none;
  
  /* efeito de desfoque atrás do gradiente */
  backdrop-filter: blur(1.5px);
  -webkit-backdrop-filter: blur(1.5px);

  transition: opacity 0.4s ease; /* deixa o fade mais suave */
}

.container-sanfona.expandir {
  max-height: 3000px; /* altura grande só pra garantir */
  padding-bottom: 40px; /* mais respiro */
}

.container-sanfona.expandir::after {
  opacity: 0; /* some suave */
}/* End custom CSS */
/* Start custom CSS for button, class: .elementor-element-62b2519 */.botao-sanfona {
    display: inline-block; /* mantém o espaço do botão */
    transition: opacity 0.3s ease, visibility 0.3s ease, margin-top 0.3s ease, padding-bottom 0.3s ease;
}

.botao-sanfona.aberto {
    opacity: 0;           /* some visualmente */
    visibility: hidden;   /* oculta sem remover do fluxo */
    position: absolute;
    margin-top: -20px;    /* sobe um pouco */
    padding-bottom: 30px; /* dá espaço extra */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3fb4596e */.aba-sanfona {
  display: flex;
  align-items: center; /* centraliza ícone e título verticalmente */
  cursor: pointer; /* deixa parecer clicável */
  margin-bottom: 0px;
  margin-left: -12px;
}

.aba-sanfona .icone {
  width: 40px;  /* ajuste do tamanho do ícone */
  height: 40px;
  margin-right: 10px; /* espaço entre ícone e título */
}

.aba-sanfona .titulo {
  font-family: 'Roboto', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: #2961B2; /* azul padrão */
}

.aba-sanfona .icone.aberto {
  display: none;
}

.aba-sanfona.ativa .icone.fechado {
  display: none;
}

.aba-sanfona.ativa .icone.aberto {
  display: inline-block;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1cb72be8 */.bloco-sanfona {
  max-width: 320px;
  margin: 0 auto 40px;
  position: relative;
}

/* Cabeçalho (ícone + caixa azul + texto) */
.bloco-sanfona .cabecalho {
  position: relative;
  margin-top: 15px;
  margin-bottom: -15px;
  height: 70px; /* altura do box azul */
  left: -11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 30px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Texto acima da caixa azul */
.bloco-sanfona .texto {
  position: absolute;
  top: 0;
  left: 50px; /* inicia depois do ícone */
  right: 50px;
  height: 65px;
  display: flex;
  align-items: center;
  padding-left: 25px;
  padding-right: 10px;
  color: white;
  font-family: 'Roboto', sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1.2;
  z-index: 2;
}

.bloco-sanfona .caixa-texto span {
  display: inline-block;   /* garante que o span tenha "peso" */
  width: 100%;             /* força cada linha a ocupar a largura toda */
  white-space: normal;     /* permite quebra de linha normal */
}

/* Caixa de texto à direita */
.bloco-sanfona.direita .texto {
  margin-left: auto;
  margin-right: -10px;
  padding-right: 35px;
  width: calc(100% - 65px);
  text-align: right;
  padding-left: 9px;
  justify-content: flex-end;

  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}

.bloco-sanfona.direita .texto strong {
    font-weight: 600;
}

.bloco-sanfona .texto strong {
    font-weight: 600;
}


/* Ícone alinhado na borda da imagem */
.bloco-sanfona .icone {
  position: absolute;
  top: -2%; 
  left: 0;
  width: 65px;
  height: auto;
  z-index: 15;
}

/* Ícone à direita */
.bloco-sanfona.direita .icone {
  left: auto;
  right: 0;
}

/* Cabeçalho invertido na direita */
.bloco-sanfona.direita .cabecalho {
  flex-direction: row-reverse;
  justify-content: flex-end;
  left: 11px;
}

/* Box azul separado atrás do texto */
.bloco-sanfona.direita .box-azul {
  position: absolute;
  top: 1.5px; 
  left: 25px;
  width: calc(100% - 55px); /* espaço para o ícone */
  height: 75px;
  background-color: #2961B2;
  border-radius: 18px;
  z-index: 1;
}

/* Imagem sem legenda */
.bloco-sanfona .imagem {
  width: 87.5%;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
  border: 1.8px solid white;
  display: block;
  margin: 10px auto 0;
  position: relative;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

/* Wrapper de imagem + legenda */
.media-wrapper {
  width: 87.5%;
  max-width: 350px;
  margin: 10px auto 0;
  display: block;
  position: relative;
  z-index: 10;
}

.media-wrapper .imagem {
  width: 100%;
  height: auto;
  border-radius: 16px 16px 0 0;
  border: 1.8px solid white;
  margin-bottom: 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.media-wrapper .legenda {
  background: white;
  color: #2961B2;
  font-family: 'Roboto', sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
  border-radius: 0 0 12px 12px;
  padding: 10px 14px;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 40px;
  margin-top: -2px;
}

/* Ajustes de borda para encaixe com ícone */
.bloco-sanfona .imagem,
.bloco-sanfona .media-wrapper .imagem {
  border-top-left-radius: 0;
}

.bloco-sanfona.direita .imagem,
.bloco-sanfona.direita .media-wrapper .imagem {
  border-top-left-radius: 16px;
  border-top-right-radius: 0;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-21bab720 */.container-sanfona {
  position: relative; /* necessário pro ::after */
  max-height: 150px;
  overflow: hidden;
  transition: max-height 1s ease, padding-bottom 0.6s ease;
}

.container-sanfona::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 62%;
  background: rgba(0, 0, 0, 0.2);
  z-index: 20;
  pointer-events: none;
  
  /* efeito de desfoque atrás do gradiente */
  backdrop-filter: blur(1.5px);
  -webkit-backdrop-filter: blur(1.5px);

  transition: opacity 0.4s ease; /* deixa o fade mais suave */
}

.container-sanfona.expandir {
  max-height: 3000px; /* altura grande só pra garantir */
  padding-bottom: 40px; /* mais respiro */
}

.container-sanfona.expandir::after {
  opacity: 0; /* some suave */
}/* End custom CSS */
/* Start custom CSS for button, class: .elementor-element-41483bc6 */.botao-sanfona {
    display: inline-block; /* mantém o espaço do botão */
    transition: opacity 0.3s ease, visibility 0.3s ease, margin-top 0.3s ease, padding-bottom 0.3s ease;
}

.botao-sanfona.aberto {
    opacity: 0;           /* some visualmente */
    visibility: hidden;   /* oculta sem remover do fluxo */
    position: absolute;
    margin-top: -20px;    /* sobe um pouco */
    padding-bottom: 30px; /* dá espaço extra */
}/* End custom CSS */