/*-----------------------------------*\
  #style.css
\*-----------------------------------*/


/*-----------------------------------*\
  #PROPRIEDADES PERSONALIZADAS
\*-----------------------------------*/

:root {

  /**
   * cores
   */

  /* gradiente */

  --bg-gradiente-onix: linear-gradient(to bottom right,
      hsl(240, 1%, 25%) 3%,
      hsl(0, 0%, 19%) 97%);
  --bg-gradiente-jato: linear-gradient(to bottom right,
      hsla(240, 1%, 18%, 0.251) 0%,
      hsla(240, 2%, 11%, 0) 100%), hsl(240, 2%, 13%);
  --bg-gradiente-amarelo-1: linear-gradient(to bottom right,
      hsl(45, 100%, 71%) 0%,
      hsla(36, 100%, 69%, 0) 50%);
  --bg-gradiente-amarelo-2: linear-gradient(135deg,
      hsla(45, 100%, 71%, 0.251) 0%,
      hsla(35, 100%, 68%, 0) 59.86%), hsl(240, 2%, 13%);
  --borda-gradiente-onix: linear-gradient(to bottom right,
      hsl(0, 0%, 25%) 0%,
      hsla(0, 0%, 25%, 0) 50%);
  --texto-gradiente-amarelo: linear-gradient(to right,
      hsl(45, 100%, 72%),
      hsl(35, 100%, 68%));

  /* sólido */

  --jato: hsl(0, 0%, 22%);
  --onix: hsl(240, 1%, 17%);
  --preto-sinistro-1: hsl(240, 2%, 13%);
  --preto-sinistro-2: hsl(240, 2%, 12%);
  --preto-esfumacado: hsl(0, 0%, 7%);
  --branco-1: hsl(0, 0%, 100%);
  --branco-2: hsl(0, 0%, 98%);
  --amarelo-laranja-crayola: hsl(45, 100%, 72%);
  --ouro-vegas: hsl(45, 54%, 58%);
  --cinza-claro: hsl(0, 0%, 84%);
  --cinza-claro-70: hsla(0, 0%, 84%, 0.7);
  --vermelho-brilho-amargo: hsl(0, 43%, 51%);

  /**
   * tipografia
   */

  /* família da fonte */
  --ff-poppins: 'Poppins', sans-serif;

  /* tamanho da fonte */
  --fs-1: 24px;
  --fs-2: 18px;
  --fs-3: 17px;
  --fs-4: 16px;
  --fs-5: 15px;
  --fs-6: 14px;
  --fs-7: 13px;
  --fs-8: 11px;

  /* peso da fonte */
  --fw-300: 300;
  --fw-400: 400;
  --fw-500: 500;
  --fw-600: 600;

  /**
   * sombra
   */

  --sombra-1: -4px 8px 24px hsla(0, 0%, 0%, 0.25);
  --sombra-2: 0 16px 30px hsla(0, 0%, 0%, 0.25);
  --sombra-3: 0 16px 40px hsla(0, 0%, 0%, 0.25);
  --sombra-4: 0 25px 50px hsla(0, 0%, 0%, 0.15);
  --sombra-5: 0 24px 80px hsla(0, 0%, 0%, 0.25);

  /**
   * transição
   */

  --transicao-1: 0.25s ease;
  --transicao-2: 0.5s ease-in-out;

}





/*-----------------------------------*\
  #RESET
\*-----------------------------------*/

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

a {
  text-decoration: none;
}

li {
  list-style: none;
}

img,
ion-icon,
a,
button,
time,
span {
  display: block;
}

button {
  font: inherit;
  background: none;
  border: none;
  text-align: left;
  /* cursor: pointer; */
}

input,
textarea {
  display: block;
  width: 100%;
  background: none;
  font: inherit;
}

::selection {
  background: var(--amarelo-laranja-crayola);
  color: var(--preto-esfumacado);
}

:focus {
  outline-color: var(--amarelo-laranja-crayola);
}

html {
  font-family: var(--ff-poppins);
}

body {
  background: var(--preto-esfumacado);
}

/* Estilização da scrollbar principal */
body::-webkit-scrollbar {
  width: 5px;
  /* para barra de rolagem vertical */
  height: 5px;
  /* para barra de rolagem horizontal */
}

body::-webkit-scrollbar-track {
  background: var(--onix);
  border-radius: 5px;
}

body::-webkit-scrollbar-thumb {
  background: var(--amarelo-laranja-crayola);
  border-radius: 5px;
}

body::-webkit-scrollbar-button {
  width: 20px;
}





/*-----------------------------------*\
  #ESTILO REUTILIZADO
\*-----------------------------------*/

.barra-lateral,
article {
  background: var(--preto-sinistro-2);
  border: 1px solid var(--jato);
  border-radius: 20px;
  padding: 15px;
  box-shadow: var(--sombra-1);
  z-index: 1;
}

.separador {
  width: 100%;
  height: 1px;
  background: var(--jato);
  margin: 16px 0;
}

.caixa-icone {
  position: relative;
  background: var(--borda-gradiente-onix);
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  color: var(--amarelo-laranja-crayola);
  box-shadow: var(--sombra-1);
  z-index: 1;
}

.caixa-icone::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--preto-sinistro-1);
  border-radius: inherit;
  z-index: -1;
}

.caixa-icone ion-icon {
  --ionicon-stroke-width: 35px;
}

article {
  display: none;
}

article.active {
  display: block;
  animation: fade 0.5s ease backwards;
}

@keyframes fade {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.h2,
.h3,
.h4,
.h5 {
  color: var(--branco-2);
}

.h2 {
  font-size: var(--fs-1);
}

.h3 {
  font-size: var(--fs-2);
}

.h4 {
  font-size: var(--fs-4);
}

.h5 {
  font-size: var(--fs-7);
  font-weight: var(--fw-500);
}

.titulo-artigo {
  position: relative;
  padding-bottom: 7px;
  color: var(--branco-2);
}

.titulo-artigo::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 30px;
  height: 3px;
  background: var(--texto-gradiente-amarelo);
  border-radius: 3px;
}

