html {
  margin: auto;
}
body {
  /* border: 2px solid black; */
  margin: auto;
  transform-origin: top left !important;
  overflow-x: hidden !important;
}
.container {
  max-width: none !important;
  padding: 0;
}
#responsivo {
  transform-origin: top left;
  /* border: 3px solid red; */
  box-sizing: border-box;
}

body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #404040;
}
.cursor-pointer {
  cursor: pointer !important;
}

div.max-area {
  width: 100%;
  /* max-width: 1400px; */
  margin: 0 auto;
  min-width: 320px;
  max-width: 1140px;
}

div.hrsite {
  width: 100%;
  background-color: #f1f1f1;
  height: 1px;
  margin-top: -12px;
}

nav a {
  text-decoration: none;
  color: #666666;
  text-transform: uppercase;
  /* border: 1px solid green; */
  padding: 38px 26px 0px 0px;
  font-size: 13px;
  font-weight: 600;
  font-family: "open sans" !important;
  transition: color 0.5s;
}
nav a.active,
nav a:hover {
  color: #333333;
  font-weight: 600;
}
nav a:last-child {
  padding-right: 0px;
}

nav .dropdown-menu {
  border-radius: 0px;
  border: none;
  background-color: #ffffff;
  padding: 37px 0 0 0;
  text-align: start;
  /* margin-top: -2px !important; */
  width: 227px;
}
nav .dropdown-menu a {
  color: #666666;
  border-top: solid 1px #cccccc;
  border: solid 1px #cccccc;
  border-bottom: 0;
  font-family: "Raleway";
  font-size: 12px;
  text-transform: none;
  transition-duration: 0.5s;
  padding: 10px 16px;
  text-wrap: wrap;
}
nav .dropdown-menu a:last-child {
  border-bottom: solid 1px #cccccc;
}
nav .dropdown-menu a:hover,
nav .dropdown-menu a.active {
  font-weight: normal;
  color: #666666;
  background-color: #ffffff;
}
.desktop .dropdown:hover .dropdown-menu {
  display: block;
}
.carousel {
  max-width: 1600px;
  margin: 0 auto;
}

/* 1. Posicionamento da Caixa de Texto (Tirando do centro e jogando pra esquerda) */
#carousel-topo .carousel-caption {
  position: absolute;
  top: 12%; /* Ajuste a altura em que o texto começa */
  left: 1.8%; /* Distância da borda esquerda */
  right: auto;
  text-align: left !important;
  width: 96.66666666666666%;
  padding: 0 95px;
}

/* 2. Estilo dos Textos (Usando a Pathway Gothic One) */
#carousel-topo .carousel-caption .titulo {
  font-family: "Pathway Gothic One", sans-serif;
  font-size: 35.7px; /* Ajuste conforme a necessidade */
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin-bottom: 30px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5); /* Sombra para o texto não sumir no fundo claro */
}

#carousel-topo .carousel-caption .subtitulo {
  font-family: "Pathway Gothic One", sans-serif;
  font-size: 31.3px;
  text-transform: uppercase;
  margin-bottom: 30px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
}

/* 3. O Terceiro Texto com a Linha Branca em cima */
#carousel-topo .carousel-caption .texto {
  font-family: "Pathway Gothic One", sans-serif;
  font-size: 31.3px;
  text-transform: uppercase;
  padding-top: 15px; /* Espaço entre a linha e o texto */
  position: relative;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
}

/* Criando a linha branca fina automaticamente via CSS */
#carousel-topo .carousel-caption .texto::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 90px; /* Largura da linha */
  height: 1px; /* Espessura da linha */
  background-color: #ffffff;
}

/* 4. Customização das Bolinhas (Indicators) para ficarem vazadas */
#carousel-topo .carousel-indicators {
  bottom: 20px;
  margin-bottom: 18px;
}

#carousel-topo .carousel-indicators button {
  width: 25px;
  height: 25px;
  border-radius: 50%; /* Deixa redondo */
  border: 1px solid #ffffff; /* Borda branca */
  background-color: transparent; /* Miolo transparente */
  margin: 0 6px;
  opacity: 1; /* Tira a opacidade padrão do Bootstrap */
}

/* A bolinha selecionada ganha o miolo branco */
#carousel-topo .carousel-indicators button.active {
  background-color: #ffffff;
}

.logotipo {
  height: 92px;
  padding: 34px 15px 0 45px;
}

main .titulo,
footer .titulo {
  font-family: "Pathway Gothic One" !important;
  font-size: 35.7px;
  font-weight: 500;
}
main .subtitulo {
  font-family: "Pathway Gothic One" !important;
  font-size: 35.7px;
  font-weight: 500;
  text-transform: uppercase;
  color: #ffffff;
}
main .texto,
footer .texto {
  font-family: "Pathway Gothic One" !important;
  font-size: 35.7px;
  font-weight: normal;
  color: #ffffff;
}
main .texto.pequeno {
  font-size: 16px;
}
main .texto.pequeno p {
  margin-bottom: 0px;
}
.botao-vermais {
  background-color: #cc3333;
  border: 4px solid #cc3333;
  color: white;
  text-decoration: none;
  font-size: 16px;
  font-family: "Merriweather";
  font-weight: bold;
  transition-duration: 0.5s;
  padding: 8px 25px;
}
.botao-vermais:hover {
  background-color: white;
  color: #cc3333;
}
.botao-vermais.grande {
  font-size: 24px;
}

