/* ============================================================
   AcheTece — CSS Base (Nível Máximo / Revisado)
   ============================================================ */

/* 0) Variáveis de cor/espaço */
:root{
  --roxo: #8A00FF;
  --azul-hover: #336be3;
  --cinza-100: #f9f9f9;
  --cinza-150: #f6f8fa;   /* Fundo padrão da HOME */
  --cinza-200: #f2f2f2;
  --cinza-300: #eaeaea;
  --cinza-400: #ddd;
  --cinza-500: #cfcfcf;
  --cinza-600: #bfbfbf;
  --cinza-700: #999;
  --cinza-800: #666;
  --cinza-texto: #444;
  --preto: #000;
  --branco: #fff;

  --raio-8: 8px;
  --raio-10: 10px;
  --raio-12: 12px;
  --sombra-1: 0 2px 6px rgba(0,0,0,.06);
  --sombra-2: 0 12px 24px rgba(0,0,0,.12);
  --sombra-3: 0 16px 38px rgba(0,0,0,.18);

  /* utilizado no posicionamento do dropdown no mobile (atualizado via JS) */
  --nav-h: 64px;
}

/* 1) Reset */
*{ margin:0; padding:0; box-sizing:border-box; }
img{ max-width:100%; height:auto; display:block; }

/* 2) Base tipográfica */
body{
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--cinza-texto);
  background: var(--site-bg); /* <- padronizado para o mesmo fundo da HOME */
  line-height:1.4;
}

/* ============================================================
   FAIXA PROMOCIONAL ESTREITA NO TOPO
   ============================================================ */
.promo-bar{
  background:#0f0714; color:#fff;
  display:flex; align-items:center; justify-content:center; gap:12px;
  padding:6px 10px; font-size:14px; line-height:1.2;
}
.promo-text strong{ font-weight:700; }
.promo-cta{
  display:inline-block; background:var(--azul); color:#fff; text-decoration:none;
  padding:6px 10px; border-radius:8px; font-weight:600; white-space:nowrap;
  transition:background .2s ease, transform .12s ease;
}
.promo-cta:hover{ background:var(--azul-hover); transform:translateY(-1px); }
@media (max-width: 600px){
  .promo-bar{ flex-wrap:wrap; row-gap:6px; }
}

/* ====== FAIXA PRETA ESTREITA NO TOPO — mobile centralizado ====== */
@media (max-width: 600px){
  .promo-bar{
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    row-gap: 8px;
    padding: 10px 12px;
  }
  .promo-text{
    display: block;
    width: 100%;
    text-align: center;
  }
  .promo-cta{
    display: inline-block;
  }
}

/* ============================================================
   HEADER / NAVBAR (compacto) + LOGO 3× MAIOR
   ============================================================ */
header{ background: var(--branco); box-shadow: none !important; }
.navbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:4px 16px;
  min-height:52px;
  background:var(--branco);
  position:relative;
  overflow:visible;
}

/* grupos */
.header-left, .header-right{ display:flex; align-items:center; }
.header-right{ margin-left:auto; gap:20px; }

/* área lógica da logo (baixa) */
.logo{
  height:48px; display:flex; align-items:center; line-height:0; position:relative; z-index:1;
}

/* LOGO 3× MAIOR sem aumentar o header */
.logo img{
  height:48px; width:auto;
  transform: scale(3);
  transform-origin: left center;
  will-change: transform;
}

/* dá um respiro entre a logo ampliada e os links */
.header-right{ gap:28px; }

/* responsivo: reduz levemente a ampliação para não sobrepor */
@media (max-width:1200px){ .logo img{ transform: scale(2.4); } }
@media (max-width: 900px){ .logo{ height:44px; } .logo img{ height:44px; transform: scale(2.0); } }
@media (max-width: 600px){ .logo{ height:42px; } .logo img{ height:42px; transform: scale(1.8); } }

/* Links de topo (ao lado da logo) — SEM negrito */
.top-nav{ display:flex; align-items:center; gap:24px; }
.top-nav a{
  color:#17161a; text-decoration:none; font-weight:400; padding:0; line-height:1;
}
.top-nav a:hover{ color:var(--azul); text-decoration:underline; }

/* Esconde links de topo em telas menores (mantém no menu sanduíche) */
@media (max-width: 900px){ .top-nav{ display:none; } }

/* ============================================================
   HAMBURGUER — 3 listras por background-image (sem spans/SVG, sempre visível)
   ============================================================ */

/* Oculta qualquer markup interno para evitar conflito */
button.hamburger span,
button.hamburger svg { display: none !important; }

