/* Reset and base */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: #111827;
  background: #ffffff;
  line-height: 1.6;
  /* ADICIONADO PARA FIXAR O FOOTER NA BASE */
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Impede a rolagem do body quando o menu está aberto, reforçado com !important */
body.nav-open {
  overflow: hidden !important; /* Adicionado !important para garantir que não seja sobrescrito */
}

img { max-width: 100%; height: auto; display: block; }

a { color: #0f766e; text-decoration: none; }
a:hover, a:focus { text-decoration: underline; }

.container {
  width: 100%;
  max-width: 1100px;
  padding: 0 16px;
  margin: 0 auto;
}

/* Skip link */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: #111827;
  color: #fff;
  padding: 8px 12px;
  z-index: 1000;
}
.skip-link:focus { left: 8px; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #ffffffcc;
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid #e5e7eb;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between; /* Mantém o logo à esquerda e o menu/hambúrguer à direita */
  min-height: 84px; /* Aumentado em 50% (56px * 1.5 = 84px) */
}
.brand { display: inline-flex; align-items: center; gap: 8px; }
.brand img {
  width: 168px; /* Aumentado em 50% (112px * 1.5 = 168px) */
  height: 42px; /* Aumentado em 50% (28px * 1.5 = 42px) */
}

/* Nav */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
}
.nav-toggle:focus { outline: 2px solid #0ea5e9; outline-offset: 2px; }
.nav-toggle[aria-expanded="true"] { background: #f3f4f6; }

.nav-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(17,24,39,0.45);
  backdrop-filter: blur(2px);
}

.site-nav {
  /* Estilos para mobile (off-canvas) */
  position: fixed;
  top: 0;
  right: 0;
  height: 100dvh;
  background: #fff;
  border-left: 1px solid #e5e7eb;
  transform: translateX(10%);
  transition: transform 200ms ease;
  padding-top: 84px; /* Espaço para a altura do header */
  padding-left: 16px;
  padding-right: 16px;
  z-index: 60;
}
.site-nav .nav-list {
  list-style: none;
  margin: 0;
  /* MODIFICADO: Remove padding horizontal do nav-list */
  padding: 0 0 24px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.site-nav a {
  display: block;
  /* NOVO: Garante que o link ocupe 100% da largura do seu pai (o li) */
  width: 100%;
  padding: 10px 12px; /* Padding interno do link */
  border-radius: 8px;
  color: #111827;
  font-weight: 500;
  white-space: nowrap; /* Impede a quebra de linha */
  overflow: hidden; /* Oculta o texto que transborda */
  text-overflow: ellipsis; /* Adiciona reticências (...) ao texto ocultado */
}
.site-nav a:hover,
.site-nav a:focus { background: #f3f4f6; text-decoration: none; }
.site-nav .nav-aux a { color: #6b7280; }

.nav-open .site-nav { transform: translateX(0); }
.nav-open .nav-backdrop[hidden] { display: block; }
.nav-open .nav-backdrop { display: block; }

/* Desktop nav */
@media (min-width: 960px) {
  .nav-toggle { display: none; } /* Oculta o botão hambúrguer no desktop */
  .site-nav {
    /* Estilos para desktop (inline no cabeçalho) */
    position: static;
    transform: none;
    width: auto;
    height: auto;
    border: 0;
    padding: 0; /* Remove padding também no desktop */
    background: transparent;
    overflow-y: visible;
    overflow-x: visible; /* Garante que não haja ocultação de overflow no desktop */
    will-change: auto;
  }
  .site-nav .nav-list {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 0;
  }
  .site-nav a {
    white-space: normal; /* Restaura o comportamento padrão para desktop */
    overflow: visible;
    text-overflow: clip;
  }
  .nav-backdrop { display: none !important; }
}

/* Main */
.main {
  display: block;
  /* ADICIONADO PARA FIXAR O FOOTER NA BASE */
  flex-grow: 1;
}

/* --- NOVOS ESTILOS PARA IMAGEM PRINCIPAL NA PÁGINA HOME --- */
.home-banner-image {
  padding: 20px 0; /* Algum preenchimento superior/inferior para espaçamento */
  text-align: center; /* Centraliza a imagem */
  border-bottom: 1px solid #e5e7eb; /* Mantém uma linha divisória, similar ao antigo hero */
}

.home-banner-image img {
  max-width: 100%; /* Garante que a imagem seja responsiva */
  height: auto; /* Mantém a proporção da imagem */
  border-radius: 8px; /* Mantém cantos arredondados para desktop */
  margin: 0 auto; /* Centraliza a imagem horizontalmente */
}

@media (max-width: 959px) {
  .home-banner-image img {
    width: 90%; /* Define a largura da imagem para 90% da tela em mobile */
    /* margin: 0 auto; REMOVIDO: Já está no estilo acima, é redundante aqui */
    border-radius: 0; /* Remove o border-radius para mobile */
  }
}
/* --- FIM DOS ESTILOS PARA IMAGEM PRINCIPAL NA PÁGINA HOME --- */

/* --- NOVOS ESTILOS PARA PÁGINA KEYSTONE EMPREENDIMENTOS (IMAGEM) --- */
.keystone-image-wrapper {
  text-align: center; /* Centraliza a imagem no wrapper */
  margin-top: 20px; /* Espaçamento da descrição */
}

.keystone-image-wrapper img {
  max-width: 100%; /* Garante que a imagem seja responsiva para desktop */
  height: auto; /* Mantém a proporção */
  border-radius: 8px; /* Cantos arredondados para desktop */
  display: block; /* Para permitir margin auto */
  margin: 0 auto; /* Centraliza a imagem */
  border: 1px solid #e5e7eb; /* Adiciona uma borda sutil à imagem */
}

@media (max-width: 959px) { /* Mobile */
  .keystone-image-wrapper img {
    width: 90%; /* A imagem terá 90% da largura da tela */
    border-radius: 0; /* Remove cantos arredondados para mobile */
  }
}
/* --- FIM DOS ESTILOS PARA PÁGINA KEYSTONE EMPREENDIMENTOS --- */


/* Features */
.features { padding: 28px 0; }
.grid-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 720px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
}
.card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 16px;
  background: #fff;
  position: relative; /* Adicionado para posicionamento do pseudo-elemento */
  overflow: hidden;   /* Adicionado para conter o pseudo-elemento */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); /* Sombra para os cartões */
}

/* Estilos para as cards específicas com imagens de fundo */
.card-mission,
.card-vision,
.card-values {
  background: transparent; /* Torna o fundo da card transparente para exibir o pseudo-elemento */
  color: #FFFFFF; /* Define a cor do texto para branco */
}

.card-mission h2,
.card-mission p,
.card-vision h2,
.card-vision p,
.card-values h2,
.card-values p {
  color: #FFFFFF; /* Garante que os títulos e parágrafos sejam brancos */
}

.card-mission::before,
.card-vision::before,
.card-values::before {
  content: '';
  position: absolute;
  inset: 0; /* Cobre toda a área da card */
  /* Adiciona o linear-gradient para o overlay escuro */
  background-image: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), var(--card-bg-image);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover; /* Ajusta a imagem para cobrir o espaço */
  opacity: 1; /* A opacidade agora é controlada pelo rgba do gradient */
  z-index: -1; /* Posiciona a imagem atrás do conteúdo da card */
}