.desktop .lista-caixa-projetos {
  gap: 100px 100px;
}
.desktop .caixa-projeto {
  width: fit-content;
}
.desktop .caixa-projeto .titulo {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  color: white;
  font-size: 28px;
  width: 480px;
  height: 292.4px;
  text-transform: uppercase;
  color: transparent;
  cursor: pointer;
  box-shadow: 0px 0px 5px 2px rgba(0, 0, 0, 0.5);
}
.desktop .caixa-projeto:hover .titulo div,
.desktop .caixa-projeto.activo .titulo div {
  color: white;
  background-color: rgba(0, 0, 0, 0.6);
  padding: 0px 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.desktop .caixa-projeto .botao-vermais {
  display: inline-block;
  cursor: pointer;
}
.desktop .paginacao a {
  background-color: #cc3333;
  color: white;
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 45px;
  height: 45px;
  font-size: 25px;
  font-family: "Raleway";
  font-weight: normal;
  cursor: pointer;
  transition-duration: 0.5s;
  border: 3px solid #cc3333;
}
.desktop .paginacao a:hover,
.desktop .paginacao a.active {
  background-color: white;
  color: #cc3333;
}

.desktop form {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Merriweather";
  font-size: 14px;
  color: #58595b;
}
.desktop .titulo.medio {
  font-size: 35px;
  color: #404040;
}
.desktop form .titulo,
.desktop .titulo.pequeno {
  font-size: 30px;
  color: #404040;
}
.desktop form input:not(input[type="checkbox"]) {
  height: 55px;
}
.desktop form textarea {
  height: 210px;
}
.desktop form > input,
.desktop form textarea {
  width: 540px;
  font-family: "Raleway";
  font-weight: bold;
  background-color: #e6e7e8;
  border: none;
  padding: 15px;
}
.desktop form > div {
  width: 540px;
}
.desktop form input::placeholder,
.desktop form textarea::placeholder {
  text-transform: uppercase;
}

footer.sombra {
  box-shadow: inset 0px 5px 5px 0px rgba(0, 0, 0, 0.25);
}
footer.desktop .lista-destaques {
  display: grid;
  /* Mantido o seu grid, mas se quiser que seja responsivo sem media queries,
     pode usar: grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); */
  grid-template-columns: repeat(3, 1fr);
}

/* Regras unificadas */
footer.desktop .destaque-card {
  height: 666.7px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  color: white;
  text-decoration: none;
  display: block;
  overflow: hidden; /* Evita que o fundo escuro vaze do card */
}

/* --- ESTILOS DO FUNDO ESCURO --- */
footer.desktop .destaque-card .titulo {
  font-family: "Merriweather", serif;
  font-weight: bold;
  font-size: 29px;
  text-transform: uppercase;
  padding: 0px 55px;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;

  /* Estado Inicial do Fundo */
  background-color: rgba(35, 31, 32, 0);
  transition: background-color 0.2s ease-in-out;
}

/* --- ESTILOS DO TEXTO (SPAN) --- */
footer.desktop .destaque-card .titulo span {
  /* Estado inicial (escondido e um pouco para cima) */
  opacity: 0;
  transform: translateY(-15px);
  transition: all 0.2s ease-in-out;
}

/* --- ESTILOS DO ÍCONE DE OLHO --- */
footer.desktop .destaque-card .titulo .icone-olho {
  width: 60px;
  height: 39px;

  /* Estado inicial (escondido e um pouco para baixo) */
  opacity: 0;
  transform: translateY(15px);
  transition: all 0.2s ease-in-out;
}

/* =======================================
   EFEITOS DE HOVER (A MÁGICA ACONTECE AQUI)
   ======================================= */

/* 1. Fundo escurece */
footer.desktop .destaque-card:hover .titulo,
footer.desktop .destaque-card.active .titulo {
  background-color: rgba(35, 31, 32, 0.8);
}

/* 2. Texto desce e aparece / Olho sobe e aparece */
footer.desktop .destaque-card:hover .titulo span,
footer.desktop .destaque-card.active .titulo span,
footer.desktop .destaque-card:hover .titulo .icone-olho,
footer.desktop .destaque-card.active .titulo .icone-olho {
  opacity: 1;
  transform: translateY(0);
}

/* ======================================= */

/* Opcional: Se for usar o botão no futuro, aqui está ele com transição */
footer.desktop .destaque-card .titulo button {
  height: 50px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s ease-in-out;
  transform: translateY(
    15px
  ); /* Coloquei para subir igual o olho, fica mais fluido */
}

footer.desktop .destaque-card:hover .titulo button {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

footer.desktop .contactos {
  color: white;
  height: 664px;
  /* background-image: url("https://interiberia.pt/public/img/fundo-contact-us.jpg"); */
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
footer.desktop .contactos .sombra {
  background-color: rgba(35, 31, 32, 0.8);
}
footer.desktop .contactos .subtitulo {
  font-family: "Raleway";
  font-size: 24px;
  font-weight: bold;
  text-transform: uppercase;
}
footer.desktop .contactos .texto {
  font-family: "Merriweather";
  font-size: 24px;
  font-weight: normal;
  color: white;
}
footer.desktop .contactos p {
  margin: 0px;
}

footer .icones {
  display: inline-block;
  width: fit-content;
  height: 44px;
  box-sizing: border-box;
}
footer .icones:hover {
  opacity: 0.6;
}
footer .icones img {
  height: 100%;
  width: auto;
}
footer .icones.pequenos {
  height: 36px;
}

footer .copyright {
  font-family: "Raleway";
  font-size: 12.8px;
  color: #404040;
}
footer .copyright a {
  color: #404040;
  text-decoration: none;
}
footer .copyright a:hover {
  text-decoration: underline;
}

.desktop .lista-caixa-projetos.especial {
  display: grid;
  grid-template-columns: repeat(
    3,
    1fr
  ); /* Escrita mais limpa que 1fr 1fr 1fr */
  gap: 0px !important;
}

.desktop .caixa-portfolio {
  height: calc(1600px / 3);
  box-sizing: border-box;
  background-position: center;
  background-size: cover; /* Cover mantém a proporção da imagem sem distorcer */
  background-repeat: no-repeat;
  overflow: hidden; /* Evita que animações vazem da caixa */
}

.desktop .caixa-portfolio.grande {
  height: 666.7px !important;
}

/* --- ESTILOS DA SOMBRA E ANIMAÇÃO DE FUNDO --- */
.desktop .caixa-portfolio .sombra {
  background-color: rgba(35, 31, 32, 0); /* Inicia transparente */
  color: white;
  text-decoration: none;
  transition: background-color 0.2s ease-in-out; /* Transição suave */
}

/* Escurece o fundo no hover ou quando focado pelo teclado */
.desktop .caixa-portfolio:hover .sombra,
.desktop .caixa-portfolio:focus .sombra {
  background-color: rgba(35, 31, 32, 0.8);
}

/* --- ESTILOS DO TÍTULO --- */
.desktop .caixa-portfolio .sombra .titulo {
  text-transform: uppercase;
  font-family: "Merriweather", serif; /* Fallback adicionado */
  font-weight: bold;
  font-size: 28px;
  line-height: 30px;

  /* Estado inicial (escondido e um pouco para cima) */
  opacity: 0;
  transform: translateY(-15px);
  transition: all 0.2s ease-in-out;
}

/* --- ESTILOS DO ÍCONE DE OLHO --- */
.desktop .caixa-portfolio .sombra .icone-olho {
  width: 60px;
  height: 39px;

  /* Estado inicial (escondido e um pouco para baixo) */
  opacity: 0;
  transform: translateY(15px);
  transition: all 0.2s ease-in-out;
}

/* --- A MÁGICA DO HOVER ACONTECENDO --- */
/* Quando passar o mouse no card, o título e o olho aparecem se encontrando no meio */
.desktop .caixa-portfolio:hover .sombra .titulo,
.desktop .caixa-portfolio:hover .sombra .icone-olho,
.desktop .caixa-portfolio:focus .sombra .titulo,
.desktop .caixa-portfolio:focus .sombra .icone-olho {
  opacity: 1;
  transform: translateY(0);
}

.portfolio img {
  max-width: 100%;
  height: auto;
}

.desktop {
  display: inherit;
}
.mobile {
  display: none;
}
.hidden-md {
  display: none;
}
@media all and (width < 992px) {
  .desktop {
    display: none !important;
  }
  .mobile {
    display: inherit;
  }
  html {
    margin: 0px;
  }
  .hidden-sm {
    display: none;
  }
  .hidden-md {
    display: block;
  }
}

.modal .titulo {
  font-family: "Merriweather";
  font-size: 24px;
  font-weight: 900;
  color: #404040;
  text-transform: uppercase;
}
.modal .data {
  font-family: "Merriweather";
  font-size: 19px;
  font-weight: normal;
  color: #404040;
  text-align: center;
}
.modal .texto {
  font-family: "Merriweather";
  font-size: 19px;
  font-weight: normal;
  color: #404040;
  text-align: justify !important;
}

.bolachas {
  box-sizing: border-box;
  /* border: 2px solid red; */
  background-color: white;
  box-shadow: 0px -10px 10px 0px rgba(255, 255, 255, 0.75);
  width: 100%;
  position: fixed;
  bottom: 0px;
  left: 0px;

  font-family: "Merriweather";
  font-size: 12px;
  color: #999999;
}
.bolachas a {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 12px;
  color: #999999;
}
.bolachas button {
  background-color: #881414;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 12px;
  color: white;
  padding: 10px 20px;
  border: 1px solid #881414;
  border-radius: 5px;
  transition-duration: 0.5s;
}
.bolachas button:hover {
  background-color: white;
  color: #881414;
}

/* ==========================================================================
   Variáveis Globais (Facilita a manutenção do tema)
   ========================================================================== */
:root {
  --color-text-main: #666666;
  --color-text-dark: #333333;
  --color-brand-hover: #cc0000;
  --color-bg-light: #f1f1f1;
  --color-bg-white: #ffffff;
  --color-border: #cccccc;
  --font-primary: "Open Sans", sans-serif;
  --font-secondary: "Roboto Slab", serif;
  --transition-speed: 0.3s;
}

.content_body {
  width: 100%;
}

:root {
  --noticias-bg: #fff;
  --noticias-border: #e2e2e2;
  --noticias-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
  --noticias-title-color: #232323;
  --noticias-text-color: #444;
  --noticias-data-color: #7a7a7a;
  --noticias-gap: 16px;
}

.noticias-ultimas {
  padding: 27px 0 0 0;
  box-sizing: border-box;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

.noticias-max-area {
  margin-top: 0;
}

.noticias-trigger {
  margin-top: 50px;
}

@keyframes deslizarParaCima {
  0% {
    opacity: 0;
    transform: translateY(400px); /* Começa 60px abaixo da posição original */
  }
  100% {
    opacity: 1;
    transform: translateY(0); /* Termina na posição exata de descanso */
  }
}

.noticias-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--noticias-gap);
  margin-top: 25px;
  /* REMOVIDO: opacity: 0; e a classe animar-entrada do grid */
}

/* Responsividade: Telas menores (Tablets) */
@media (max-width: 992px) {
  .noticias-grid {
    grid-template-columns: 1fr;
  }
}

/* 1. O cartão nasce invisível e rebaixado */
.noticia-card-animado {
  opacity: 0;
  transform: translateY(
    150px
  ); /* Reduzi de 400px para 150px para não sobrecarregar a tela */
}

/* 2. A classe que o JS vai injetar para acionar o gatilho */
.noticia-card-animado.animar-entrada {
  animation: deslizarParaCima 0.8s cubic-bezier(0.3, 0.5, 0.4, 1) forwards;
}

@keyframes deslizarParaCima {
  0% {
    opacity: 0;
    transform: translateY(150px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.noticias {
  color: #333333;
  font-size: 28px;
  font-weight: 700;
  text-align: left;
  font-family: "Roboto Slab", serif;
}

.noticias-lista {
  display: grid;
  gap: var(--noticias-gap);
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  margin-top: 10px;
}

.noticias-titulo {
  margin: 16px 0 0 0;
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
}

.noticias-item {
  display: flex;
  flex-direction: column;
  background-color: #f7f7f7;
  overflow: hidden;
  width: 266px;
  height: 370px;
  transition:
    all 0.5s ease,
    box-shadow 0.3s ease;
  cursor: pointer;
  box-sizing: border-box;
  padding: 9px;
}

.noticias-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--noticias-shadow);
  background-color: #ffffff;
}

.noticias-margem-direita {
  margin-right: 12px;
}

.noticias-imagem {
  width: 100%;
  height: 180px;
  background-color: #f6f6f6;
  overflow: hidden;
}

.noticias-imagem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.noticias-content {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.noticias-data {
  margin: 3px 0 10px 0;
  font-family: "Roboto Slab", serif;
  color: #666666;
  font-size: 10px;
  font-weight: 400;
  text-align: left;
}

.noticias-texto {
  font-family: "Open Sans", sans-serif;
  color: #666666;
  font-size: 13px;
  font-weight: 400;
  text-align: left;
  height: 55px;
  overflow: hidden;
}

.noticias-sem-dados {
  text-align: center;
  color: var(--noticias-data-color);
  font-size: 0.95rem;
  padding: 18px;
}

.noticia-singular-container {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-bottom: 50px;
  margin-top: 40px;
}

.noticia-imagem-principal img {
  object-fit: cover;
  display: block;
}

/* Coluna de Conteúdo */
.noticia-conteudo-wrapper {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
}

/* Cabeçalho */
.noticias-header {
}

.noticias-titulo-singular {
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 5px;
}

.noticias-data {
  font-family: "Roboto Slab", serif;
  color: #666666;
  font-size: 10px;
  font-weight: 400;
  text-align: left;
  margin: 0;
}

/* Corpo do Texto */
.noticia-corpo {
  margin: 10px 0 0 0;
  color: #666666;
  font-size: 12px;
  font-weight: 400;
  text-align: left;
  font-family: "Open Sans", sans-serif;
}

/* Rodapé e Botão Voltar */
.noticia-rodape {
  margin-top: 30px;
}

.btn-voltar-vermelho {
  display: inline-block;
  background-color: #cc0000;
  color: #ffffff;
  padding: 10px 24px;
  text-decoration: none;
  font-weight: bold;
  font-size: 14px;
  text-transform: uppercase;
  transition: background-color 0.3s ease;
}

.btn-voltar-vermelho:hover {
  background-color: #990000; /* Efeito hover para UX */
}

/* Container principal (o bloco branco) */
.bloco-sombra {
  position: relative; /* Necessário para posicionar a sombra ::after */
  background-color: #fff;
  border-radius: 8px; /* Cantos arredondados, se desejar */
  margin-top: 50px; /* Espaçamento interno */
  box-shadow: none; /* Desativa sombras normais */
  z-index: 20;
}

.bloco-sombra::after {
  content: ""; /* Necessário para que o pseudo-elemento exista */
  position: absolute; /* Posicionamento absoluto em relação ao container */
  bottom: -20px; /* Coloca a sombra abaixo do container */
  left: 50%; /* Centraliza horizontalmente */
  transform: translateX(-50%); /* Ajuste final de centralização */
  width: 80%; /* Controla a largura total da sombra */
  height: 20px; /* Controla a altura visível da sombra */
  background: radial-gradient(
    ellipse at center,
    rgba(0, 0, 0, 0.9) 0%,
    rgba(0, 0, 0, 0) 80%
  ); /* Gradiente radial */
  filter: blur(3px); /* Suaviza e desfoca a sombra */
  z-index: -1; /* Garante que a sombra fique atrás do container */
}

.bloco-sombra-header {
  position: relative;
  /* A cor de fundo da sua seção cinza clara */
  background-color: #f4f4f4;
}

/* Trocamos para ::before por semântica (vai no topo) */
.bloco-sombra-header::before {
  content: "";
  position: absolute;
  top: 0px; /* Cola exatamente no teto da div */
  left: 50%;
  transform: translateX(-50%);
  width: 85%; /* Deixa a sombra um pouco menor que a tela para sumir nas pontas */
  height: 5px; /* A altura da "queda" da sombra */

  /* A MÁGICA: 'ellipse at top' faz o gradiente escorrer apenas de cima para baixo */
  background: radial-gradient(
    ellipse at top,
    rgba(0, 0, 0, 0.3) 0%,
    rgba(0, 0, 0, 0) 75%
  );

  /* Remove o blur excessivo, o gradiente já faz o desfoque perfeito */

  /* Garante que a sombra invisível não bloqueie você de selecionar textos */
  pointer-events: none;
}

/* Junta-te a Nós  */
.junta_te_nos {
  position: relative;
  text-align: center;
  padding: 60px 0 0;
  background-color: #fff;
}
.junta_te_nos > .max_area > .titulo {
  font-family: "Roboto Slab", serif !important;
  color: #333;
  font-size: 28px;
  font-weight: 700;
  line-height: 40px;
  text-align: center;
  margin: -5px 0 19px;
}
.junta_te_nos > .max_area > .conteudo {
  font-family: "Open Sans", sans-serif;
  color: #333;
  font-size: 14px;
  line-height: 18px;
  text-align: center;
  max-width: 753px;
  margin: 0 auto 21px;
  position: relative;
  padding: 0 !important;
  top: -5px;
}
.junta_te_nos > .max_area > .conteudo a {
  color: #337ab7;
  text-decoration: underline;
}

/* Contacte-nos */
.contacte_nos {
  position: relative;
  padding: 28px 0 56px 0;
  background-color: #f9f9f9;
  text-align: center; /* Centraliza os blocos principais */
  z-index: 30;
}

/* Títulos e Textos */
.contacte_nos .titulo {
  font-family: "Roboto Slab", serif !important;
  color: #333333;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 15px;
}

.contacte_nos .conteudo {
  display: inline-block;
  font-family: "Open Sans", sans-serif;
  color: #333333;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 40px;
  max-width: 825px;
  width: 100%;
}

.contacte_nos .conteudo p {
  margin: 0;
}

/* Área do Formulário */
.contacte_nos .formulario {
  display: inline-block;
  /* Reduza esse valor. Se estava 750px, tente 600px ou 550px */
  max-width: 660px;
  width: 100%;
  text-align: left;
}

.contacte_nos .form-group {
  display: flex;
  width: 320px;
  flex-direction: column;
  justify-content: start;
  margin-bottom: 25px; /* Espaço entre a linha de cima e a de baixo */
}

/* Labels (Textos em cima dos campos) */
.contacte_nos label {
  display: flex;
  width: auto;
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  color: #000000;
  margin-bottom: 6px;
  margin-left: 2px;
}

/* Inputs de Texto */
.contacte_nos input[type="text"],
.contacte_nos input[type="email"] {
  width: 319px;
  border: 1px solid #cccccc;
  border-radius: 0; /* Cantos retos como na imagem */
  height: 30px !important;
  padding: 8px 12px;
  font-family: "Open Sans", sans-serif;
  font-size: 14px;
  box-sizing: border-box;
  outline: none;
  transition: border-color 0.3s;
}

.contacte_nos input[type="text"]:focus {
  border-color: #999999;
}

/* Estilo dos Radio Buttons (Telefone / E-mail) */
.contacte_nos .radio {
  display: flex;
  gap: 30px; /* Distância entre os dois botões */
  height: 38px; /* Mesma altura dos inputs de texto para alinhar perfeito */
  align-items: center; /* Centraliza verticalmente */
  margin-top: 0;
}

.contacte_nos .radio label {
  display: flex;
  align-items: center;
  font-size: 12px;
  margin: 0;
  cursor: pointer;
  font-weight: normal;
}

.contacte_nos .radio input[type="radio"] {
  margin: 0 8px 0 0;
  accent-color: #990000;
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* Botão Vermelho de Enviar */
.contacte_nos .mediamaster-btn {
  display: flex;
  justify-content: center; /* Centraliza o botão horizontalmente */
  align-items: center;
  width: 100%; /* Garante que a caixa ocupe toda a largura do formulário */
  margin-top: 5px;
}

.contacte_nos .mediamaster-btn button {
  background-color: #cc0000; /* Vermelho vivo da imagem */
  border: none;
  color: #ffffff;
  padding: 12px 22px;
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase; /* Força letras maiúsculas */
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.contacte_nos .mediamaster-btn button:hover {
  background-color: #a30000; /* Escurece um pouco ao passar o mouse */
}

/* Mensagens de Sucesso e Erro */
.contacte_nos .msg-success {
  color: #2b7d32;
  margin-bottom: 20px;
}

.contacte_nos .msg-error {
  color: #c62828;
  margin-bottom: 20px;
}

/* Footer CSS - Classes específicas do rodapé */

div.caixa_inferior {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 0 0 0;
  background-color: #242629;
  width: 100%;
  min-height: 384px;
  margin: 0 auto;
}

div.caixa_inferior > div.max_area > div.caixa_1 {
  float: left;
  min-height: 155px;
  max-width: 666px;
  width: 100%;
  text-align: left;
  padding: 0 0 0 10px;
}

div.caixa_inferior > div.max_area > div.caixa_1 > div.conteudo {
  margin: 28px auto 120px auto; /* Mudei para 'auto' nas laterais para ele centralizar a caixa inteira, já que você usou text-align: center */
  font-family: "Open Sans", sans-serif;
  color: #f1f0f0;
  font-size: 14px;
  font-weight: 400;
  line-height: 21px;
  width: fit-content;
  max-width: 100%;
}

div.caixa_inferior > div.max_area > div.caixa_2 {
  float: left;
  height: auto;
  margin: 6px 70px 0px 55px;
  max-width: 150px;
  position: relative;
}

div.caixa_2 > div.div-ralc {
  position: relative;
  text-align: center;
  margin-top: 20px;
}

div.caixa_2 > div.div-ralc img {
  width: 130px;
}

div.caixa_2 > div.div-livro {
  position: relative;
  margin-top: 15px;
  text-align: center;
}

div.caixa_2 > div.div-livro img {
  width: 85px;
}

div.caixa_inferior > div.max_area > div.caixa_3 {
  float: left;
  height: auto;
  margin: 0 0 0 0;
  max-width: 202px;
  position: relative;
  left: 6px;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.titulo {
  font-family: "Roboto Slab", serif !important;
  color: #f1f0f0;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
  position: relative;
  margin: -2px 0 0 0;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.contacto {
  font-family: "Open Sans", sans-serif;
  color: #cccccc;
  font-size: 16px;
  font-weight: 400;
  text-align: left;
  margin: 10px 0;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.contacto a {
  color: #cccccc;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.contacto a:hover {
  color: #a7a5a5;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.conteudo {
  font-family: "Open Sans", sans-serif;
  color: #cccccc;
  font-size: 12px;
  font-weight: 400;
  line-height: 20px;
  text-align: left;
  margin: 7px 0 0 0;
  position: relative;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.caixa_3_hr {
  margin: 31px 0 20px 0;
  background-color: #666666;
  width: 198px;
  height: 5px;
  position: relative;
  top: -2px;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.subscrever {
  width: 100%;
  position: relative;
  top: -11px;
  left: -3px;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.subscrever input {
  float: left;
  border-radius: 0;
  width: 179px;
  height: 30px;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.subscrever span:hover {
  background-position: 0 100%;
}

div.caixa_inferior > div.max_area > div.caixa_3 > div.subscrever span {
  display: block;
  float: left;
  box-sizing: border-box;
  background-color: #242629;
  width: 20px;
  height: 30px;
  cursor: pointer;
  background-image: url("../imagens/subscrever.jpg");
}

div.caixa_inferior > div.max_area > div.hr_1 {
  background-color: #cccccc;
  height: 2px;
  width: 79.4%;
  margin: -75px 0 0 0;
}

div.caixa_inferior > div.max_area > div.area_mobile {
  display: none;
}

div.caixa_inferior > div.max_area > div.caixa_4 > ul {
  padding: 0;
  margin: 0;
}

div.caixa_inferior > div.max_area > div.caixa_4 > ul > li {
  display: inline-block;
  position: relative;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(2) {
  margin-left: -18px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(3) {
  margin-left: -43px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(4) {
  margin-left: -5px;
  position: relative;
  top: 4px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(5) {
  left: 4px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(6) {
  margin-left: 17px;
  left: 5px;
  top: 2px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(7) {
  margin-left: 3px;
  left: 9px;
  top: 3px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(8) {
  margin-left: 12px;
  left: 11px;
  top: 1px;
}

div.caixa_inferior > div.max_area > div.caixa_4 ul > li:nth-child(9) {
  margin-left: -15px;
  position: relative;
  left: 43px;
}

div.caixa_inferior > div.max_area > div.caixa_4 {
  float: left;
  width: 82%;
  margin: -50px 0 0 -14px;
}

div.caixa_inferior > div.max_area > div.hr_2 {
  margin: 28px 0 0 0;
  background-color: #999999;
  width: 100%;
  height: 1px;
}

div.copyright {
  margin: 5px 0 0 0;
  text-align: center;
  font-family: "Open Sans", sans-serif;
  color: #666666;
  font-size: 10px;
  font-weight: 400;
  min-height: 33px;
}

div.sociais {
  width: 63px;
  height: 30px;
  float: right;
  margin: 0 0 0 0;
  position: relative;
  right: -2px;
}

div.sociais div.facebook:hover {
  background-position: 0 100%;
}

div.sociais div.facebook {
  cursor: pointer;
  width: 25px;
  height: 25px;
  background-image: url("../imagens/icones/facebook.jpg");
  display: inline-block;
  margin: 0 5px 0 0;
}

div.sociais div.linkedin {
  width: 25px;
  height: 25px;
  background-image: url("../imagens/icones/linkedin.jpg");
  display: inline-block;
  cursor: pointer;
}

div.sociais div.linkedin:hover {
  background-position: 0 100%;
}

/* Mobile styles */
@media (max-width: 1135px) {
  div.caixa_inferior > div.max_area > div.caixa_1 {
    text-align: center !important;
  }
  div.area_desktop {
    display: none !important;
  }
  div.caixa_inferior {
    text-align: center;
  }
  div.caixa_inferior > div.max_area > div.caixa_1 {
    padding: 0;
    display: inline-block;
    max-width: 100%;
  }

  div.caixa_inferior > div.max_area > div.caixa_2 {
    margin: 0;
    display: inline-block;
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  div.caixa_inferior > div.max_area > div.hr_1 {
    clear: both;
    margin: 0;
    display: inline-block;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 {
    display: inline-block;
    width: 95%;
    text-align: center;
    max-width: 100%;
    margin-top: 35px;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 > div.titulo {
    text-align: center;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 > div.conteudo {
    text-align: center;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 > div.contacto {
    text-align: center;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 > div.caixa_3_hr {
    width: 90%;
    margin: 25px auto 18px auto;
    position: relative;
    left: -6px;
  }
  div.caixa_inferior > div.max_area > div.caixa_4 {
    clear: both;
    margin: 0px;
    display: inline-block;
    width: 100%;
    max-width: 100%;
  }
  div.caixa_inferior > div.max_area > div.caixa_3 > div.subscrever {
    display: inline-block;
    text-align: center;
    width: 202px;
  }
  .conteudo {
    clear: both;
    padding: 13px;
    display: inline-block;
    width: 100%;
  }
  div.sociais {
    margin-top: 5px;
  }
}
/* 3. A linha branca sobe naturalmente para baixo dos textos, sem o -75px */
div.caixa_inferior > div.max_area > div.hr_1.area_desktop {
  margin: -80px 0 0px 0 !important; /* Margem natural (ajuste se quiser mais perto) */
}

.subscrever input.form-control {
  font-family:
    "Open Sans", Arial, sans-serif !important; /* Muda para a fonte lisa */
  font-variant: normal !important; /* Desliga efeitos estranhos de fonte */
  text-transform: lowercase !important;
}

.subscrever input.form-control::placeholder {
  text-transform: lowercase !important;
  font-family: inherit !important;
  font-weight: 500;
  font-size: 14px;
}

.page__main {
  background: #ffffff;
}

.page__hero {
  background: #f1f1f1;
  padding-top: 22px;
  margin-bottom: 4px;
}

.page__hero-copy h1 {
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 22px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 2px;
}

.page__hero-copy p {
  font-family: "Open Sans", sans-serif;
  color: #333333;
  font-size: 12px;
  font-weight: 400;
  text-align: left;
  text-transform: uppercase;
  min-height: 36px;
}

.sobre-nos__about,
.sobre-nos__join-us,
.sobre-nos__contact,
.sobre-nos__process {
  background: #ffffff;
  border-radius: 12px;
  padding: 37px;
}

.sobre-nos__stats {
  background: #ffffff;
  border-radius: 12px;
  padding: 0 37px 37px 37px;
}

.sobre-nos__about h2,
.sobre-nos__process h2,
.sobre-nos__join-us h2,
.sobre-nos__contact h2 {
  margin-top: 0;
  font-size: 16px;
  color: #666666;
  font-weight: 700;
  margin-bottom: 10px;
}

.sobre-nos__about p,
.sobre-nos__join-us p,
.sobre-nos__contact p,
.sobre-nos__footer-about p {
  color: #666666;
  font-size: 16px;
  font-family: "Open Sans", sans-serif;
  line-height: 19px;
}

.sobre-nos__highlights {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.shighlight-section {
  background: #ffffff;
  padding: 1.5rem;
  text-align: center; /* Centraliza o texto das descrições */
}

/* 1. O Container Principal (Obrigatório ser transparente) */
.highlight-title {
  /* IMPORTANTE: Não coloque background-color aqui! */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  width: 100%;
  max-width: 400px;
  min-height: 90px;
  margin: 0 auto 45px auto;
  position: relative;
  text-align: center;
}

/* 2. O Texto (Camada da FRENTE) */
.highlight-title span {
  position: relative; /* OBRIGATÓRIO para o z-index funcionar */
  z-index: 2; /* Força o texto a ficar na frente da caixa vermelha */
  font-family: "Roboto Slab", serif;
  color: white;
  font-size: 20px;
  font-weight: 600;
}

/* 3. O Retângulo Vermelho Reto (Camada do MEIO) */
.highlight-title::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #cc0000;
  z-index: 1; /* Fica atrás do texto, mas na frente da sombra */
}

/* 4. A Sombra Gradiente (Camada do FUNDO) */
.highlight-title::after {
  content: "";
  position: absolute;
  /* Faz a caixa da sombra vazar 5px para cima e 5px para baixo do botão vermelho */
  top: -5px;
  bottom: -5px;
  left: 0;
  width: 100%;

  /* A MÁGICA: Colocamos o seu gradiente duas vezes separados por vírgula */
  background-image: 
        /* 1º Gradiente (Sombra do Topo) */
    linear-gradient(
      to right,
      rgba(0, 0, 0, 0.5) 0%,
      rgba(0, 0, 0, 0) 30%,
      rgba(0, 0, 0, 0) 70%,
      rgba(0, 0, 0, 0.5) 100%
    ),
    /* 2º Gradiente (Sombra da Base) */
    linear-gradient(
        to right,
        rgba(0, 0, 0, 0.5) 0%,
        rgba(0, 0, 0, 0) 30%,
        rgba(0, 0, 0, 0) 70%,
        rgba(0, 0, 0, 0.5) 100%
      );

  /* Colamos o 1º no topo e o 2º embaixo */
  background-position: top, bottom;

  /* Limitamos a altura de CADA sombra para 10px (sua configuração) */
  background-size:
    100% 10px,
    100% 10px;

  /* Impedimos que o gradiente se repita preenchendo o meio do botão */
  background-repeat: no-repeat;

  filter: blur(3px);
  z-index: 0;
  pointer-events: none;
}

.highlight-section p {
  font-size: 16px;
  color: #666666;
  font-family: "Open Sans", sans-serif;
  line-height: 19px;
}

.sobre-nos__stats-flex {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 40px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.sobre-nos__stats-flex article h3 {
  color: #666666;
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  margin-bottom: 19px;
}

.sobre-nos__stats-flex article p {
  color: #666666;
  font-size: 16px;
  font-family: "Open Sans", sans-serif;
  line-height: 19px;
  text-align: center;
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(
      -50px,
      0,
      0
    ); /* Começa 50px empurrado para a esquerda */
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0); /* Volta para o lugar original */
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 50px, 0); /* Começa 50px empurrado para baixo */
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0); /* Volta para o lugar original */
  }
}

/* Container Principal */
.sobre-nos__process {
  background: #f9f9f9;
  margin-top: 52px;
  padding: 34px 0;
  position: relative;
}

/* --- SOMBRA DO TOPO (Projetada para fora / para cima) --- */
.sobre-nos__process::before {
  content: "";
  position: absolute;

  /* A MÁGICA: Empurra a sombra 15px PARA FORA do teto da seção */
  top: -6px;

  left: 0;
  width: 100%;
  height: 6px;

  /* Elipse na base: A parte escura fica colada na borda da seção e esfumaça para cima */
  background: radial-gradient(
    ellipse at bottom,
    rgba(0, 0, 0, 0.4) 0%,
    rgba(0, 0, 0, 0) 60%
  );

  pointer-events: none;

  /* IMPORTANTE: z-index alto garante que a sombra sobreponha a seção branca que estiver acima dela */
  z-index: 10;
}

/* --- SOMBRA DA BASE (Projetada para fora / para baixo) --- */
.sobre-nos__process::after {
  content: "";
  position: absolute;

  /* A MÁGICA: Empurra a sombra 15px PARA FORA do chão da seção */
  bottom: -6px;

  left: 0;
  width: 100%;
  height: 6px;

  /* Elipse no topo: A parte escura fica colada na borda da seção e esfumaça para baixo */
  background: radial-gradient(
    ellipse at top,
    rgba(0, 0, 0, 0.4) 0%,
    rgba(0, 0, 0, 0) 60%
  );

  pointer-events: none;
  z-index: 10;
}

.sobre-nos__process-title {
  font-family: "Roboto Slab", serif;
  color: #666666;
  font-size: 28px !important;
  font-weight: 700;
  text-align: center;
  margin-bottom: 50px;
}

.sobre-nos__process-flex {
  display: grid;
  justify-self: center;
  grid-template-columns: repeat(5, 1fr);
  width: 970px;
  position: relative; /* ESSENCIAL: Cria a âncora para a linha */
  z-index: 1; /* Cria a camada para não esconder a linha atrás do fundo do site */
}

/* A LINHA CINZA CONTÍNUA DO CENTRO */
.sobre-nos__process-flex::before {
  content: "";
  position: absolute;
  top: 120px;

  left: 6%;
  width: 84%;
  height: 3px;
  background: linear-gradient(
    to right,
    rgba(102, 102, 102, 0.5) 0%,
    rgba(102, 102, 102, 1) 20%,
    rgba(102, 102, 102, 1) 80%,
    rgba(102, 102, 102, 0.5) 100%
  );
  box-shadow: 0px 0px 10px rgba(102, 102, 102, 0.8);
  z-index: -1;
}
.process-icon-mobile {
  display: none !important;
}

/* Coluna Individual */
.sobre-nos__process-item {
  display: flex;
  flex-direction: column;
  justify-self: center;
}

/* 2. Container da Imagem (A mágica do alinhamento) */
.sobre-nos__process-icon {
  display: flex;
  align-items: flex-end; /* MÁGICA: Empurra o fundo das imagens para a mesma linha imaginária */
  justify-content: center;
  height: 130px; /* Cria uma "caixa" de altura fixa para eles se alinharem */
  margin-bottom: 25px;
}

.sobre-nos__process-icon img {
  max-width: 100%;
  max-height: 100%; /* Impede imagens gigantes de quebrarem o layout */
  object-fit: contain;
  /* IMPORTANTE: Removi o margin-top: 50px daqui! O flex-end acima já resolve isso. */
}

/* --- AJUSTE DA ÚLTIMA IMAGEM (SEM SETA) --- */
.sobre-nos__process-item:last-child .sobre-nos__process-icon img {
  /* Essa margem "finge" que existe uma seta embaixo da imagem */
  margin-bottom: 2px;
}

/* O Card Branco com os Textos */
.sobre-nos__process-card {
  background: #ffffff;
  padding: 25px 10px;
  width: 180px;
  /* Borda sutil e sombra leve como na imagem */
  border: 1px solid #e8e8e8;
  box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.4);
  flex-grow: 1; /* Faz o card esticar até o final caso o texto do vizinho seja maior */
}

/* Título de dentro do Card */
.sobre-nos__process-card h3 {
  font-family: "Roboto Slab", serif;
  font-size: 16px;
  font-weight: 700;
  color: #666666;
  text-align: center;
  margin-top: 0;
  margin-bottom: 20px;
}

/* A Lista de Textos (Removendo as bolinhas) */
.sobre-nos__process-card ul {
  list-style: none; /* Remove o padrão de bolinhas pretas (bullets) */
  padding: 0;
  margin: 0;
}

.sobre-nos__process-card li {
  font-family: "Open Sans", sans-serif;
  color: #666666;
  font-size: 14px;
  font-weight: 400;
  line-height: 17px;
  text-align: left;
  margin-bottom: 10px;
}

/* =========================================
   2. ESTADO INICIAL (Escondidos)
========================================= */
.sobre-nos__process-icon,
.sobre-nos__process-card {
  opacity: 0; /* Ficam invisíveis esperando a vez deles */
}

/* =========================================
   3. O GATILHO (Quando o JS adicionar a classe no pai)
========================================= */
.iniciar-animacao .sobre-nos__process-icon {
  animation: fadeInLeft 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

.iniciar-animacao .sobre-nos__process-card {
  animation: fadeInUp 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

/* =========================================
   4. O EFEITO CASCATA ATUALIZADO
========================================= */
.iniciar-animacao
  .sobre-nos__process-item:nth-child(1)
  .sobre-nos__process-icon,
.iniciar-animacao
  .sobre-nos__process-item:nth-child(1)
  .sobre-nos__process-card {
  animation-delay: 0.1s;
}

.iniciar-animacao
  .sobre-nos__process-item:nth-child(2)
  .sobre-nos__process-icon,
.iniciar-animacao
  .sobre-nos__process-item:nth-child(2)
  .sobre-nos__process-card {
  animation-delay: 0.3s;
}

.iniciar-animacao
  .sobre-nos__process-item:nth-child(3)
  .sobre-nos__process-icon,
.iniciar-animacao
  .sobre-nos__process-item:nth-child(3)
  .sobre-nos__process-card {
  animation-delay: 0.5s;
}

.iniciar-animacao
  .sobre-nos__process-item:nth-child(4)
  .sobre-nos__process-icon,
.iniciar-animacao
  .sobre-nos__process-item:nth-child(4)
  .sobre-nos__process-card {
  animation-delay: 0.7s;
}

.iniciar-animacao
  .sobre-nos__process-item:nth-child(5)
  .sobre-nos__process-icon,
.iniciar-animacao
  .sobre-nos__process-item:nth-child(5)
  .sobre-nos__process-card {
  animation-delay: 0.9s;
}

/* Container da Navbar com as linhas divisórias */
.servicos__navbar {
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  background-color: #ffffff;
}

/* A Lista em linha reta */
.servicos__nav-list {
  display: flex;
  flex-wrap: wrap; /* Garante que não quebre feio no mobile */
  gap: 40px; /* Espaçamento entre os links */
  list-style: none;
  padding: 0;
  margin: 0;
}

/* O Item individual da lista */
.servicos__nav-item {
  position: relative; /* ESSENCIAL: Serve de âncora para o triângulo vermelho */
}

/* O Link (Texto cinza padrão) */
.servicos__nav-link {
  display: block;
  padding: 10px 0; /* Dá altura à barra de navegação */
  color: #666666;
  font-family:
    "Open Sans", sans-serif !important; /* Ou a fonte que estiver usando */
  font-size: 12px;
  text-decoration: none;
  transition: color 0.3s ease;
  text-transform: none;
}

/* Efeito Hover simples */
.servicos__nav-link:hover {
  color: #cc0000;
}

/* =========================================
   O ESTADO ATIVO (Vermelho + Triângulo)
========================================= */

/* Muda a cor do texto quando a tag pai <li> tem a classe is-active */
.servicos__nav-item.is-active .servicos__nav-link {
  color: #cc0000;
}

/* A MÁGICA: O Triângulo Vermelho apontando para cima */
/* 1. Prepara o triângulo escondido em TODOS os itens */
.servicos__nav-item::after {
  content: "";
  position: absolute;

  /* Começa um pouco mais para baixo para dar o efeito de subir */
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);

  /* Desenha o triângulo vermelho */
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid #cc0000;

  /* A MÁGICA: Deixa ele invisível por padrão e adiciona uma transição suave */
  opacity: 0;
  transition: all 0.1s ease;
}

/* 2. Revela o triângulo quando o mouse passa por cima (hover) OU se estiver ativo */
.servicos__nav-item:hover::after,
.servicos__nav-item.is-active::after {
  opacity: 1; /* Fica 100% visível */
  bottom: -1px; /* Sobe e "gruda" na linha cinza perfeitamente */
}

/* =========================================
   SISTEMA DE ABAS (Esconde/Mostra)
========================================= */
.servicos__tab-panel {
  display: none; /* Esconde todas as abas por padrão */
  animation: fadeIn 0.5s ease; /* Uma animação suave na troca (opcional) */
}

.servicos__tab-panel.is-active {
  display: block; /* Mostra apenas a aba que tem a classe ativa */
}

/* =========================================
   TIPOGRAFIA E ESPAÇAMENTOS
========================================= */

.servico-hero {
  margin-top: 40px;
}
.servicos__conteudo {
  margin-top: 40px;
}

/* Título Principal (WEBSITES) */
.servicos__conteudo-title {
  font-family: "Open Sans", sans-serif;
  line-height: 19px;
  font-size: 16px;
  font-weight: 700;
  color: #666666;
  margin-bottom: 25px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* Bloco que segura cada dupla de Subtítulo + Texto */
.servicos__paragrafo-bloco {
  margin-bottom: 40px; /* O grande respiro entre um assunto e outro */
}

/* Subtítulo (Criação de Sites Novos) */
.servicos__paragrafo-subtitle {
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #666666;
  margin-top: 0;
  margin-bottom: 15px;
}

/* O Texto da Descrição */
.servicos__paragrafo-texto {
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  color: #666666;
  line-height: 1.4;
  margin: 0;
}

/* Container da imagem */
.servicos__imagem-wrapper {
  margin: 32px 0; /* Espaçamento de respiro acima e abaixo da imagem */
  padding: 0;
  text-align: left; /* Ou 'center' se preferir as imagens centralizadas */
}

/* A Imagem em si */
.servicos__imagem {
  justify-self: center;
  max-width: 50%; /* IMPEDE que a imagem quebre o layout no celular */
  height: auto; /* Mantém a proporção original da foto */
  border-radius: 8px; /* Dá um acabamento moderno com cantos arredondados (opcional) */
  display: block; /* Comportamento de bloco seguro */
}

/* O texto da descrição (Legenda) */
.servicos__imagem-legenda {
  margin-top: 12px;
  font-size: 0.95rem;
  text-align: center;
  color: #555; /* Um cinza um pouco mais claro para diferenciar do texto principal */
  font-style: italic; /* Dá cara de legenda de revista/blog */
  line-height: 1.5;
}

/* Animação suave para quando trocar de aba */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* O Botão Principal */
.botao-voltar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #cc0000;
  color: #ffffff;
  padding: 6px 17px;
  margin-top: 40px;
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

/* O Hover (quando passa o mouse) */
.botao-voltar:hover {
  background-color: #a30000; /* Um tom de vermelho um pouco mais escuro */
  color: #ffffff;
}

/* A Setinha Branca */
.seta-voltar {
  font-size: 15px; /* Deixa a seta um pouquinho menor que o texto para ficar elegante */
  margin-right: 10px; /* O espaço entre a seta e a letra V */
  font-weight: 500;
}

/* Container Principal */
.ultimos-projetos {
  padding: 36px 0 50px;
  background-color: #fafafa;
  margin: 40px 0 -50px;
  z-index: 10;
}

/* =========================================
   CABEÇALHO E TÍTULO
========================================= */
.ultimos-projetos__header {
  text-align: center;
  margin-bottom: 30px;
}

.ultimos-projetos__title {
  display: inline-block;
  text-align: center;
  font-family:
    "Roboto Slab", serif; /* Mantendo o padrão dos seus outros títulos */
  font-size: 28px;
  font-weight: 700;
  color: #666666;
  margin: 0;
  position: relative; /* Âncora para a linha abaixo */
  padding-bottom: 25px; /* Espaço entre o texto e a linha */
}

/* A linha fina cinza abaixo do título */
.ultimos-projetos__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%); /* Centraliza a linha no meio do título */
  width: 100%; /* Largura da linha */
  height: 1px;
  background-color: #bbbbbb; /* Cor da linha */
}

/* =========================================
   O GRID DE PROJETOS
========================================= */
.ultimos-projetos__grid {
  display: grid;
  /* Divide em 3 colunas de tamanhos iguais no desktop */
  width: 920px;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px; /* Espaço entre os projetos */
  justify-self: center;
}

/* O "Cartão" que segura a imagem */
.ultimos-projetos__card {
  display: inline;
  background-color: #ffffff;
  /* Uma sombra extremamente leve para dar profundidade, como na imagem */
  box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.05);
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
  cursor: pointer; /* Indica que é clicável */
  overflow: hidden; /* Garante que a imagem não vaze para fora do card */
}

/* Efeito Hover: O projeto "levanta" quando o mouse passa por cima */
.ultimos-projetos__card:hover {
  transform: translateY(-5px);
  box-shadow: 0px 8px 15px rgba(0, 0, 0, 0.1);
}

/* A Imagem do Projeto */
.ultimos-projetos__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover; /* Garante que a imagem preencha o quadrado sem distorcer */
}

/* ==========================================================================
   SINGLE VIEW DE PROJETOS
   ========================================================================== */

.projeto-singular-container {
  max-width: 1200px; /* Largura máxima para manter o layout elegante */
  margin: 0 auto;
  padding: 40px 15px;
}

/* --- TOPO (3 COLUNAS) --- */
.projeto-topo {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
  margin-bottom: 40px;
}

/* Coluna 1: Logotipo */
.projeto-logo {
  flex: 1 1 200px;
  max-width: 250px;
}

.projeto-logo img {
  width: 100%;
  height: auto;
  display: block;
}

/* Coluna 2: Informação Central (Maior) */
.projeto-info {
  flex: 2 1 400px;
}

.projeto-titulo {
  padding: 45px 0 18px 0;
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
}

.projeto-descricao {
  font-family: "Open Sans", sans-serif;
  color: #666666;
  font-size: 12px;
  font-weight: 400;
  text-align: left;
  margin: 0 0 20px 0;
  height: 137px;
}

.btn-visitar {
  display: inline-block;
  background-color: #cc0000;
  color: #ffffff;
  padding: 10px 24px;
  text-decoration: none;
  font-weight: bold;
  font-size: 14px;
  text-transform: uppercase;
}

.btn-visitar:hover {
  background-color: #990000;
}

/* Coluna 3: Tags / Características */
.projeto-tags {
  flex: 1 1 200px;
  border-left: 1px solid #ddd; /* A linha separadora elegante */
  padding-left: 30px;
}

.projeto-tags h3 {
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  padding: 0 0 11px 0;
}

.projeto-tags ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.projeto-tags li {
  display: flex;
  align-items: center;
  color: #333;
  font-weight: bold;
  font-size: 13px;
  margin-bottom: 10px;
  text-transform: uppercase;
}

/* O quadrado laranja da lista */
.projeto-tags li::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: #ff6600;
  margin-right: 10px;
}

/* --- LINHA DIVISÓRIA --- */
.projeto-separador {
  border: 0;
  border-top: 1px solid #ddd;
  margin: 0 0 40px 0;
}

/* --- CORPO (IMAGEM GRANDE) --- */
.projeto-corpo {
  text-align: center; /* Centraliza a imagem/conteúdo */
  margin-bottom: 50px;
}

.projeto-corpo img {
  max-width: 100%; /* Garante que a imagem gigante não quebra a tela */
  height: auto;
}

/* Responsividade para Telemóvel */
@media (max-width: 768px) {
  .projeto-tags {
    border-left: none;
    border-top: 1px solid #ddd;
    padding-left: 0;
    padding-top: 20px;
  }
}

.servicos__highlight-texto {
  font-size: 16px;
  color: #666666;
  font-family: "Open Sans", sans-serif;
  line-height: 19px;
  text-align: center;
}

.servicos__conhecer-portfolio {
  display: block;
  width: 100%;
  margin-top: -20px;
}

.servicos__conhecer-portfolio img {
  display: flex;
  justify-self: end;
  max-width: 360px;
  height: auto;
  margin-bottom: 100px;
}

.servicos__btn-voltar {
  display: none;
  background: none;
  border: none;
  color: #666;
  font-size: 14px;
  padding: 10px 0 0 5%;

  margin-bottom: 5px;
  cursor: pointer;
  text-align: left;
  line-height: 1.42857143;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.servicos__btn-voltar:hover {
  color: #cc0000;
}

/* A linha fina cinza abaixo do botão */
.servicos__btn-voltar-linha {
  display: none;
  border: 0;
  width: 91%;
  justify-self: center;
  border-top: 2px solid #a3a3a3;
  margin: 0 0 25px 0;
}

/* Container geral da seção */
.clientes-depoimentos {
  background-color: #ffffff;
}

/* O "Cartão" do depoimento (Organizado em linha com Flexbox) */
.cliente-card {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 40px 0;
  border-bottom: 1px solid #f0f0f0; /* Linha horizontal bem suave separando os clientes */
}

/* Remove a linha horizontal do último cliente da lista */
.cliente-card:last-child {
  border-bottom: none;
}

/* Coluna 1: O container do Logo */
.cliente-card__imagem-col {
  flex: 0 0 250px; /* Trava a largura da coluna de imagens em 250px */
  padding-right: 30px;
  text-align: center; /* Centraliza a imagem no próprio bloco */
}

.cliente-card__imagem {
  max-width: 100%;
  height: auto;
}

/* Coluna 2: O container do Texto */
.cliente-card__conteudo-col {
  flex: 1; /* Ocupa todo o resto do espaço disponível */
  padding-left: 30px;
  /* A MÁGICA DA IMAGEM: A linha vertical separadora */
  border-left: 1px solid #e0e0e0;
}

/* Título (Nome da Empresa) */
.cliente-card__titulo {
  font-family: "Roboto Slab", serif;
  font-size: 1.15rem;
  color: #2c3e50; /* Um cinza bem escuro/azulado padrão corporativo */
  margin: 0 0 30px 0;
  font-weight: 700;
}

/* Texto do Depoimento */
.cliente-card__resumo {
  font-family: "Open Sans", sans-serif;
  color: #666666;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 20px;
}

/* Bloco do Autor */
.cliente-card__autor {
  font-family: "Open Sans", sans-serif;
  font-size: 0.95rem;
  line-height: 1.4;
}

/* Nome do Autor */
.cliente-card__nome {
  font-weight: 700;
  color: #444444;
}

/* Cargo do Autor */
.cliente-card__cargo {
  font-style: italic;
  color: #666666;
  font-size: 16px;
  font-weight: 700;
}

/* =========================================
   ESTRUTURA PRINCIPAL (As duas colunas)
========================================= */
.contactos-wrapper {
  display: flex;
  gap: 30px;
  align-items: stretch; /* Faz as duas colunas terem a mesma altura */
}

/* Coluna da Esquerda (Form) */
.contactos-formulario-col {
  position: relative;
  max-width: 66.2%;
  width: 100%;
  background-color: #f7f7f7; /* Fundo cinza bem claro */
  padding: 20px;
}

.contactos-formulario-col::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%); /* Centraliza a linha no meio do título */
  height: 4px;
  background-color: #616161; /* Cor da linha */
  width: 100%;
}

/* Coluna da Direita (Info) */
.contactos-info-col {
  flex: 1;
  text-align: center;
  position: relative;
  overflow: visible;
}

.contactos-info-col img {
  width: 117%;
}

.contactos-titulo {
  font-size: 14px;
  font-weight: 700;
  color: #333333;
  margin-bottom: 5px;
  font-family: "Roboto Slab", serif;
}

.contactos-subtitulo {
  font-size: 14px;
  color: #555;
  margin-bottom: 30px;
}

.form-proposta {
  display: grid;
  padding: 0 25px;
  grid-template-columns: 1fr 1fr; /* Divide em duas colunas iguais */
  gap: 15px 25px; /* Espaço entre as linhas e entre as colunas */
}

/* Labels e Inputs */
.form-group label {
  display: block;
  font-size: 12px;
  color: #444;
  margin-bottom: 5px;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
  width: 100%;
  padding: 4px 4px;
  border: 1px solid #ccc;
  font-size: 13px;
  background-color: #fff;
  outline: none;
  border-radius: 0;
}

.form-group input:focus,
.form-group textarea:focus {
  border-color: #cc0000;
}

/* Linha Específica: Código Postal e Localidade */
.gp-cep-localidade {
  display: flex;
  gap: 15px;
}
.cep-inputs {
  display: flex;
  gap: 5px;
}
.input-cp {
  width: 50px !important;
}
.gp-localidade {
  flex: 1; /* Pega o resto do espaço */
}

/* Checkboxes */
.checkbox-list label {
  display: block;
  margin-bottom: 3px;
  font-size: 12px;
  cursor: pointer;
}
.checkbox-list input[type="checkbox"],
.checkbox-copia input[type="checkbox"] {
  margin-right: 5px;
}
.checkbox-copia {
  font-size: 11px !important;
  color: #555 !important;
  display: block !important;
  font-weight: 400;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* Área do Botão */
.form-submit-area {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}

.btn-enviar-proposta {
  background-color: #cc0000;
  color: #fff;
  border: none;
  padding: 5px 35px;
  font-weight: bold;
  font-size: 13px;
  cursor: pointer;
  transition: background 0.3s ease;
}

.btn-enviar-proposta:hover {
  background-color: #a00000;
}

.nota-obrigatoria {
  font-size: 11px;
  color: #666;
  margin-top: 8px;
}

/* =========================================
   BARRA DE FILTROS (TOPO)
========================================= */
.portfolio-filtros-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
  border-bottom: 1px solid #dcdcdc;
  padding: 0;
  min-height: 51px;
}

.portfolio-filtros {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-self: center;
  align-self: center;
  gap: 15px;
}

.portfolio-filtros .filtro-item {
  display: flex;
  align-items: center;
  padding: 5px 11px;
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #555555;
  cursor: pointer;
  border: solid 1px #e5e5e5;
}

/* O item "TODOS" que tem fundo vermelho */
.portfolio-filtros .filtro-item.is-active {
  background-color: #cc0000;
  color: #ffffff;
}

.portfolio-filtros .filtro-item a {
  color: #555555;
  text-decoration: none;
}

.portfolio-filtros .filtro-item.is-active a {
  text-decoration: none;
}

.portfolio-filtros .filtro-item.is-active:first-child a {
  color: #ffffff;
}

/* O quadradinho colorido ao lado do texto no filtro */
.portfolio-filtros .cor-box {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 8px;
}

.portfolio-page {
  background-color: #e9e9e9;
  padding-bottom: 60px;
  margin-bottom: -50px;
}

/* =========================================
   GRID DE PROJETOS E CARTÕES
========================================= */
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 colunas iguais no desktop */
  padding: 0 25px;
  gap: 43px 68px; /* Espaçamento entre os cartões */
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(250px); /* Começa 40px mais para baixo */
  }
  to {
    opacity: 1;
    transform: translateY(0); /* Termina na posição original */
  }
}

.portfolio-card {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
  opacity: 0;
  animation: fadeInUp 0.8s ease forwards;
  transition: all ease-in-out 0.2s;
}

.portfolio-card:hover {
  cursor: pointer;
  box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2); /* Sombra mais forte no hover */
}

.portfolio-card__img-container {
  width: 100%;
  /* Define uma altura fixa para todas as imagens ficarem alinhadas, se necessário */
  aspect-ratio: 4/3;
  overflow: hidden;
  padding: 11px;
}

.portfolio-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Garante que a imagem preencha a área sem distorcer */
}

.portfolio-card__info {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* Empurra os quadradinhos para o final se a altura variar */
  justify-content: space-between;
}

.portfolio-card__titulo {
  font-family: "Roboto Slab", serif;
  font-size: 16px;
  font-weight: 700;
  color: #333333;
  margin: 0 0 20px 0;
}

.portfolio-card__tags {
  display: flex;
  gap: 6px;
  margin-top: auto; /* Joga os quadrados coloridos pro final do card */
}

/* Os quadradinhos coloridos no rodapé do cartão */
.cor-box-small {
  display: inline-block;
  width: 12px;
  height: 12px;
}

/* =========================================
   MENU DROPDOWN DOS FILTROS
========================================= */

/* 1. Prepara o item principal para ser o 'ancoradouro' do submenu */
.portfolio-filtros .has-dropdown {
  position: relative; /* Essencial para o dropdown ficar alinhado com o pai */
}

/* Garante que o título e o ícone fiquem alinhados */
.filtro-item-titulo {
  display: flex;
  align-items: center;
}

/* 3. Os links dentro do Dropdown */
.portfolio-dropdown li {
  padding: 0;
}

.portfolio-dropdown li a {
  display: block;
  padding: 8px 20px;
  color: #555555;
  text-decoration: none;
  font-size: 11px;
  font-weight: 600;
  transition:
    background-color 0.2s,
    color 0.2s;
}

/* Hover no item do dropdown */
.portfolio-dropdown li a:hover {
  background-color: #f9f9f9;
  color: #cc0000; /* Fica vermelho ao passar o mouse */
}

/* 2. O visual da caixinha do Dropdown (Preparada para Animar) */
.portfolio-dropdown {
  position: absolute;
  top: 100%;
  left: -1px;
  background-color: #ffffff;
  border: 1px solid #dcdcdc;
  border-top: none;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  list-style: none;
  padding: 10px 0;
  margin: 0;
  z-index: 100;
  /* Regras de ocultação do desktop */
  display: block;
  visibility: hidden;
  opacity: 0;
  transform: translateY(-15px);
  transition: all 0.2s ease;
  width: 101%;
  box-sizing: border-box;
}

/* 4. A MÁGICA: Exibe o menu com a animação ao passar o mouse (SÓ DESKTOP) */
.portfolio-filtros .has-dropdown:hover .portfolio-dropdown {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
}

/* Muda o cursor para indicar que o título é clicável */
.filtro-item-titulo {
  cursor: pointer;
}

.info {
  color: #333333;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  font-family: "Roboto Slab", serif;
  margin: 28px 0 40px 0;
  text-transform: uppercase;
}

/* ==========================================================================
   FORMULÁRIO DE PESQUISA
   ========================================================================== */

/* Estilo do Input */
.input-pesquisa {
  border-style: solid;
  border-width: 1px;
  border-color: #cccccc;
  box-sizing: border-box;
  background-color: #ffffff;
  width: 207px;
  height: 29px;
  border-radius: 0;
}

/* Quando o utilizador clica dentro do input */
.input-pesquisa:focus {
  box-shadow: none;
  border-color: #999; /* Escurece a borda ligeiramente para dar feedback visual */
}

/* Estilo do Botão */
.btn-pesquisa-vermelho {
  display: inline-block;
  position: relative;
  top: 0px;
  left: 3px;
  border-radius: 0;
  background-color: #cc0000;
  color: #ffffff;
  font-weight: bold;
  font-size: 14px;
  padding: 0 30px;
  text-transform: uppercase;
  border: none; /* Garante que nenhuma borda interfira no alinhamento com o input */
  transition: background-color 0.3s ease; /* Efeito suave na transição de cor */
}

/* Quando o utilizador passa o rato no botão */
.btn-pesquisa-vermelho:hover {
  background-color: #990000;
  color: #ffffff;
}

/* ==========================================================================
   LISTA DE RESULTADOS DA PESQUISA
   ========================================================================== */

/* Container da Lista */
.resultados-lista {
  margin-bottom: 50px;
}

/* Cada Item (Link) */
.resultado-item {
  padding: 30px 0;
  border-bottom: 1px solid #eaeaeb;
  transition: background-color 0.3s ease;
  display: block;
}

/* Remove a borda do último item para ficar limpo */
.resultado-item:last-child {
  border-bottom: none;
}

/* Título do Resultado */
.resultado-titulo {
  font-family: "Roboto Slab", serif;
  color: #333333;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
  margin: 0 0 27px 0;
  cursor: pointer;
}

/* Magia de UX: O título fica vermelho quando passa o rato no item inteiro */
.resultado-item:hover .resultado-titulo {
  color: #cc0000;
}

/* Etiqueta (Notícia / Projeto) */
.resultado-tipo {
  font-size: 11px;
  letter-spacing: 1px;
  color: #666666;
  background-color: #f4f4f4;
  padding: 4px 10px;
  border-radius: 3px;
  text-transform: uppercase;
  font-weight: 600;
}

/* Resumo do Texto */
.resultado-resumo {
  color: #555555;
  line-height: 1.7;
  font-size: 15px;
  margin: 0;
}

/* Caixa de Nenhum Resultado Encontrado */
.resultado-vazio {
  background-color: #fbfbfb;
  border: 1px dashed #dcdcdc;
  padding: 60px 20px;
  text-align: center;
  color: #666666;
  font-size: 16px;
  border-radius: 4px;
}

/* ==========================================================================
   TOPBAR: PESQUISA E IDIOMA (CABEÇALHO)
   ========================================================================== */

/* Container principal que alinha tudo */
.topbar-direita {
  display: flex;
  align-items: center;
  height: 30px; /* Altura fixa para manter tudo perfeitamente alinhado */
}

/* A "Caixa" de pesquisa (Fundo branco com bordas) */
.topbar-search-form {
  display: flex;
  align-items: center;
  background-color: #ffffff;
  height: 100%;
  border-left: 1px solid #d9d9d9;
  border-right: 1px solid #d9d9d9;
  width: 220px; /* Largura da barra de pesquisa */
}

/* O campo de texto transparente e sem bordas */
.topbar-search-input {
  border: none;
  outline: none;
  height: 29px !important;
  background: transparent;
  width: 100% !important;
  font-size: 12px;
  font-weight: normal !important;
  color: #333333;
  background-color: #ffffff !important;
  padding: 0 10px !important;
}

/* O botão com a lupa */
.topbar-search-btn {
  border: none;
  background: transparent;
  padding: 0 10px;
  cursor: pointer;
  color: #999999; /* Cor cinza do ícone da imagem */
  font-size: 14px;
  font-weight: bold;
  transition: color 0.3s ease;
}

.topbar-search-btn:hover {
  color: #cc0000; /* Fica vermelho ao passar o rato (UX) */
}

/* Container do link de Idioma */
.topbar-idioma-wrapper {
  padding: 0 15px;
  display: flex;
  align-items: center;
}

/* Estilo do link ENGLISH */
.topbar-idioma-link {
  font-size: 11px;
  font-weight: bold;
  color: #333333;
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: 0.5px;
  transition: color 0.3s ease;
}

.topbar-idioma-link:hover {
  color: #cc0000;
}

/* ==========================================================================
   PAGINAÇÃO MINIMALISTA
   ========================================================================== */

.paginacao-simples {
  display: flex !important; /* Força o alinhamento horizontal */
  align-self: center;
  justify-self: center;
  list-style: none !important; /* Mata as bolinhas da lista para sempre */
  padding: 0;
  margin: 0;
  gap: 10px; /* Espaço entre os números */
}

.paginacao-simples .page-item {
  display: inline-block;
}

.paginacao-simples .page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  color: #555555; /* Cor do texto padrão */
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  border: 1px solid transparent; /* Invisível por padrão */
  border-radius: 3px;
  transition: color 0.2s ease;
}

/* Estado Ativo: Igual à sua 2ª imagem (Apenas uma borda sutil, sem fundo) */
.paginacao-simples .page-item.active .page-link {
  border-color: #cccccc;
  color: #333333;
  font-weight: bold;
  cursor: default;
}

/* Quando passa o rato num número (Fica vermelho MediaMaster) */
.paginacao-simples .page-item:not(.active):not(.disabled) .page-link:hover {
  color: #cc0000;
}

/* Setas Desativadas */
.paginacao-simples .page-item.disabled .page-link {
  color: #dddddd;
  cursor: not-allowed;
  pointer-events: none;
}