.tem-barra-rolagem::-webkit-scrollbar {
  width: 5px;
  /* para barra de rolagem vertical */
  height: 5px;
  /* para barra de rolagem horizontal */
}

.tem-barra-rolagem::-webkit-scrollbar-track {
  background: var(--onix);
  border-radius: 5px;
}

.tem-barra-rolagem::-webkit-scrollbar-thumb {
  background: var(--amarelo-laranja-crayola);
  border-radius: 5px;
}

.tem-barra-rolagem::-webkit-scrollbar-button {
  width: 20px;
}

.cartao-conteudo {
  position: relative;
  background: var(--borda-gradiente-onix);
  padding: 15px;
  border-radius: 14px;
  box-shadow: var(--sombra-2);
  /* cursor: pointer; */
  z-index: 1;
}

.cartao-conteudo::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--bg-gradiente-jato);
  border-radius: inherit;
  z-index: -1;
}





/*-----------------------------------*\
  #PRINCIPAL
\*-----------------------------------*/

main {
  margin: 15px 12px;
  margin-bottom: 75px;
  min-width: 259px;
}





/*-----------------------------------*\
  #BARRA LATERAL
\*-----------------------------------*/

.barra-lateral {
  margin-bottom: 15px;
  max-height: 112px;
  overflow: hidden;
  transition: var(--transicao-2);
}

.barra-lateral.active {
  max-height: 405px;
}

.info-barra-lateral {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}

.caixa-avatar {
  background: var(--bg-gradiente-onix);
  border-radius: 20px;
}

.caixa-avatar img {
  border-radius: 20px;
}

.conteudo-info .nome {
  color: var(--branco-2);
  font-size: var(--fs-3);
  font-weight: var(--fw-500);
  letter-spacing: -0.25px;
  margin-bottom: 10px;
}

.conteudo-info .titulo {
  color: var(--branco-1);
  background: var(--onix);
  font-size: var(--fs-8);
  font-weight: var(--fw-300);
  width: max-content;
  padding: 3px 12px;
  border-radius: 8px;
}

.botao-mais-info {
  position: absolute;
  top: 0;
  right: 0;
  border-radius: 0 15px;
  font-size: var(--fs-6);
  color: var(--amarelo-laranja-crayola);
  background: var(--borda-gradiente-onix);
  padding: 10px;
  box-shadow: var(--sombra-2);
  transition: var(--transicao-1);
  z-index: 1;
}

.botao-mais-info::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: var(--bg-gradiente-jato);
  transition: var(--transicao-1);
  z-index: -1;
}

.botao-mais-info:hover,
.botao-mais-info:focus {
  color: var(--amarelo-laranja-crayola);
}

.botao-mais-info:hover::before,
.botao-mais-info:focus::before {
  background: var(--bg-gradiente-amarelo-1);
}

.botao-mais-info span {
  display: none;
}

.mais-info-barra-lateral {
  opacity: 0;
  visibility: hidden;
  transition: var(--transicao-2);
}

.barra-lateral.active .mais-info-barra-lateral {
  opacity: 1;
  visibility: visible;
}

.lista-contatos {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.item-contato {
  min-width: 100%;
  display: flex;
  align-items: center;
  gap: 16px;
}

.info-contato {
  max-width: calc(100% - 46px);
  width: calc(100% - 46px);
}

.titulo-contato {
  color: var(--cinza-claro-70);
  font-size: var(--fs-8);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.info-contato :is(.link-contato, time, address) {
  color: var(--branco-2);
  font-size: var(--fs-7);
}

.info-contato address {
  font-style: normal;
}

.lista-social {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 15px;
  padding-bottom: 4px;
  padding-left: 7px;
}

.item-social .link-social {
  color: var(--cinza-claro-70);
  font-size: 18px;
}

.item-social .link-social:hover {
  color: var(--amarelo-laranja-crayola);
}





/*-----------------------------------*\
  #BARRA DE NAVEGAÇÃO
\*-----------------------------------*/

.barra-navegacao {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: hsla(240, 1%, 17%, 0.75);
  backdrop-filter: blur(10px);
  border: 1px solid var(--jato);
  border-radius: 12px 12px 0 0;
  box-shadow: var(--sombra-2);
  z-index: 5;
}

.lista-barra-navegacao {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
}

.link-barra-navegacao {
  color: var(--cinza-claro);
  font-size: var(--fs-8);
  padding: 20px 7px;
  transition: color var(--transicao-1);
}

.link-barra-navegacao:hover,
.link-barra-navegacao:focus {
  color: var(--cinza-claro-70);
}

.link-barra-navegacao.active {
  color: var(--amarelo-laranja-crayola);
}

/*-----------------------------------*\
  #SOBRE
\*-----------------------------------*/

.sobre .titulo-artigo {
  margin-bottom: 15px;
}

/* Container do logo e título */
.container-logo-titulo {
  display: flex;
  flex-direction: column;
  margin-bottom: 15px;
}

.logo-aolhonu {
  width: 100px;
  height: auto;
  margin-bottom: 20px;
  filter: drop-shadow(0 4px 10px rgba(255, 219, 112, 0.3));
  transition: transform 0.3s ease, filter 0.3s ease;
}

.logo-aolhonu:hover {
  transform: scale(1.05);
  filter: drop-shadow(0 6px 15px rgba(255, 219, 112, 0.5));
}

.texto-sobre {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
}

.texto-sobre p {
  margin-bottom: 15px;
}

/*
  - serviço
*/

.servico {
  margin-bottom: 35px;
}

.titulo-servico {
  margin-bottom: 20px;
}

.lista-servicos {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

.item-servico {
  position: relative;
  background: var(--borda-gradiente-onix);
  padding: 20px;
  border-radius: 14px;
  box-shadow: var(--sombra-2);
  z-index: 1;
}

.item-servico::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--bg-gradiente-jato);
  border-radius: inherit;
  z-index: -1;
}

.caixa-icone-servico {
  margin-bottom: 10px;
}

.caixa-icone-servico img {
  margin: auto;
}

.caixa-conteudo-servico {
  text-align: center;
}

.titulo-item-servico {
  margin-bottom: 7px;
}

.texto-item-servico {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
}

/*
  - depoimentos
*/

.depoimentos {
  margin-bottom: 30px;
}

/* wrapper para cabeçalho com navegação */
.wrapper-cabecalho-navegacao {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.titulo-depoimentos {
  margin-bottom: 0;
}

/* botões de navegação do carrossel */
.botoes-navegacao-carrossel {
  display: flex;
  gap: 8px;
}

.botao-nav-carrossel {
  position: relative;
  background: var(--borda-gradiente-onix);
  color: var(--amarelo-laranja-crayola);
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  transition: var(--transicao-1);
  z-index: 1;
}

.botao-nav-carrossel::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--preto-sinistro-1);
  border-radius: inherit;
  z-index: -1;
  transition: var(--transicao-1);
}