/* Definindo as variáveis CSS para as imagens de fundo */
.card-mission { --card-bg-image: url('../img/lote.png'); }
.card-vision { --card-bg-image: url('../img/olho.png'); }
.card-values { --card-bg-image: url('../img/aperto.png'); }


/* CTA */
.cta { padding: 24px 0 40px; }
.cta-inner {
  border: 1px solid #dbeafe;
  border-radius: 14px;
  padding: 20px;
  background: #eff6ff;
  text-align: center;
}

/* Page header */
.page-header { padding: 28px 0; }
.page-header h1 { margin: 0 0 8px 0; }

/* New styles for Contact page layout */
.contact-layout {
  display: flex;
  flex-direction: column; /* Conteúdo empilhado por padrão em mobile */
  gap: 24px; /* Espaço entre texto e imagem quando empilhados */
}

.contact-details {
  /* O texto se ajustará automaticamente */
}

/* NOVOS ESTILOS PARA ITENS DE CONTATO COM ÍCONES */
.contact-item {
  display: flex; /* Para alinhar o ícone com o texto */
  align-items: center; /* Centralizar verticalmente ícone e texto */
  margin-bottom: 8px; /* Espaçamento entre os itens de contato */
}

.contact-link {
  display: inline-flex; /* Para o link e o ícone ficarem juntos */
  align-items: center;
  gap: 8px; /* Espaço entre o ícone e o texto do link */
  color: #111827; /* Cor do texto padrão para links de contato */
  text-decoration: none; /* Remover sublinhado padrão */
}
.contact-link:hover,
.contact-link:focus {
  text-decoration: underline; /* Sublinhado no hover/focus */
  color: #0f766e; /* Cor do link padrão do tema no hover/focus */
}

.contact-icon {
  flex-shrink: 0; /* Impede o ícone de encolher */
  width: 24px;
  height: 24px;
}

/* Estilo específico para o link do WhatsApp para manter a cor da marca */
.contact-link.whatsapp {
    color: #25D366; /* Cor verde para o link do WhatsApp */
}
.contact-link.whatsapp:hover,
.contact-link.whatsapp:focus {
    color: #128C7E; /* Tom mais escuro de verde no hover */
}