button.hamburger{
  /* Medidas e variáveis (desktop) */
  --hb-w: 22px;      /* largura da listra */
  --hb-thick: 3px;   /* espessura da listra */
  --hb-gap: 6px;     /* distância do centro até as listras de cima/baixo */

  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  padding:0;
  border:0 !important;
  box-shadow:none !important;
  background-color: transparent !important;
  cursor:pointer;
  line-height:0;
  -webkit-appearance:none;
  appearance:none;

  /* Desenha as 3 listras (forçado) */
  background-image:
    linear-gradient(#111,#111),
    linear-gradient(#111,#111),
    linear-gradient(#111,#111) !important;
  background-repeat: no-repeat !important;
  background-position:
    50% calc(50% - var(--hb-gap)),
    50% 50%,
    50% calc(50% + var(--hb-gap)) !important;
  background-size:
    var(--hb-w) var(--hb-thick),
    var(--hb-w) var(--hb-thick),
    var(--hb-w) var(--hb-thick) !important;
}

/* Acessibilidade */
button.hamburger:focus-visible{
  outline:2px solid rgba(0,0,0,.15);
  outline-offset:2px;
}

/* Mobile: proporções menores */
@media (max-width:768px){
  button.hamburger{
    width:28px;
    height:28px;
    /* Variáveis mobile */
    --hb-w: 18px;
    --hb-thick: 2px;
    --hb-gap: 4px;
  }
}

/* ============================================================
   Botão da casinha — mesmo tamanho/estilo do hambúrguer
   (funciona tanto com .icon-btn quanto .icone-home)
   ============================================================ */
.icon-btn,
.icone-home{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  padding:0;
  background:var(--branco);
  border:3px solid #d6d6d6;
  border-radius:var(--raio-10);
  box-shadow:none !important;
  color:#1c1b22;
  text-decoration:none;
  line-height:1;
  cursor:pointer;
}
.icon-btn svg,
.icone-home svg{
  width:20px;
  height:20px;
}

/* Mobile: mesmas medidas do hambúrguer */
@media (max-width:768px){
  .icon-btn,
  .icone-home{
    width:28px;
    height:28px;
    border-radius:var(--raio-8);
  }
  .icon-btn svg,
  .icone-home svg{
    width:20px;
    height:20px;
  }
}

/* ============================================================
   MENU SUSPENSO (dropdown)
   ============================================================ */
/* Âncora no botão */
.menu-wrap{ position:relative; display:inline-flex; align-items:center; }

/* Painel base — visibilidade controlada por .open */
.menu-dropdown{
  background:var(--branco);
  border:1px solid var(--cinza-300);
  border-radius: var(--raio-12);
  box-shadow: none !important;
  z-index:10000;
  max-height:80vh; overflow:auto; -webkit-overflow-scrolling:touch;

  /* desktop: ancorado ao botão, à direita */
  position:absolute; top:calc(100% + 8px); right:0; left:auto;

  width:auto; min-width:220px; max-width:320px;

  opacity:0; pointer-events:none; visibility:hidden;
  transform: translateY(8px) scale(.98);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.menu-dropdown.open{
  opacity:1; pointer-events:auto; visibility:visible;
  transform: translateY(0) scale(1);
}

/* Cabeçalho: só o X (padronizado) */
.menu-dropdown .menu-header{
  display:flex; justify-content:flex-end; align-items:center;
  padding:8px 10px; background:transparent;
}
.menu-dropdown .menu-header span{ display:none; }
.menu-dropdown .menu-close{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px;
  background:#f0f2f5; border:0; border-radius:10px; cursor:pointer;
  padding:0; line-height:1; color:#1c1b22;
}
.menu-dropdown .menu-close:hover{ background:#e9ebee; }
.menu-dropdown .menu-close:active{ background:#e3e5e9; }
.menu-dropdown .menu-close svg{ display:block; }

.menu-dropdown .menu-item{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:10px;
  color:#24292f; text-decoration:none; font-weight:400;
  background:transparent; transition: background-color .15s ease, color .15s ease;
}
.menu-dropdown .menu-item:hover{ background:#f6f8fa; color:#111; }
.menu-dropdown .menu-item .icon{
  width:18px; height:18px; flex:0 0 18px; color: currentColor; stroke: currentColor; fill:none; stroke-width:2;
}

/* Mobile: centralizado na tela, logo abaixo do header (ajuste de largura) */
@media (max-width:768px){
  .menu-dropdown{
    position: fixed;
    top: calc(var(--nav-h, 64px) + 8px);
    left: 50%;
    right: auto;
    width: max-content;
    max-width: 90vw;
    min-width: 160px;
    padding: 4px 0;
    transform: translate(-50%, 8px) scale(.98);
    transform-origin: top center;
    -webkit-overflow-scrolling: touch;
    border-radius:14px;
  }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ text-align:center; padding:40px 20px; }
.hero img{ width:100%; max-width:640px; border-radius:10px; margin:0 auto 20px; }
.hero h1{ font-size:1.8rem; color:#000; margin-bottom:6px; }
.hero p{ font-size:1rem; color:var(--cinza-texto); max-width:700px; margin:0 auto; }

/* Área de cadastro (mantida p/ páginas internas) */
.area-cadastro{ display:flex; flex-direction:column; align-items:center; gap:6px; margin-top:24px; }
.frase-cadastro{ font-size:16px; font-weight:700; color:#333; }
.btn-principal{
  display:inline-block; background:var(--azul); color:var(--branco);
  padding:10px 24px; font-size:15px; border-radius:10px; text-decoration:none; font-weight:700;
  transition: background-color .25s ease, box-shadow .25s ease;
}
.btn-principal:hover{ background:var(--azul); box-shadow:none !important; }
.botao-login{
  display:inline-block; background:#fff; color:var(--azul);
  border:1px solid var(--azul); border-radius:10px; padding:12px 24px;
  font-weight:700; text-decoration:none; transition: background-color .2s, color .2s, border-color .2s, box-shadow .2s;
}
.botao-login:hover{ background:var(--azul); color:#fff; border-color:var(--azul); box-shadow:none !important; }

/* ============================================================
   CTA PRETA (acima do rodapé)
   ============================================================ */
.cta-bar{
  background:#0f0714; color:#fff; padding:20px 16px;
  display:flex; align-items:center; justify-content:flex-start; gap:12px; flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.06); margin-top:32px; text-align:left;
}
.cta-text h3{ margin:0 0 4px 0; font-size:18px; font-weight:700; line-height:1.2; }
.cta-text p{ margin:0; font-size:15px; opacity:.9; }
.cta-btn{
  display:inline-block; background:#fff; color:#2a2535; text-decoration:none;
  padding:10px 18px; border-radius:10px; font-weight:600; box-shadow:none !important;
  transition: transform .12s ease, background .2s ease, box-shadow .2s ease; white-space:nowrap;
}
.cta-btn:hover{ background:#f2f2f5; transform:translateY(-1px); box-shadow:none !important; }
@media (max-width: 720px){
  .cta-text h3{ font-size:16px; }
  .cta-text p{ font-size:14px; }
}

/* ===== Rodapé (igual ao index, com logo_simbolo à esquerda) ===== */
footer{
  background:#fff;
  border-top:1px solid #e5e5e5;
  padding:30px 20px;
  margin-top:40px;
}
.footer-container{
  max-width:1000px;
  margin:0 auto;
}
.footer-block{
  display:grid;
  grid-template-columns: 42px 1fr;
  column-gap:12px;
  align-items:start;
}
.footer-logo{
  width:32px; height:auto; display:block; margin-top:2px;
}
.footer-title{
  font-size:15px; font-weight:700; color:#111; margin:0 0 10px 0;
}
.footer-links{ list-style:none; margin:0; padding:0; }
.footer-links li{ margin-bottom:8px; }
.footer-links a{
  text-decoration:none; color:#222; font-size:14px; transition:color .2s;
}
.footer-links a:hover{ color:var(--azul); }

@media (max-width:520px){
  .footer-block{ grid-template-columns:36px 1fr; column-gap:10px; }
  .footer-logo{ width:30px; }
}

/* ============================================================
   NAVEGAÇÃO “ANTIGA” (compatibilidade)
   ============================================================ */
.nav-links{ list-style:none; display:flex; align-items:center; gap:16px; margin:0; padding:0; flex-wrap:wrap; justify-content:center; }
.nav-links li a{
  color:#fff; background:var(--azul); text-decoration:none; font-weight:700; font-size:16px;
  padding:10px 18px; border-radius: var(--raio-8); transition: background-color .2s ease;
}
.nav-links li a:hover{ background:var(--azul); }
.texto-visitante{ font-size:14px; color:#333; }
.botao-buscar-topo{
  background:var(--azul); color:#fff; padding:8px 16px; border-radius:6px; text-decoration:none; font-weight:700; font-size:14px;
}

/* ============================================================
   CONTAINERS / FORM / TABELAS / PAINEL (preservado)
   ============================================================ */
.container{
  max-width:900px; margin:40px auto; padding:30px; background:var(--branco);
  border-radius:16px; box-shadow:none !important;
}
.logo-formulario{ text-align:center; margin-bottom:20px; }
.logo-formulario img{ max-width:180px; }
.titulo{ text-align:center; color:#000; margin-bottom:30px; font-size:26px; }

.formulario label{ display:block; margin-top:15px; font-weight:700; color:#000; }
.formulario input, .formulario select{
  width:100%; padding:10px; margin-top:5px;
  border:1px solid #ccc; border-radius: var(--raio-8);
  background:#f9f9f9; font-size:14px;
}

.botao-salvar{
  width:auto; margin-top:30px; padding:12px 24px;
  background:var(--azul); color:#fff; border:0; border-radius: var(--raio-10);
  font-size:16px; font-weight:700; cursor:pointer; transition: background-color .25s ease, box-shadow .25s ease;
}
.botao-salvar:hover{ background:var(--azul); box-shadow:none !important; }

.botao-editar{
  display:inline-block; padding:8px 14px; background:var(--azul); color:#fff;
  border-radius: var(--raio-8); text-decoration:none; font-size:14px; font-weight:700; transition: background-color .25s ease;
}
.botao-editar:hover{ background:var(--azul); }

.table-wrapper{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
table{ width:100%; min-width:900px; margin-top:20px; border-collapse:collapse; }
th, td{
  padding:10px; text-align:center; vertical-align:middle; border-bottom:1px solid #ddd; font-size:14px; white-space:nowrap;
}
thead tr{ background:#f2f2f2; }

.btn-whatsapp{
  background:#25D366; color:#fff; padding:8px 16px; border-radius: var(--raio-8);
  text-decoration:none; font-weight:700; font-size:14px; display:inline-block; transition: background-color .2s ease; text-align:center; white-space:nowrap;
}
.btn-whatsapp:hover{ background:#25D366; }

.painel-acoes{
  display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin:20px 0 30px;
}
.painel-acoes a{
  text-decoration:none; font-weight:700; font-size:14px; padding:10px 20px; border-radius: var(--raio-8);
  text-align:center; transition: background-color .2s ease;
}
.btn-cinza{ background:#444; color:#fff; }
.btn-azul-medio{ background:var(--azul); color:#fff; }
.btn-azul-forte{ background:var(--azul); color:#fff; }

.erro-campo{ border:2px solid red; background:#fff5f5; }
.mensagem-campo{ color:red; font-size:13px; margin-top:-10px; margin-bottom:12px; }

.plano-box{
  background:#e6f0ff; border:2px solid var(--azul); border-radius:12px;
  padding:20px; margin:30px auto; text-align:center; max-width:300px;
}
.plano-titulo{ font-size:18px; color:var(--azul); margin-bottom:6px; font-weight:600; }
.plano-preco{ font-size:28px; font-weight:700; color:var(--azul); }

.flash-message{ text-align:center; font-size:16px; margin-bottom:20px; font-weight:700; }
.flash-message.error{ color:red; }
.flash-message.success{ color:green; }

@media (max-width: 768px){
  .container{ margin:20px; padding:20px; }
  .titulo{ font-size:22px; }
  .botao-salvar, .botao-editar, .botao-cadastrar{ font-size:15px; max-width:100%; }
}

/* ===== Cookie Consent (modal central) ===== */
.cookie-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.55);
  z-index:99998;
}
.cookie-modal{
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  z-index:99999;
}
.cookie-card{
  width:min(720px, 92vw);
  background:#fff; color:#111;
  border:2px solid #d6d6d6;
  border-radius:16px;
  box-shadow:none !important;
  padding:22px;
}
.cookie-card h2{
  font-size:28px; line-height:1.2; margin-bottom:12px; color:#111;
}
.cookie-text{
  font-size:16px; line-height:1.6; color:#222; margin-bottom:16px;
}
.cookie-link{ color:var(--azul); text-decoration:underline; }

.cookie-actions{
  display:flex; flex-wrap:wrap; gap:12px; margin-top:14px;
}
.btn-cookie{
  flex:1 1 220px;
  background:#111; color:#fff; border:0;
  padding:14px 18px; border-radius:999px; font-weight:600;
  cursor:pointer; transition:transform .05s ease, opacity .2s ease;
}
.btn-cookie:hover{ opacity:.92; }
.btn-cookie:active{ transform:scale(.98); }

.btn-cookie-outline{
  flex:1 1 220px;
  background:#fff; color:#111; border:2px solid #111;
  padding:14px 18px; border-radius:999px; font-weight:600;
  cursor:pointer; transition:background .2s ease, color .2s ease, transform .05s ease;
}
.btn-cookie-outline:hover{ background:#111; color:#fff; }
.btn-cookie-outline:active{ transform:scale(.98); }

.cookie-prefs{
  background:#f6f8fa;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:12px;
  margin:8px 0 10px;
}
.cookie-switch{
  display:flex; align-items:center; gap:10px;
  padding:6px 4px; font-size:15px; color:#222;
}
.cookie-switch input{ width:18px; height:18px; }

#ck-modal[hidden], #ck-backdrop[hidden]{ display:none !important; }

/* ===== Hero novo ===== */
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 28px;
  align-items: center;
  padding: 28px 20px 8px;
  max-width: 1120px;
  margin: 0 auto;
}
.hero-copy h1{
  font-size: clamp(24px, 3.2vw, 36px);
  color:#000;
  margin: 10px 0 8px;
  line-height: 1.2;
}
.hero-copy p{
  font-size: clamp(14px, 1.6vw, 18px);
  color:#444;
  margin: 0 0 14px;
}

.role-toggle{ display:flex; gap:8px; }
.chip{
  appearance: none;
  border:1px solid #d6d6d6;
  background:#fff;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  font: inherit;
}
.chip.is-active{ background:#0f0714; color:#fff; border-color:#0f0714; }

.hero-ctas{ display:flex; gap:12px; align-items:center; margin: 8px 0 10px; }
.link-inline{ color:#8A00FF; text-decoration:none; }
.link-inline:hover{ text-decoration:underline; }

.hero-badges{
  display:flex; gap:10px; flex-wrap:wrap;
  list-style:none; padding:0; margin:6px 0 0;
}
.hero-badges li{
  font-size: 13px;
  background:#f6f8fa;
  border:1px solid #e6e7eb;
  padding:6px 10px;
  border-radius:999px;
}

.hero-figure img{
  width:100%;
  border-radius:10px;
  display:block;
}

@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; gap: 18px; padding-top: 18px; }
  .hero-figure{ order:-1; }
}

/* ===== Como funciona ===== */
.how-it-works{
  max-width: 1120px;
  margin: 22px auto 8px;
  padding: 0 20px 20px;
}
.how-it-works h2{
  font-size: clamp(20px, 2.4vw, 28px);
  margin: 0 0 8px;
  color:#000;
  text-align:center;
}
.steps{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
}
.step{
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  padding:16px;
  text-align:center;
}
.step-ico{ font-size: 22px; margin-bottom:6px; }
.step h3{ font-size:16px; margin:0 0 4px; color:#111; }
.step p{ font-size:14px; color:#555; margin:0; }

@media (max-width: 900px){
  .steps{ grid-template-columns: 1fr; }
}

/* --------------- ATENÇÃO: bloco duplicado do hambúrguer removido --------------- */
/* (não há mais CSS do hambúrguer dentro de @media para evitar conflito) */

/* Mobile (ajustes diversos já aprovados) */
@media (max-width: 768px) {

  .titulo-privacidade{
    text-align: center;
    margin-bottom: 28px;
  }
  
  .titulo-privacidade h1{
    font-size: 28px;
    font-weight: 800;
    color: #111;
    line-height: 1.3;
  }

  /* Ajuste do tamanho da fonte dos links da navbar */
  .header-right a {
    font-size: 12px; /* ou 13px, se quiser menor */
  } 
   
  .container-termos{
    max-width: 940px;
    width: 90%;
    margin: 40px auto;
    padding: 32px 48px;
    background:#fff;
    border:1px solid #eee;
    border-radius: 10px;
    box-shadow: none !important;

    /* --- Roxo da marca para botões (sem afetar o restante do site) --- */

    /* Paleta roxa (ajuste os hex se quiser) */
    :root {
      --roxo-primario: #7B00FF;
      --roxo-hover:    #9E37FF;
      --roxo-ring:     #E4D4FF;
    }

    /* Sobrescreve APENAS nos botões que hoje herdam --azul */
    button, .btn, [class*="btn-"], input[type="submit"], a.btn {
      --azul:  var(--roxo-primario);
      --azul-2: var(--roxo-hover);
    }

    /* Caso algum botão tenha a cor fixa em #003bb3, forçamos a troca aqui */
    button, .btn, [class*="btn-"], input[type="submit"], a.btn {
      background-color: var(--roxo-primario) !important;
      border-color:     var(--roxo-primario) !important;
      color: #fff;
    }
    button:hover, .btn:hover, [class*="btn-"]:hover,
    button:focus, .btn:focus, [class*="btn-"]:focus {
      background-color: var(--roxo-hover) !important;
      border-color:     var(--roxo-hover) !important;
      outline: 3px solid var(--roxo-ring);
      outline-offset: 2px;
    }

    /* mantém o raio/altura dos seus botões atuais; remova se já existir */
    button, .btn, [class*="btn-"], input[type="submit"], a.btn {
      border-radius: 999px;
      font-weight: 700;
    }

    /* ===== Layout de duas colunas (sidebar + conteúdo) ===== */
   .search-layout{
     display:grid;
     grid-template-columns: 300px 1fr;   /* largura da sidebar */
     gap:24px;
     align-items:start;
     margin-top:16px;
   }
   
   /* Botão de filtro (mobile) */
   .filters-toggle{
     display:none;
     border:1px solid #e5e5ea;
     background:#fff;
     padding:10px 14px;
     border-radius:10px;
     font-weight:600;
   }
   
   /* ===== Sidebar ===== */
   .filters-panel{
     background:#fff;
     border:1px solid #ececf1;
     border-radius:14px;
     padding:16px;
     box-shadow: 0 1px 2px rgba(0,0,0,0.03);
     position:sticky;        /* fica fixa ao rolar */
     top:88px;               /* ajuste conforme a altura do seu cabeçalho */
     height:fit-content;
   }
   
   .filters-title{
     font-size:18px;
     margin:0 0 10px 0;
     font-weight:700;
   }
   
   .filter-field{ margin-bottom:14px; }
   .filter-field label{
     display:block;
     font-size:14px;
     margin-bottom:6px;
     color:#555;
   }
   
   /* Inputs/Selects compactos (estilo OLX) */
   .filters-panel select,
   .filters-panel input{
     width:100%;
     height:44px;
     border:1px solid #e6e6e9;
     background:#f7f7f8;
     border-radius:10px;
     padding:0 12px;
     font-size:14px;
   }
   
   /* Ações */
   .filter-actions{
     display:flex;
     align-items:center;
     gap:12px;
     margin-top:8px;
   }
   .btn-primary{
     border:0;
     padding:10px 16px;
     border-radius:12px;
     background:#8A00FF;            /* roxo da sua identidade */
     color:#fff;
     font-weight:700;
     cursor:pointer;
   }
   .btn-primary:hover{ filter:brightness(0.95); }
   .link-reset{
     font-size:14px;
     color:#8A00FF;
     text-decoration:underline;
   }

   /* ===== Autocomplete (typeahead) ===== */
   .typeahead-wrap{
     position: relative;
   }
   
   .typeahead-list{
     position: absolute;
     left: 0;
     right: 0;
     top: calc(100% + 6px);
     margin: 0;
     padding: 6px 0;
     list-style: none;
     background: #fff;
     border: 1px solid #e6e6e6;
     border-radius: 12px;
     box-shadow: 0 8px 24px rgba(0,0,0,0.08);
     max-height: 320px;
     overflow-y: auto;
     z-index: 1000;
     display: none; /* escondido por padrão */
   }
   
   .typeahead-list.show{
     display: block;
   }
   
   .typeahead-item{
     padding: 10px 14px;
     cursor: pointer;
     font-size: 15px;
     line-height: 1.2;
     display: flex;
     align-items: center;
     gap: 8px;
   }
   
   .typeahead-item:hover,
   .typeahead-item[aria-selected="true"]{
     background: #f4f0ff; /* leve roxo do seu tema */
   }
   
   .typeahead-item .pin{
     width: 18px;
     height: 18px;
     display: inline-block;
     border-radius: 50%;
     background: #8A00FF; /* roxo da marca */
     opacity: .9;
   }
   
   .typeahead-empty{
     padding: 10px 14px;
     color: #777;
     font-size: 14px;
   }
     
   /* ===== Painel de resultados ===== */
   .results-panel{
     background:transparent; /* deixe seu conteúdo como já está */
     min-height:200px;
   }
   
   /* ===== Responsivo ===== */
   @media (max-width: 992px){
     .search-layout{
       grid-template-columns: 1fr;
     }
     .filters-toggle{
       display:inline-flex;
       margin:8px 0 0 0;
     }
     /* Sidebar vira “off-canvas” */
     .filters-panel{
       position:fixed;
       left:0; top:0; bottom:0;
       width:88%;
       max-width:360px;
       border-radius:0 14px 14px 0;
       transform:translateX(-110%);
       transition:transform .25s ease;
       z-index:9999;
       overflow:auto;
     }
     .filters-panel.is-open{
       transform:translateX(0);
     }
     body.filters-open{
       overflow:hidden; /* trava o scroll do fundo ao abrir filtros */
     }

   /* ===== Layout de busca ===== */
   .search-outer{
     max-width: 1200px;
     margin: 0 auto;
     padding: 0 16px;
   }
   
   .search-layout{
     display: grid !important;
     grid-template-columns: 320px minmax(0, 1fr);
     gap: 24px;
     align-items: start;
   }
   
   /* Sidebar (coluna esquerda) */
   .filters-panel{
     width: 320px;
     background: #fff;
     border: 1px solid #ececf1;
     border-radius: 14px;
     padding: 16px;
     box-shadow: 0 1px 2px rgba(0,0,0,.03);
     position: sticky;
     top: 88px;
     height: fit-content;
   }
   .filters-title{font-size:18px;margin:0 0 10px;font-weight:700}
   .filter-field{margin-bottom:14px}
   .filter-field label{display:block;font-size:14px;margin-bottom:6px;color:#555}
   .filters-panel select{
     width:100%;height:44px;border:1px solid #e6e6e9;background:#f7f7f8;
     border-radius:10px;padding:0 12px;font-size:14px
   }
   .filter-actions{display:flex;align-items:center;gap:12px;margin-top:8px}
   .btn-primary{border:0;padding:10px 16px;border-radius:12px;background:#8A00FF;color:#fff;font-weight:700;cursor:pointer}
   .btn-primary:hover{filter:brightness(.95)}
   .link-reset{font-size:14px;color:#8A00FF;text-decoration:underline}
   
   /* Coluna direita (resultados) */
   .results-panel{min-width:0}
   .results-panel.container{width:auto;max-width:none;padding:0}

   /* ===== Caixa de localização na coluna direita ===== */
   .localizacao-box{
     background:#fff;
     border:1px solid #e9e9e9;
     border-radius:12px;
     padding:16px;
     margin-bottom:16px;
   }
   .localizacao-titulo{
     margin:0 0 12px;
     font-size:16px;
     font-weight:800;
     color:#111;
   }
   .localizacao-box label{
     display:block;
     margin:10px 0 6px;
     font-weight:700;
     font-size:14px;
     color:#333;
   }
   .localizacao-box select{
     width:100%;
     padding:12px;
     border:1px solid #ccc;
     border-radius:8px;
     font-size:14px;
     margin-bottom:8px;
     background:#fff;
   }
   .localizacao-box select option[disabled]{
     color:#003bb3;
     font-weight:500;
   }
     
   /* Mobile: filtros viram painel lateral */
   @media (max-width: 992px){
     .search-layout{grid-template-columns: 1fr}
     .filters-toggle{display:inline-flex;margin:8px 0;border:1px solid #e5e5ea;background:#fff;padding:10px 14px;border-radius:10px;font-weight:600}
     .filters-panel{
       position: fixed; left:0; top:0; bottom:0;
       width: 88%; max-width: 360px;
       border-radius: 0 14px 14px 0;
       transform: translateX(-110%);
       transition: transform .25s ease;
       z-index: 9999; overflow:auto;
     }
     .filters-panel.is-open{transform: translateX(0)}
     body.filters-open{overflow:hidden}

   /* ===== Caixa da coluna direita ===== */
   .localizacao-box{
     background:#fff; border:1px solid #e9e9e9; border-radius:12px; padding:16px; margin-bottom:16px;
   }
   .localizacao-titulo{ margin:0 0 12px; font-size:16px; font-weight:800; color:#111; }
   .localizacao-box label{ display:block; margin:10px 0 6px; font-weight:700; font-size:14px; color:#333; }
   .localizacao-box select{
     width:100%; padding:12px; border:1px solid #ccc; border-radius:8px; font-size:14px; margin-bottom:8px; background:#fff;
   }
   .localizacao-box select:disabled{ background:#f5f5f5; color:#777; cursor:not-allowed; }
   .localizacao-box select option[disabled]{ color:#003bb3; font-weight:500; } /* placeholder azul */

   .btn-whats {
     display:inline-block; padding:6px 10px; border-radius:8px;
     background:#25D366; color:#fff; text-decoration:none; font-weight:600;
   }

   /* ===== Mobile-first – evita rolagem lateral ===== */
   html, body { max-width: 100%; overflow-x: hidden; }
   *, *::before, *::after { box-sizing: border-box; }
   
   /* container seguro no mobile */
   @media (max-width: 768px){
     .container { max-width: 100% !important; padding-inline: 12px !important; }
   }
   
   /* ===== Layout da busca ===== */
   .layout-busca{
     display: grid;
     grid-template-columns: 320px 1fr;
     gap: 24px;
     align-items: start;
   }
   @media (max-width: 992px){ .layout-busca{ grid-template-columns: 280px 1fr; gap:16px; } }
   @media (max-width: 768px){ .layout-busca{ grid-template-columns: 1fr; } }
   
   /* Painel de filtros (desktop) */
   .filtros{
     background:#fff; border:1px solid #eee; border-radius:16px;
     padding:16px; max-width:360px; width:100%;
   }
   .filtros .campo{ margin-bottom:12px; }
   .filtros label{ font-weight:700; display:block; margin-bottom:6px; }
   .filtros select, .filtros input{ width:100%; }
   
   /* Botões do topo (estilo OLX) */
   .busca-header{
     display:flex; align-items:center; gap:12px; margin-bottom:12px;
   }
   .btn-filtros{
     display:inline-flex; align-items:center; gap:8px; border:1px solid #ddd;
     padding:10px 14px; border-radius:12px; background:#fff; cursor:pointer;
   }
   
   /* Drawer de filtros no mobile */
   .fechar-filtros{ display:none; }
   @media (max-width: 768px){
     .btn-filtros{ display:inline-flex; }
     .filtros{
       position: fixed; inset: 0; width:100%; height:100%; max-width:none;
       transform: translateX(-110%); transition: transform .25s ease;
       z-index: 9999; overflow-y: auto; padding:18px;
     }
     .filtros.filtros--aberto{ transform: translateX(0); }
     .fechar-filtros{
       display:inline-flex; align-items:center; justify-content:center;
       width:40px; height:40px; border-radius:12px; border:1px solid #eee;
       background:#fff; margin-left:auto;
     }
   }
   
   /* ===== Lista de resultados (cards) ===== */
   .resultados{
     display:grid; grid-template-columns:1fr; gap:12px;
   }
   @media (min-width: 768px){ .resultados{ grid-template-columns: repeat(2, 1fr); } }
   @media (min-width: 1100px){ .resultados{ grid-template-columns: repeat(3, 1fr); } }
   
   .card-tear{
     background:#fff; border:1px solid #eee; border-radius:16px;
     padding:14px; transition: box-shadow .2s ease, border-color .2s ease;
   }
   .card-tear:hover{ border-color:#ddd; box-shadow:0 2px 10px rgba(0,0,0,.04); }
   
   .card-titulo{
     font-weight:700; font-size:1rem; line-height:1.35; margin:0 0 8px;
   }
   .card-meta{ font-size:.875rem; color:#555; display:flex; gap:16px; flex-wrap:wrap; }

   /* =====================  QUEM SOMOS – AJUSTES  ===================== */
   :root{
     --roxo:#8A00FF;
     --roxo-hover:#A63DFF;
     --cinza-900:#1F2937;
     --cinza-700:#374151;
     --cinza-500:#6B7280;
     --cinza-200:#E5E7EB;
     --card-borda:#E8EAF1;
   }
   
   /* Espaço entre título e frase (lead) */
   .qs-hero h2{ margin:0; color:var(--cinza-900); letter-spacing:-0.01em; }
   .qs-hero .lead{
     margin-top: 12px;            /* <= aumenta o espaço solicitado */
     color: var(--cinza-500);
     line-height: 1.6;
   }
   
   /* Container do bloco “Como o AcheTece resolve” */
   .qs-hero{
     padding: 24px;
     border:1px solid var(--card-borda);
     border-radius: 18px;
     background:#fff;
   }
   
   /* CTAs com troca de cores no hover (swap) */
   .qs-ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-top:16px; }
   .btn-swap{
     display:inline-flex; align-items:center; justify-content:center;
     height:46px; padding:0 20px; border-radius:9999px;
     font-weight:700; border:2px solid var(--roxo);
     transition: all .18s ease-in-out; cursor:pointer; text-decoration:none;
   }
   .btn-swap:focus-visible{ outline:3px solid var(--roxo-hover); outline-offset:2px; }
   
   /* Primário (roxo) -> branco no hover */
   .btn-swap.principal{ background:var(--roxo); color:#fff; }
   .btn-swap.principal:hover{ background:#fff; color:var(--roxo); }
   
   /* Secundário (branco) -> roxo no hover */
   .btn-swap.secundario{ background:#fff; color:var(--roxo); }
   .btn-swap.secundario:hover{ background:var(--roxo); color:#fff; }
   
   /* Bloco de contato com cara de “Fale Conosco” */
   .qs-contact{
     position:relative;
     padding: 28px 24px;
     border-radius:18px;
     background: #F4F7FF;
     border: 1px solid #CFE0FF;
     box-shadow: 0 1px 0 #E2E8FF inset;
   }
   .qs-contact:before{
     content:""; position:absolute; left:0; top:0; right:0; height:4px;
     background: linear-gradient(90deg, var(--roxo), var(--roxo-hover));
     border-top-left-radius:18px; border-top-right-radius:18px;
   }
   .qs-contact h3{ margin:0 0 10px 0; color:var(--cinza-900); }
   .qs-contact p.sub{ margin:0 0 16px 0; color:var(--cinza-500); }
   
   .qs-contact .items{ display:grid; gap:12px; }
   .qs-contact .item{
     display:flex; align-items:center; gap:12px;
     background:#fff; border:1px solid var(--card-borda);
     border-radius:12px; padding:12px 14px;
   }
   .qs-contact .item svg{ flex:0 0 22px; color:var(--roxo); }
   
   /* Mini-CTAs no contato */
   .qs-contact .actions{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
   .qs-contact .actions a{ text-decoration:none; }
   
   /* Cartões gerais desta página (bordas/contorno sugestão) */
   .qs-card{
     background:#fff; border:1px solid var(--card-borda); border-radius:16px;
   }
   @media (max-width: 720px){
     .qs-ctas .btn-swap{ width:100%; }
   }

   /* === Fundo global do site (mesmo da home) === */
   :root{
     --site-bg: var(--cinza-150);  /* usa exatamente o cinza da HOME (#f6f8fa) */
   }
   
   /* Fundo global sempre igual à home */
   html{ color-scheme: light; }        /* evita dark mode automático do celular */
   html, body{
     background: var(--site-bg);
     color: var(--cinza-900);
   }
   
   /* Qualquer seção/faixa que deva ter o mesmo fundo da home */
   .bg-site{
     background: var(--site-bg);
   }

   :root{
     /* use seu cinza 150; troque o hex se já tiver outra referência */
     --cinza-150: #F3F4F6;
   }
   
   /* Faixa cinza que envolve todo o conteúdo até a faixa preta */
   .faixa-cinza {
     background: var(--cinza-150);
     padding: 24px 0 56px;   /* respiro acima/abaixo */
   }
   
   /* Se houver alguma regra global pintando as sections/container de branco, neutraliza aqui */
   .faixa-cinza section,
   .faixa-cinza .container {
     background: transparent !important;
   }
   
   /* Garante que só os cartões/caixas continuem brancos */
   .card, .box, .painel, .tabela, .filtros, .lista-teares, .table-wrap {
     background: #fff;
     border-radius: 16px;
     box-shadow: 0 1px 2px rgba(0,0,0,.04);
   }
   
   /* Título/hero dentro do cinza */
   .hero-miolo {
     margin: 0 auto 16px;
     max-width: 1200px;
     padding: 16px 16px 0;
     background: transparent;
   }

   .link-roxo{ color:#8A00FF; font-weight:700; text-decoration:none; }
   .link-roxo:hover{ text-decoration:underline; }

      