.botao-nav-carrossel:hover {
  background: var(--bg-gradiente-amarelo-1);
  transform: translateY(-1px);
}

.botao-nav-carrossel:hover::before {
  background: var(--bg-gradiente-amarelo-2);
}

.botao-nav-carrossel:active {
  transform: translateY(0);
}

.botao-nav-carrossel:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.botao-nav-carrossel:disabled:hover {
  background: var(--borda-gradiente-onix);
  transform: none;
}

.botao-nav-carrossel:disabled:hover::before {
  background: var(--preto-sinistro-1);
}

.botao-nav-carrossel ion-icon {
  --ionicon-stroke-width: 50px;
}

.lista-depoimentos {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 15px;
  margin: 0 -15px;
  padding: 25px 15px;
  padding-bottom: 35px;
  overflow-x: auto;
  scroll-behavior: smooth;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
}

.item-depoimentos {
  min-width: 100%;
  scroll-snap-align: center;
}

.caixa-avatar-depoimentos {
  width: 60px;
  height: 60px;
  border-radius: 20px;
  margin: 0 auto 20px;
  box-shadow: var(--sombra-1);
  overflow: hidden;
}

.titulo-item-depoimentos {
  margin-bottom: 10px;
  font-size: var(--fs-4);
}

.subtitulo-item-depoimentos {
  margin-bottom: 20px;
  font-size: var(--fs-7);
  color: var(--cinza-claro-70);
}

.texto-depoimentos {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
  display: -webkit-box;
  line-clamp: 4;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/*
  - convite para depoimento
*/

.convite-depoimento .cartao-convite-depoimento {
  position: relative;
  background: var(--bg-gradiente-jato);
  border: 2px dashed var(--amarelo-laranja-crayola);
  color: var(--cinza-claro);
  text-align: center;
  opacity: 0.8;
  transition: var(--transicao-1);
  display: flex;
  flex-direction: column;
  height: 100%;
}

.convite-depoimento .cartao-convite-depoimento:hover {
  opacity: 1;
  border-color: var(--ouro-vegas);
  transform: translateY(-2px);
}

.convite-depoimento .cartao-convite-depoimento::before {
  background: var(--bg-gradiente-jato);
}

.icone-convite-depoimento {
  width: 60px;
  height: 60px;
  background: var(--borda-gradiente-onix);
  border-radius: 20px;
  margin: 0 auto 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  color: var(--amarelo-laranja-crayola);
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}

.icone-convite-depoimento::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--preto-sinistro-1);
  border-radius: inherit;
  z-index: -1;
}

.titulo-convite-depoimento {
  margin-bottom: 10px;
  font-size: var(--fs-4);
  color: var(--branco-2);
  font-weight: var(--fw-500);
  flex-shrink: 0;
}

.subtitulo-convite-depoimento {
  margin-bottom: 20px;
  font-size: var(--fs-7);
  color: var(--cinza-claro-70);
  font-weight: var(--fw-400);
  flex-shrink: 0;
}

.texto-convite-depoimento {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
  margin-bottom: 25px;
  display: -webkit-box;
  line-clamp: 4;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.botao-enviar-depoimento {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--borda-gradiente-onix);
  color: var(--amarelo-laranja-crayola);
  padding: 10px 16px;
  border-radius: 8px;
  font-size: var(--fs-7);
  font-weight: var(--fw-400);
  text-decoration: none;
  transition: var(--transicao-1);
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  margin-top: auto;
}

.botao-enviar-depoimento::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: var(--preto-sinistro-1);
  border-radius: inherit;
  z-index: -1;
  transition: var(--transicao-1);
}

.botao-enviar-depoimento:hover {
  transform: translateY(-1px);
  color: var(--ouro-vegas);
}

.botao-enviar-depoimento:hover::before {
  background: var(--bg-gradiente-amarelo-2);
}

.botao-enviar-depoimento ion-icon {
  font-size: 16px;
}

/*
  - modal dos depoimentos
*/

.container-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow-y: auto;
  overscroll-behavior: contain;
  z-index: 20;
  pointer-events: none;
  visibility: hidden;
}

.container-modal::-webkit-scrollbar {
  display: none;
}

.container-modal.active {
  pointer-events: all;
  visibility: visible;
}

.sobreposicao {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: hsl(0, 0%, 5%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 1;
  transition: var(--transicao-1);
}

.sobreposicao.active {
  opacity: 0.8;
  visibility: visible;
  pointer-events: all;
}

.modal-depoimentos {
  background: var(--preto-sinistro-2);
  position: relative;
  padding: 15px;
  margin: 15px;
  border: 1px solid var(--jato);
  border-radius: 14px;
  box-shadow: var(--sombra-5);
  transform: scale(1.2);
  opacity: 0;
  transition: var(--transicao-1);
  z-index: 2;
}

.container-modal.active .modal-depoimentos {
  transform: scale(1);
  opacity: 1;
}

.botao-fechar-modal {
  position: absolute;
  top: 15px;
  right: 15px;
  background: var(--onix);
  border-radius: 8px;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--branco-2);
  font-size: 18px;
  opacity: 0.7;
}