.contact-image-wrapper {
  text-align: center; /* Centraliza a imagem em telas menores */
}

.contact-image {
  max-width: 100%; /* Garante que a imagem seja responsiva */
  height: auto;
  border-radius: 8px; /* Borda arredondada opcional para um visual mais limpo */
}

@media (min-width: 960px) { /* Breakpoint alinhado com a navegação desktop */
  .contact-layout {
    flex-direction: row; /* Conteúdo lado a lado para desktop */
    align-items: flex-start; /* Alinha os itens ao topo */
    justify-content: space-between; /* Distribui o espaço entre texto e imagem */
  }

  .contact-details {
    flex: 1; /* Permite que o texto ocupe o espaço disponível */
    max-width: 52%; /* AJUSTADO: Reduzido de 60% para 52% para dar espaço à imagem maior */
  }

  .contact-image-wrapper {
    flex: 1; /* Permite que a imagem ocupe o espaço disponível */
    max-width: 48%; /* AJUSTADO: Aumentado de 40% para 48% (40% * 1.20) para a imagem aparecer 20% maior */
    text-align: right; /* Alinha a imagem à direita do seu contêiner */
  }
}

/* New styles for Services page layout */
.services-content-grid {
  display: flex; /* Default to column for mobile */
  flex-direction: column;
  gap: 24px; /* Space between columns/cards on mobile */
  padding-bottom: 24px; /* Add some padding at the bottom of the grid */
}

/* Ensure lists inside the cards are properly styled */
.services-column-left ul,
.services-column-right ul {
    list-style: disc; /* Use disk for main list items */
    margin-left: 20px;
    margin-bottom: 16px;
    padding: 0;
}

.services-column-left ul ul,
.services-column-right ul ul {
    list-style: circle; /* Use circle for nested list items */
    margin-left: 20px;
    margin-top: 8px;
    margin-bottom: 8px;
}

.services-column-left li,
.services-column-right li {
    margin-bottom: 8px;
}


@media (min-width: 960px) { /* Breakpoint alinhado com a navegação desktop */
  .services-content-grid {
    display: grid;
    grid-template-columns: calc(50% - 16px) calc(50% - 16px); /* Cada coluna tem 50% - 16px, para um gap de 32px */
    gap: 32px; /* Espaço entre colunas no desktop */
  }
}

/* Footer */
.site-footer {
  border-top: 1px solid #e5e7eb;
  background: #fafafa;
  margin-top: 24px;
}
.footer-inner {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 0;
  text-align: center;
  align-items: center;
}
.footer-links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  gap: 12px;
  justify-content: center;
}
@media (min-width: 720px) {
  .footer-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    text-align: left;
  }
  .footer-links {
    justify-content: flex-start;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .site-nav { transition: none; }
}

/* --- ESTILOS PARA A PÁGINA 'QUEM SOMOS' (about-us) --- */
.about-page-header {
  position: relative; /* Define o contexto para posicionamento absoluto */
  overflow: hidden; /* Garante que a imagem de fundo não ultrapasse os limites da seção */
  padding-top: 28px; /* Adiciona padding para o topo da seção */
  padding-bottom: 28px; /* Adiciona padding para a parte inferior da seção */
}

.about-page-header .background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('../img/vila5.png'); /* Caminho da imagem de fundo */
  background-repeat: no-repeat;
  background-position: center center; /* Centraliza a imagem */
  opacity: 0.5; /* 50% de transparência */
  z-index: 0; /* Coloca a imagem atrás do conteúdo */
}

.about-page-header .container {
  position: relative; /* Garante que o texto fique acima do overlay de fundo */
  z-index: 1;
  /* Removidos estilos de moldura daqui, que agora serão aplicados ao .about-content-frame */
}

/* NOVA CLASSE PARA MOLDURA DO CONTEÚDO NA PÁGINA 'QUEM SOMOS' */
.about-content-frame {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 24px; /* Padding para o conteúdo interno da moldura */
  background: #ffffff; /* Fundo branco para o conteúdo */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); /* Sombra suave para destacar a moldura */
  margin-top: 24px; /* Espaço entre os títulos e o conteúdo emoldurado */
}


/* Media query para smartphones (largura máxima de 959px) */
@media (max-width: 959px) {
  .about-page-header .background-overlay {
    background-size: 90% auto; /* 90% da largura, altura automática */
  }
  .about-content-frame { /* Ajustes para a nova moldura em mobile */
    padding: 16px; /* Ajusta o padding para telas menores */
  }
}

/* Media query para desktop (largura mínima de 960px) */
@media (min-width: 960px) {
  .about-page-header .background-overlay {
    background-size: auto 90%; /* Largura automática, 90% da altura */
  }
}
/* --- FIM DOS ESTILOS PARA A PÁGINA 'QUEM SOMOS' --- */