.botao-fechar-modal:hover,
.botao-fechar-modal:focus {
  opacity: 1;
}

.botao-fechar-modal ion-icon {
  --ionicon-stroke-width: 50px;
}

.caixa-avatar-modal {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  margin: 0 auto;
  margin-bottom: 24px;
  overflow: hidden;
  box-shadow: var(--sombra-2);
}

.wrapper-img-modal>img {
  display: none;
}

.titulo-modal {
  margin-bottom: 4px;
}

.subtitulo-modal {
  color: var(--cinza-claro);
  font-size: var(--fs-7);
  font-weight: var(--fw-300);
  margin-bottom: 10px;
  opacity: 0.8;
  font-style: italic;
}

.conteudo-modal time {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  margin-bottom: 10px;
}

.conteudo-modal p {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
}

/*
  - clientes
*/

.clientes {
  margin-bottom: 15px;
}

.titulo-clientes {
  margin-bottom: 0;
}

.lista-clientes {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 15px;
  margin: 0 -15px;
  padding: 25px;
  padding-bottom: 25px;
  overflow-x: auto;
  scroll-behavior: smooth;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  scroll-padding-inline: 25px;
}

.item-clientes {
  min-width: 50%;
  scroll-snap-align: start;
}

.item-clientes img {
  width: 100%;
  filter: grayscale(1);
  transition: var(--transicao-1);
}

.item-clientes img:hover {
  filter: grayscale(0);
}

/*
  - parceiros
*/

.parceiros {
  margin-bottom: 15px;
}

.titulo-parceiros {
  margin-bottom: 0;
}

.lista-parceiros {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 15px;
  margin: 0 -15px;
  padding: 25px;
  padding-bottom: 25px;
  overflow-x: auto;
  scroll-behavior: smooth;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  scroll-padding-inline: 25px;
}

.item-parceiros {
  min-width: 50%;
  scroll-snap-align: start;
}

.item-parceiros img {
  width: 100%;
  filter: grayscale(1);
  transition: var(--transicao-1);
}

.item-parceiros img:hover {
  filter: grayscale(0);
}

/*-----------------------------------*\
  #CURRÍCULO
\*-----------------------------------*/

.titulo-artigo {
  margin-bottom: 30px;
}

/*
  - educação e experiência
*/

.linha-tempo {
  margin-bottom: 30px;
}

.wrapper-titulo {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 25px;
}

.lista-linha-tempo {
  font-size: var(--fs-6);
  margin-left: 45px;
}

.item-linha-tempo {
  position: relative;
}

.item-linha-tempo:not(:last-child) {
  margin-bottom: 20px;
}

.titulo-item-linha-tempo {
  font-size: var(--fs-6);
  line-height: 1.3;
  margin-bottom: 7px;
}

.lista-linha-tempo span {
  color: var(--ouro-vegas);
  font-weight: var(--fw-400);
  line-height: 1.6;
}

.item-linha-tempo:not(:last-child)::before {
  content: "";
  position: absolute;
  top: -25px;
  left: -30px;
  width: 1px;
  height: calc(100% + 50px);
  background: var(--jato);
}

.item-linha-tempo::after {
  content: "";
  position: absolute;
  top: 5px;
  left: -33px;
  height: 6px;
  width: 6px;
  background: var(--texto-gradiente-amarelo);
  border-radius: 50%;
  box-shadow: 0 0 0 4px var(--jato);
}

.texto-linha-tempo {
  color: var(--cinza-claro);
  font-weight: var(--fw-300);
  line-height: 1.6;
}

/*
  - habilidades
*/

.titulo-habilidades {
  margin-bottom: 20px;
}

.lista-habilidades {
  padding: 20px;
}


.item-habilidades:not(:last-child) {
  margin-bottom: 15px;
}

.habilidade .wrapper-titulo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.habilidade .wrapper-titulo data {
  color: var(--cinza-claro);
  font-size: var(--fs-7);
  font-weight: var(--fw-300);
}

.fundo-progresso-habilidade {
  background: var(--jato);
  width: 100%;
  height: 8px;
  border-radius: 10px;
}

.preenchimento-progresso-habilidade {
  background: var(--texto-gradiente-amarelo);
  height: 100%;
  border-radius: inherit;
}

/*-----------------------------------*\
  #PORTFÓLIO
\*-----------------------------------*/

.lista-filtro {
  display: none;
}

.caixa-selecao-filtro {
  position: relative;
  margin-bottom: 25px;
}

.selecao-filtro {
  background: var(--preto-sinistro-2);
  color: var(--cinza-claro);
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--jato);
  border-radius: 14px;
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
}

.selecao-filtro.active .icone-selecao {
  transform: rotate(0.5turn);
}

.lista-selecao {
  background: var(--preto-sinistro-2);
  position: absolute;
  top: calc(100% + 6px);
  width: 100%;
  padding: 6px;
  border: 1px solid var(--jato);
  border-radius: 14px;
  z-index: 3;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: 0.15s ease-in-out;
}

.selecao-filtro.active+.lista-selecao {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.item-selecao button {
  background: var(--preto-sinistro-2);
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  width: 100%;
  padding: 8px 10px;
  border-radius: 8px;
}

.item-selecao button:hover {
  --preto-sinistro-2: hsl(240, 2%, 20%);
}

.lista-projetos {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  margin-bottom: 10px;
}

.item-projeto {
  display: none;
}

.item-projeto.active {
  display: block;
  animation: scaleUp 0.25s ease forwards;
}

@keyframes scaleUp {
  0% {
    transform: scale(0.5);
  }

  100% {
    transform: scale(1);
  }
}

.item-projeto>a {
  width: 100%;
}

.img-projeto {
  position: relative;
  width: 100%;
  height: 200px;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 15px;
}

.img-projeto::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  z-index: 1;
  transition: var(--transicao-1);
}

.item-projeto>a:hover .img-projeto::before {
  background: hsla(0, 0%, 0%, 0.5);
}

.caixa-icone-item-projeto {
  --scale: 0.8;

  background: var(--preto-sinistro-2);
  color: var(--amarelo-laranja-crayola);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(var(--scale));
  font-size: 20px;
  padding: 18px;
  border-radius: 12px;
  opacity: 0;
  z-index: 1;
  transition: var(--transicao-1);
}

.item-projeto>a:hover .caixa-icone-item-projeto {
  --scale: 1;
  opacity: 1;
}

.caixa-icone-item-projeto ion-icon {
  --ionicon-stroke-width: 50px;
}

.img-projeto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transicao-1);
}

.item-projeto>a:hover img {
  transform: scale(1.1);
}

.titulo-projeto,
.categoria-projeto {
  margin-left: 10px;
}

.titulo-projeto {
  color: var(--branco-2);
  font-size: var(--fs-5);
  font-weight: var(--fw-400);
  line-height: 1.3;
}

.categoria-projeto {
  color: var(--cinza-claro-70);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
}

/*-----------------------------------*\
  #BLOG
\*-----------------------------------*/

.posts-blog {
  margin-bottom: 10px;
}

.lista-posts-blog {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

.item-post-blog>a {
  position: relative;
  background: var(--borda-gradiente-onix);
  height: 100%;
  box-shadow: var(--sombra-4);
  border-radius: 16px;
  z-index: 1;
}

.item-post-blog>a::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: var(--preto-sinistro-1);
  z-index: -1;
}

.caixa-banner-blog {
  width: 100%;
  height: 200px;
  border-radius: 12px;
  overflow: hidden;
}

.caixa-banner-blog img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transicao-1);
}

.item-post-blog>a:hover .caixa-banner-blog img {
  transform: scale(1.1);
}

.conteudo-blog {
  padding: 15px;
}

.meta-blog {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 7px;
  margin-bottom: 10px;
}

.meta-blog :is(.categoria-blog, time) {
  color: var(--cinza-claro-70);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
}

.meta-blog .ponto {
  background: var(--cinza-claro-70);
  width: 4px;
  height: 4px;
  border-radius: 4px;
}

.titulo-item-blog {
  margin-bottom: 10px;
  line-height: 1.3;
  transition: var(--transicao-1);
}

.item-post-blog>a:hover .titulo-item-blog {
  color: var(--amarelo-laranja-crayola);
}

.texto-blog {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
  display: -webkit-box;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/*-----------------------------------*\
  #CONTATO
\*-----------------------------------*/

/* Seção de convite para contato */
.convite-contato {
  margin-bottom: 30px;
}

.texto-convite {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.titulo-convite {
  color: var(--branco-1);
  margin-bottom: 15px;
}

.descricao-convite {
  color: var(--cinza-claro-70);
  font-size: var(--fs-6);
  line-height: 1.6;
  margin-bottom: 15px;
}

.chamada-convite {
  color: var(--branco-2);
  font-size: var(--fs-5);
}

.chamada-convite strong {
  color: var(--amarelo-laranja-crayola);
}

/* Seção de canais de contato */
.canais-contato {
  margin-bottom: 30px;
}

.titulo-canais {
  color: var(--branco-1);
  margin-bottom: 20px;
  text-align: center;
}

.lista-canais-contato {
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
}

.item-canal-contato {
  background: var(--bg-gradiente-jato);
  border: 1px solid var(--jato);
  border-radius: 16px;
  transition: var(--transicao-1);
}

.item-canal-contato:hover {
  border-color: var(--amarelo-laranja-crayola);
  transform: translateY(-2px);
  box-shadow: var(--sombra-2);
}

.link-canal-contato {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 20px;
  color: var(--branco-2);
  transition: var(--transicao-1);
}

.caixa-icone-canal {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  background: var(--borda-gradiente-onix);
  border-radius: 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 24px;
  transition: var(--transicao-1);
}

.info-canal {
  flex: 1;
}

.titulo-canal {
  color: var(--branco-1);
  font-size: var(--fs-5);
  font-weight: var(--fw-500);
  margin-bottom: 4px;
}

.descricao-canal {
  color: var(--cinza-claro-70);
  font-size: var(--fs-7);
  margin-bottom: 6px;
}

.numero-contato,
.usuario-contato,
.email-contato {
  color: var(--amarelo-laranja-crayola);
  font-size: var(--fs-6);
  font-weight: var(--fw-500);
}

/* Estilos específicos por plataforma */
.item-canal-contato.whatsapp:hover .caixa-icone-canal {
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color: var(--branco-1);
}

.item-canal-contato.telegram:hover .caixa-icone-canal {
  background: linear-gradient(135deg, #0088cc 0%, #006bb3 100%);
  color: var(--branco-1);
}

.item-canal-contato.discord:hover .caixa-icone-canal {
  background: linear-gradient(135deg, #7289da 0%, #5b6eae 100%);
  color: var(--branco-1);
}

.item-canal-contato.instagram:hover .caixa-icone-canal {
  background: linear-gradient(135deg, #E4405F 0%, #833AB4 50%, #F77737 100%);
  color: var(--branco-1);
}

.item-canal-contato.linkedin:hover .caixa-icone-canal {
  background: linear-gradient(135deg, #0077B5 0%, #005885 100%);
  color: var(--branco-1);
}

.item-canal-contato.email:hover .caixa-icone-canal {
  background: var(--bg-gradiente-amarelo-1);
  color: var(--preto-esfumacado);
}

/* Seção CTA */
.cta-contato {
  margin-top: 40px;
}

.cartao-cta {
  background: var(--bg-gradiente-jato);
  border: 1px solid var(--jato);
  border-radius: 16px;
  padding: 30px;
  text-align: center;
}

.titulo-cta {
  color: var(--amarelo-laranja-crayola);
  margin-bottom: 15px;
}

.texto-cta {
  color: var(--cinza-claro-70);
  font-size: var(--fs-6);
  line-height: 1.6;
  margin-bottom: 20px;
}

.horario-atendimento {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--ouro-vegas);
  font-size: var(--fs-7);
  font-weight: var(--fw-500);
}

.horario-atendimento ion-icon {
  font-size: 16px;
}

/*-----------------------------------*\
  #RESPONSIVO
\*-----------------------------------*/

/**
 * telas responsivas maiores que 450px
 */

@media (min-width: 450px) {

  /**
   * clientes
   */

  .item-clientes {
    min-width: calc(33.33% - 10px);
  }

  .item-parceiros {
    min-width: calc(33.33% - 10px);
  }

  /**
   * PORTFÓLIO, BLOG
   */

  .img-projeto,
  .caixa-banner-blog {
    border-radius: 16px;
  }

}

/**
 * telas responsivas maiores que 580px
 */

@media (min-width: 580px) {

  /**
   * PROPRIEDADES PERSONALIZADAS
   */

  :root {

    /**
     * tipografia
     */

    /* tamanho da fonte */
    --fs-1: 32px;
    --fs-2: 24px;
    --fs-3: 26px;
    --fs-4: 18px;
    --fs-6: 15px;
    --fs-7: 15px;
    --fs-8: 12px;

  }

  /**
   * ESTILO REUTILIZADO
   */

  .barra-lateral,
  article {
    width: 520px;
    margin: auto;
    padding: 30px;
  }

  .titulo-artigo {
    font-weight: var(--fw-600);
    padding-bottom: 15px;
  }

  .titulo-artigo::after {
    width: 40px;
    height: 5px;
  }

  .caixa-icone {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    font-size: 18px;
  }

  /**
   * PRINCIPAL
   */

  main {
    margin-top: 60px;
    margin-bottom: 100px;
  }

  /**
   * BARRA LATERAL
   */

  .barra-lateral {
    max-height: 180px;
    margin-bottom: 30px;
  }

  .barra-lateral.active {
    max-height: 584px;
  }

  .info-barra-lateral {
    gap: 25px;
  }

  .caixa-avatar {
    border-radius: 20px;
  }

  .caixa-avatar img {
    width: 120px;
    border-radius: 20px;
  }

  .conteudo-info .nome {
    margin-bottom: 15px;
  }

  .conteudo-info .titulo {
    padding: 5px 18px;
  }

  .botao-mais-info {
    top: 0;
    right: 0;
    padding: 10px 15px;
  }

  .botao-mais-info span {
    display: block;
    font-size: var(--fs-8);
  }

  .botao-mais-info ion-icon {
    display: none;
  }

  .separador {
    margin: 32px 0;
  }

  .lista-contatos {
    gap: 20px;
  }

  .info-contato {
    max-width: calc(100% - 64px);
    width: calc(100% - 64px);
  }

  /**
   * BARRA DE NAVEGAÇÃO
   */

  .barra-navegacao {
    border-radius: 20px 20px 0 0;
  }

  .lista-barra-navegacao {
    gap: 20px;
  }

  .link-barra-navegacao {
    --fs-8: 14px;
  }

  /**
   * SOBRE
   */

  .sobre .titulo-artigo {
    margin-bottom: 20px;
  }

  /* Responsivo para logo */
  .logo-aolhonu {
    max-width: 100px;
  }

  .texto-sobre {
    margin-bottom: 40px;
  }

  /* serviço */

  .item-servico {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 18px;
    padding: 30px;
  }

  .caixa-icone-servico {
    margin-bottom: 0;
    margin-top: 5px;
  }

  .caixa-conteudo-servico {
    text-align: left;
  }

  /* depoimentos */

  .wrapper-cabecalho-navegacao {
    margin-bottom: 25px;
  }

  .botao-nav-carrossel {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    font-size: 18px;
  }

  .lista-depoimentos {
    gap: 30px;
    margin: 0 -30px;
    padding: 30px;
    padding-bottom: 35px;
  }

  .cartao-conteudo {
    padding: 30px;
    border-radius: 20px;
  }

  .caixa-avatar-depoimentos {
    width: 80px;
    height: 80px;
    border-radius: 20px;
  }

  .caixa-avatar-depoimentos img {
    width: 80px;
    border-radius: 20px;
  }

  .titulo-item-depoimentos {
    margin-bottom: 10px;
    font-size: var(--fs-4);
  }

  .subtitulo-item-depoimentos {
    margin-bottom: 20px;
    font-size: var(--fs-7);
    color: var(--cinza-claro-70);
  }

  .texto-depoimentos {
    line-clamp: 2;
    -webkit-line-clamp: 2;
  }

  /* convite para depoimento */

  .icone-convite-depoimento {
    width: 80px;
    height: 80px;
    border-radius: 20px;
    font-size: 24px;
    margin-bottom: 25px;
  }

  .titulo-convite-depoimento {
    font-size: var(--fs-4);
    margin-bottom: 15px;
  }

  .subtitulo-convite-depoimento {
    font-size: var(--fs-7);
    margin-bottom: 25px;
  }

  .texto-convite-depoimento {
    margin-bottom: 30px;
  }

  .botao-enviar-depoimento {
    padding: 12px 20px;
    font-size: var(--fs-6);
    gap: 10px;
    border-radius: 10px;
  }

  .botao-enviar-depoimento ion-icon {
    font-size: 18px;
  }

  /* modal dos depoimentos */

  .container-modal {
    padding: 20px;
  }

  .modal-depoimentos {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 25px;
    padding: 30px;
    border-radius: 20px;
  }

  .wrapper-img-modal {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .caixa-avatar-modal {
    border-radius: 20px;
    margin-bottom: 0;
  }

  .caixa-avatar-modal img {
    width: 65px;
  }

  .wrapper-img-modal>img {
    display: block;
    flex-shrink: 0;
    width: 35px;
    margin-left: -10px;
    margin-top: 25px;
  }

  /* clientes */

  .lista-clientes {
    gap: 50px;
    margin: 0 -30px;
    padding: 45px;
    scroll-padding-inline: 45px;
  }

  .item-clientes {
    min-width: calc(33.33% - 35px);
  }

  /* parceiros */

  .lista-parceiros {
    gap: 50px;
    margin: 0 -30px;
    padding: 45px;
    scroll-padding-inline: 45px;
  }

  .item-parceiros {
    min-width: calc(33.33% - 35px);
  }

  /**
   * CURRÍCULO
   */

  .lista-linha-tempo {
    margin-left: 65px;
  }

  .item-linha-tempo:not(:last-child)::before {
    left: -40px;
  }

  .item-linha-tempo::after {
    height: 8px;
    width: 8px;
    left: -43px;
  }

  .item-habilidades:not(:last-child) {
    margin-bottom: 25px;
  }

  /**
   * PORTFÓLIO, BLOG
   */

  .img-projeto,
  .caixa-banner-blog {
    border-radius: 16px;
  }

  .lista-posts-blog {
    gap: 30px;
  }

  .conteudo-blog {
    padding: 25px;
  }

  /**
   * CONTATO
   */

  .caixa-mapa {
    height: 380px;
    border-radius: 18px;
  }

  .wrapper-entrada {
    gap: 30px;
    margin-bottom: 30px;
  }

  .entrada-formulario {
    padding: 15px 20px;
  }

  textarea.entrada-formulario {
    margin-bottom: 30px;
  }

  .botao-formulario {
    --fs-6: 16px;
    padding: 16px 20px;
  }

  .botao-formulario ion-icon {
    font-size: 18px;
  }

  /* modal do blog */

  .container-modal-blog {
    padding: 20px;
  }

  .modal-blog {
    padding: 30px;
    border-radius: 20px;
    max-width: 900px;
  }

  .caixa-banner-modal-blog {
    height: 250px;
    border-radius: 20px;
  }

  .wrapper-img-modal {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

}

/**
 * telas responsivas maiores que 768px
 */

@media (min-width: 768px) {

  /**
   * ESTILO REUTILIZADO
   */

  .barra-lateral,
  article {
    width: 700px;
  }

  .tem-barra-rolagem::-webkit-scrollbar-button {
    width: 100px;
  }

  /**
   * BARRA LATERAL
   */

  .lista-contatos {
    grid-template-columns: 1fr 1fr;
    gap: 30px 15px;
  }

  /**
   * BARRA DE NAVEGAÇÃO
   */

  .link-barra-navegacao {
    --fs-8: 15px;
  }

  /**
   * SOBRE
   */

  /* modal dos depoimentos */

  .modal-depoimentos {
    gap: 35px;
    max-width: 680px;
  }

  .caixa-avatar-modal img {
    width: 80px;
  }

  /**
   * PORTFÓLIO
   */

  .titulo-artigo {
    padding-bottom: 20px;
  }

  /* Logo responsivo para telas de 768px */
  .logo-aolhonu {
    max-width: 100px;
  }

  .caixa-selecao-filtro {
    display: none;
  }

  .lista-filtro {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 25px;
    padding-left: 5px;
    margin-bottom: 30px;
  }

  .item-filtro button {
    color: var(--cinza-claro);
    font-size: var(--fs-5);
    transition: var(--transicao-1);
  }

  .item-filtro button:hover {
    color: var(--cinza-claro-70);
  }

  .item-filtro button.active {
    color: var(--amarelo-laranja-crayola);
  }

  /**
   * PORTFÓLIO, BLOG
   */

  .lista-projetos,
  .lista-posts-blog {
    grid-template-columns: 1fr 1fr;
  }

  /**
   * CONTATO
   */

  .lista-canais-contato {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

}

/**
 * telas responsivas maiores que 1024px
 */

@media (min-width: 1024px) {

  /**
   * PROPRIEDADES PERSONALIZADAS
   */

  :root {

    /**
    * sombra
    */
    --sombra-1: -4px 8px 24px hsla(0, 0%, 0%, 0.125);
    --sombra-2: 0 16px 30px hsla(0, 0%, 0%, 0.125);
    --sombra-3: 0 16px 40px hsla(0, 0%, 0%, 0.125);

  }

  /**
   * ESTILO REUTILIZADO
   */

  .barra-lateral,
  article {
    width: 950px;
    box-shadow: var(--sombra-5);
  }

  /**
   * PRINCIPAL 
   */

  main {
    margin-bottom: 60px;
  }

  .conteudo-principal {
    position: relative;
    width: max-content;
    margin: auto;
  }

  /**
   * BARRA DE NAVEGAÇÃO
   */

  .barra-navegacao {
    position: absolute;
    bottom: auto;
    top: 0;
    left: auto;
    right: 0;
    width: max-content;
    border-radius: 0 20px;
    padding: 0 20px;
    box-shadow: none;
  }

  .lista-barra-navegacao {
    gap: 30px;
    padding: 0 20px;
  }

  .link-barra-navegacao {
    font-weight: var(--fw-500);
  }

  /**
   * SOBRE
   */

  /* serviço */

  .lista-servicos {
    grid-template-columns: 1fr 1fr;
    gap: 20px 25px;
  }

  /* logo responsivo */
  .logo-aolhonu {
    max-width: 100px;
  }

  /* depoimentos */

  .item-depoimentos {
    min-width: calc(50% - 15px);
  }

  /* clientes */

  .item-clientes {
    min-width: calc(25% - 38px);
  }

  /* parceiros */

  .item-parceiros {
    min-width: calc(25% - 38px);
  }

  /**
   * PORTFÓLIO
   */

  .lista-projetos {
    grid-template-columns: repeat(3, 1fr);
  }

  /**
   * BLOG
   */

  .caixa-banner-blog {
    height: 230px;
  }

  /**
   * CONTATO
   */

  .lista-canais-contato {
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
  }

}

/**
 * telas responsivas maiores que 1250px
 */

@media (min-width: 1250px) {

  /**
   * RESET
   */

  body::-webkit-scrollbar {
    width: 5px;
    /* para barra de rolagem vertical */
    height: 5px;
    /* para barra de rolagem horizontal */
  }

  body::-webkit-scrollbar-track {
    background: var(--onix);
    border-radius: 5px;
  }

  body::-webkit-scrollbar-thumb {
    background: var(--amarelo-laranja-crayola);
    border-radius: 5px;
  }

  body::-webkit-scrollbar-button {
    width: 20px;
  }

  /**
   * ESTILO REUTILIZADO
   */

  .barra-lateral,
  article {
    width: auto;
  }

  article {
    min-height: 100%;
  }

  /**
   * PRINCIPAL
   */

  main {
    max-width: 1200px;
    margin-inline: auto;
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 25px;
  }

  .conteudo-principal {
    min-width: 75%;
    width: 75%;
    margin: 0;
  }

  /**
   * BARRA LATERAL
   */

  .barra-lateral {
    position: sticky;
    top: 60px;
    max-height: max-content;
    width: 25%;
    margin: 0;
    overflow: visible;
    padding-block: 30px;
  }

  .info-barra-lateral {
    flex-direction: column;
  }

  .caixa-avatar img {
    width: 150px;
  }

  .conteudo-info .nome {
    white-space: nowrap;
    text-align: center;
  }

  .conteudo-info .titulo {
    margin: auto;
  }

  .botao-mais-info {
    display: none;
  }

  .mais-info-barra-lateral {
    opacity: 1;
    visibility: visible;
  }

  .lista-contatos {
    grid-template-columns: 1fr;
  }

  .info-contato :is(.link-contato) {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .info-contato :is(.link-contato, time, address) {
    --fs-7: 14px;
    font-weight: var(--fw-300);
  }

  .separador:last-of-type {
    margin: 15px 0;
    opacity: 0;
  }

  .lista-social {
    justify-content: center;
  }

  /**
   * CURRÍCULO
   */

  .texto-linha-tempo {
    max-width: 700px;
  }

}

/*-----------------------------------*\
  #CURSOR PERSONALIZADO
\*-----------------------------------*/

/* ocultar cursor padrão em elementos interativos */
a,
button,
input,
textarea,
select {
  cursor: none !important;
}

/* efeitos hover para elementos interativos com cursor personalizado */
a:hover,
button:hover {
  transition: var(--transicao-1);
}

/* cursor personalizado para dispositivos móveis - mostrar cursor padrão */
@media (hover: none) and (pointer: coarse) {
  body {
    cursor: auto !important;
  }

  a,
  button,
  input,
  textarea,
  select {
    cursor: auto !important;
  }

  .cursor-bolinha {
    display: none !important;
  }

  /* ajustes dos botões de navegação para mobile */
  .wrapper-cabecalho-navegacao {
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
  }

  .botoes-navegacao-carrossel {
    align-self: flex-end;
  }
}

/*
  - modal do blog
*/

.container-modal-blog {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overflow-y: auto;
  overflow-x: hidden;
  z-index: 20;
  transition: var(--transicao-1);
}

.container-modal-blog::-webkit-scrollbar {
  display: none;
}

.container-modal-blog.active {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.sobreposicao-blog {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--preto-sinistro);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 1;
  transition: var(--transicao-1);
}

.sobreposicao-blog.active {
  opacity: 0.8;
  visibility: visible;
  pointer-events: all;
}

.modal-blog {
  background: var(--preto-sinistro-2);
  position: relative;
  padding: 15px;
  margin: 15px;
  border: 1px solid var(--jato);
  border-radius: 14px;
  box-shadow: var(--sombra-5);
  transform: scale(1.2);
  opacity: 0;
  transition: var(--transicao-1);
  z-index: 2;
  max-width: 800px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
}

.container-modal-blog.active .modal-blog {
  transform: scale(1);
  opacity: 1;
}

.botao-fechar-modal-blog {
  position: absolute;
  top: 15px;
  right: 15px;
  background: var(--onix);
  border-radius: 8px;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--branco-2);
  font-size: 18px;
  opacity: 0.7;
  z-index: 3;
}

.botao-fechar-modal-blog:hover,
.botao-fechar-modal-blog:focus {
  opacity: 1;
}

.botao-fechar-modal-blog ion-icon {
  --ionicon-stroke-width: 50px;
}

.caixa-banner-modal-blog {
  width: 100%;
  height: 200px;
  border-radius: 16px;
  margin: 0 auto;
  margin-bottom: 24px;
  overflow: hidden;
  box-shadow: var(--sombra-2);
}

.caixa-banner-modal-blog img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wrapper-img-modal-blog > img {
  display: none;
}

.meta-modal-blog {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
}

.categoria-modal-blog {
  color: var(--amarelo-laranja-crayola);
  font-size: var(--fs-7);
  font-weight: var(--fw-500);
}

.meta-modal-blog .ponto {
  background: var(--cinza-claro);
  width: 3px;
  height: 3px;
  border-radius: 50%;
}

.meta-modal-blog time {
  color: var(--cinza-claro);
  font-size: var(--fs-7);
  font-weight: var(--fw-300);
}

.titulo-modal-blog {
  color: var(--branco-1);
  margin-bottom: 20px;
}

.texto-modal-blog {
  color: var(--cinza-claro);
  font-size: var(--fs-6);
  font-weight: var(--fw-300);
  line-height: 1.6;
  max-height: 400px;
  overflow-y: auto;
  padding-right: 10px;
}

.texto-modal-blog::-webkit-scrollbar {
  width: 5px;
}

.texto-modal-blog::-webkit-scrollbar-track {
  background: var(--onix);
  border-radius: 5px;
}

.texto-modal-blog::-webkit-scrollbar-thumb {
  background: var(--amarelo-laranja-crayola);
  border-radius: 5px;
}

.texto-modal-blog::-webkit-scrollbar-button {
  display: none;
}

.texto-modal-blog p {
  margin-bottom: 15px;
}

.texto-modal-blog p:last-child {
  margin-bottom: 0;
}

.texto-modal-blog strong {
  color: var(--amarelo-laranja-crayola);
  font-weight: var(--fw-500);
}

/* Estilos responsivos adicionais para o modal do blog */

@media (min-width: 768px) {
  
  /* modal do blog responsivo */
  .modal-blog {
    max-width: 750px;
    padding: 40px;
  }

  .caixa-banner-modal-blog {
    height: 300px;
  }

  .texto-modal-blog {
    max-height: 500px;
  }
  
}