:root{
  --bg:#0b1420;
  --navy-900:#0A2342;
  --navy-800:#0d3052;
  --navy-700:#13406f;
  --slate-300:#cbd5e1;
  --slate-400:#94a3b8;
  --slate-500:#74839b;
  --white:#ffffff;
  --accent:#1E88E5;
  --accent-2:#22B07D;
  --radius:14px;
  --shadow:0 14px 40px rgba(2,6,23,.22);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--slate-300);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif}
a{color:var(--slate-300);text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1120px,92%);margin-inline:auto}

/* Topbar */
.topbar{background:var(--navy-900);color:var(--slate-300);font-size:14px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:8px 0}
.topbar .socials{display:flex;gap:10px;align-items:center}
.topbar a{opacity:.95}

/* Header */
header{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,rgba(10,35,66,.95),rgba(10,35,66,.85));backdrop-filter:saturate(120%) blur(4px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;gap:12px;align-items:center}
.logo{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--navy-800),var(--navy-700));display:grid;place-items:center;color:#fff;font-weight:800;letter-spacing:.5px}
.brand h1{font:700 18px/1.1 Merriweather,serif;margin:0;color:#fff}
.btn{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;font-weight:700;border:1px solid transparent;transition:transform .15s ease, box-shadow .15s ease, background .15s ease}
.btn:hover{transform:translateY(-1px)}
.nav a.btn{background:var(--accent);color:#0b1220;box-shadow:0 8px 20px rgba(30,136,229,.35)}
.nav a.btn.secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.18);box-shadow:none}
.nav a.btn.secondary:hover{background:rgba(255,255,255,.06)}

/* Hero */
.hero{position:relative;padding:80px 0 64px;background:radial-gradient(1000px 400px at 10% -10%,rgba(30,136,229,.18),transparent), radial-gradient(900px 500px at 110% 10%,rgba(34,176,125,.12),transparent)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center}
.eyebrow{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--slate-300);padding:8px 12px;border-radius:999px;font-weight:600}
.hero h2{font:700 clamp(30px,4.5vw,48px)/1.08 Merriweather,serif;color:#fff;margin:18px 0 12px}
.hero p{color:var(--slate-400);font-size:18px}
.cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.btn.primary{background:var(--accent);color:#0b1220}
.btn.secondary{background:transparent;border-color:rgba(255,255,255,.18);color:#fff}
.hero-card{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}
.hero-card img{filter:saturate(.9) contrast(1.02)}
.hero-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,20,32,0),rgba(11,20,32,.25))}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}
.k{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px;text-align:center}
.k h4{margin:0;font:700 22px/1 Inter;color:#fff}
.k p{margin:6px 0 0;color:var(--slate-500);font-size:13px}

/* Sections */
.section{padding:64px 0;border-top:1px solid rgba(255,255,255,.06)}
.section h3{font:700 26px/1.2 Merriweather,serif;margin:0 0 14px;color:#fff}
.lead{color:var(--slate-400);margin:0 0 24px}

/* Services */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px;min-height:168px;transition:transform .18s ease, background .18s ease}
.card:hover{transform:translateY(-2px);background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.05))}
.card .icon{font-size:24px;opacity:.9}
.card h4{margin:0;font:700 18px/1.2 Inter;color:#fff}
.card p{margin:0;color:var(--slate-400)}

/* Differentials band */
.band{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:center;background:linear-gradient(135deg,rgba(30,136,229,.12),rgba(34,176,125,.10));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:24px}
.band ul{margin:0;padding-left:18px;color:var(--slate-300)}

/* Blog */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:18px;min-height:160px;transition:transform .18s ease}
.post:hover{transform:translateY(-2px)}
.post-date{display:block;color:var(--slate-500);font-size:13px;margin-bottom:6px}
.post-title{margin:6px 0 8px;color:#fff;font:700 18px/1.3 Inter}
.post-excerpt{margin:0 0 10px;color:var(--slate-400)}
.post-readmore{color:var(--accent)}
.blog-cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}

/* Footer */
footer{padding:44px 0;background:#060b12;color:var(--slate-400);margin-top:64px;border-top:1px solid rgba(255,255,255,.06)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:22px}
.foot h5{margin:0 0 12px;font:700 16px/1 Inter;color:#fff}
.foot a{color:var(--slate-300)}
.copy{border-top:1px solid rgba(255,255,255,.08);margin-top:22px;padding-top:16px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.copy .divider{opacity:.4}

/* WhatsApp */
.floating-wa{position:fixed;right:16px;bottom:16px;background:#25d366;color:#0b1220;border-radius:999px;padding:14px 16px;font-weight:800;box-shadow:0 12px 28px rgba(2,6,23,.45)}

/* Reveal animation */
[data-animate]{opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease}
[data-animate].in{opacity:1;transform:none}

/* Responsive */
@media (max-width: 980px){
  .hero-grid,.band{grid-template-columns:1fr}
  .services{grid-template-columns:1fr 1fr}
  .posts{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .services{grid-template-columns:1fr}
  .posts{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
}
/* ==========================================
   FUNDO MAIS CLARO (mantém harmonia visual)
   ========================================== */

/* Fundo geral (substitui o fundo escuro atual) */
html, body {
  background-color: #e2e8f0 !important; /* azul-cinza claro */
  color: #0f172a !important; /* texto principal mais escuro */
}

/* Ajuste das seções principais */
main, .content, .section, .blog-container {
  background-color: #e2e8f0 !important;
}

/* Cabeçalho e rodapé continuam azuis */
header {
  background: linear-gradient(180deg, rgba(10,35,66,.95), rgba(10,35,66,.85)) !important;
}
footer {
  background: #0b1420 !important;
  color: #e2e8f0 !important;
}

/* Títulos e textos */
h1, h2, h3, h4, h5, h6 {
  color: #0f172a !important;
}
p, li, .lead, .section p {
  color: #1e293b !important;
}

/* Caixas do blog (mantêm contraste e leitura) */
.post {
  background-color: #0f172a !important;
  color: #f1f5f9 !important;
  border: 1px solid rgba(15, 23, 42, 0.25) !important;
}
.post-title { color: #ffffff !important; }
.post-date { color: #94a3b8 !important; }
.post-excerpt { color: #cbd5e1 !important; }
.post-readmore { color: #38bdf8 !important; }

/* Ajuste para campos e botões */
input, textarea {
  background: #f8fafc !important;
  color: #0f172a !important;
  border: 1px solid #cbd5e1 !important;
}
.btn.secondary {
  background: #f8fafc !important;
  color: #0f172a !important;
  border: 1px solid #cbd5e1 !important;
}
.btn.secondary:hover {
  background: #dbeafe !important;
}

/* Ajuste de pequenos textos e detalhes */
span, small, time {
  color: #475569 !important;
}
/* Correção de contraste para conteúdos em fundo escuro (cards e página de post) */
.post,
.post * { color: inherit; } /* limpa possíveis heranças forçadas */

.post {
  background: #0f172a !important;
  color: #f1f5f9 !important; /* cor base clara para o card/post */
}

/* Texto do conteúdo do artigo */
.post .post-content,
.post .post-content p,
.post .post-content li,
.post .post-content span,
.post .post-content em,
.post .post-content strong {
  color: #e6eef9 !important;
}

/* Títulos dentro do post */
.post h1, .post h2, .post h3, .post h4, .post h5, .post h6 {
  color: #ffffff !important;
}

/* Metadados */
.post .post-date { color: #94a3b8 !important; }
.post .post-excerpt { color: #cbd5e1 !important; }

/* Tags do post */
#postTags span {
  color: #e6eef9 !important;
  border-color: rgba(255,255,255,.25) !important;
}

/* Autor do post (seu bloco featuredAuthor) */
#featuredAuthor #faName { color: #ffffff !important; }
#featuredAuthor #faRole { color: #cbd5e1 !important; }
/* === Topbar: textos e links brancos === */
.topbar,
.topbar * {
  color: #ffffff !important;
}
.topbar a:hover {
  color: #e2e8f0 !important;
}

/* === Header: nome da empresa em branco === */
.brand h1 {
  color: #ffffff !important;
}
/* === Rodapé: textos e links brancos === */
footer,
footer * {
  color: #ffffff !important;
}

footer a:hover {
  color: #e2e8f0 !important; /* tom levemente acinzentado no hover */
}

/* Opcional: aumenta o contraste e melhora a legibilidade */
footer {
  background: #0A2342; /* mantém o azul escuro consistente com o cabeçalho */
}
/* === Logo personalizada no header === */
.logo-img {
  height: 48px;             /* ajuste se quiser maior ou menor */
  width: auto;
  display: block;
  object-fit: contain;
  margin-right: 10px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand h1 {
  color: #ffffff;
  font: 700 18px/1.1 Merriweather, serif;
  margin: 0;
}
 .logo-img{
  height:44px;        /* ajuste se quiser 36–48px */
  width:auto;
  object-fit:contain;
  display:block;
}
.brand{display:flex;align-items:center;gap:10px}
.brand h1{margin:0;color:#fff;font:700 18px/1.1 Merriweather,serif}
header {
  background: linear-gradient(90deg, #BFD3E6 0%, #1E4FA1 50%, #0A2342 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: saturate(120%) blur(4px);
}
/* ===== Mobile header refinado ===== */
@media (max-width: 640px){

  /* Topbar: fonte menor e quebra controlada */
  .topbar .wrap{
    flex-wrap: wrap;
    gap: 6px 12px;
    padding: 6px 0;
  }
  .topbar, .topbar a{ font-size: 12px; }

  /* Header: menos altura, espaços coerentes */
  header .nav{
    padding: 10px 0;
    gap: 10px;
  }

  /* Brand: logo + título lado a lado sem esmagar */
  .brand{
    gap: 8px;
    max-width: 100%;
    overflow: hidden;
  }
  .logo-img{ height: 36px; }               /* 44px no desktop; 36px no mobile */
  .brand h1{
    font-size: 16px;
    line-height: 1.1;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    max-width: 62vw;                        /* evita quebrar em 3 linhas */
  }

  /* Navegação: vira carrossel horizontal de chips */
  header nav{
    display: flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    max-width: 100%;
  }
  header nav::-webkit-scrollbar{ display: none; }

  /* Botões mais compactos */
  .nav a.btn{
    padding: 8px 14px;
    font-weight: 700;
    border-radius: 999px;
    flex: 0 0 auto;                         /* não esticam; rolam horizontalmente */
  }

  /* Gradiente suave permanece */
  header{
    background: linear-gradient(90deg, #BFD3E6 0%, #1E4FA1 50%, #0A2342 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,.10);
    backdrop-filter: saturate(120%) blur(4px);
  }

  /* Evita quina clara sob o header em iOS */
  body{ background-color:#E6EEF6; }
}
/* ----- Mobile menu ----- */
.hamb{ display:none; }

@media (max-width:640px){
  /* esconde nav desktop e mostra hambúrguer */
  header nav { display:none !important; }
  .hamb{
    display:inline-flex; flex-direction:column; justify-content:center;
    gap:4px; width:42px; height:38px; border:1px solid rgba(255,255,255,.22);
    border-radius:10px; background:transparent; cursor:pointer;
  }
  .hamb span{
    display:block; height:2px; width:22px; background:#fff; border-radius:2px;
    transition:transform .2s ease, opacity .2s ease;
    margin:0 auto;
  }
  /* animação X */
  .hamb[aria-expanded="true"] span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .hamb[aria-expanded="true"] span:nth-child(2){ opacity:0; }
  .hamb[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

  .mobile-menu{
    position: absolute; left:0; right:0; top:100%;
    background: rgba(6,11,18,.94);
    border-bottom:1px solid rgba(255,255,255,.08);
    display:flex; flex-direction:column; gap:10px;
    padding:12px 4%;
    backdrop-filter: blur(8px) saturate(120%);
    animation: menudown .18s ease;
  }
  .mobile-menu .btn{ width:100%; justify-content:center; }
  @keyframes menudown{ from{ opacity:.0; transform:translateY(-6px) } to{ opacity:1; transform:none } }
}
/* adicione isso */
header .nav { position: relative; z-index: 50; }

/* o dropdown já usa position:absolute; isso faz ele ficar preso ao header */
/* o header container precisa ser referência para o dropdown */
.nav { position: relative; z-index: 50; }

/* ----- Mobile menu ----- */
.hamb{ display:none; }

@media (max-width:640px){
  header nav { display:none !important; } /* some o menu desktop */
  .hamb{
    display:inline-flex; flex-direction:column; justify-content:center;
    gap:4px; width:42px; height:38px; border:1px solid rgba(255,255,255,.22);
    border-radius:10px; background:transparent; cursor:pointer;
  }
  .hamb span{
    display:block; height:2px; width:22px; background:#fff; border-radius:2px;
    transition:transform .2s ease, opacity .2s ease; margin:0 auto;
  }
  /* animação X */
  .hamb[aria-expanded="true"] span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .hamb[aria-expanded="true"] span:nth-child(2){ opacity:0; }
  .hamb[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

  /* VISIBILIDADE CONTROLADA POR CLASSE */
  .mobile-menu{
    position:absolute; left:0; right:0; top:100%;
    background: rgba(6,11,18,.94);
    border-bottom:1px solid rgba(255,255,255,.08);
    display:none;                      /* fechado por padrão */
    flex-direction:column; gap:10px;
    padding:12px 4%;
    backdrop-filter: blur(8px) saturate(120%);
  }
  .mobile-menu.is-open{                /* aberto */
    display:flex;
    animation: menudown .18s ease;
  }
  .mobile-menu .btn{ width:100%; justify-content:center; }

  @keyframes menudown{
    from{ opacity:.0; transform:translateY(-6px) }
    to  { opacity:1;  transform:none }
  }
}
/* Esconde o mobile-menu por padrão (desktop) */
.mobile-menu { display: none; }

/* Desktop força só o menu principal */
@media (min-width: 641px){
  .main-nav { display: flex !important; }
  .hamb { display: none !important; }
  .mobile-menu { display: none !important; } /* evita duplicar */
}

/* Mobile: esconde o menu principal e mostra hambúrguer */
@media (max-width: 640px){
  .main-nav { display: none !important; }
  .hamb { display: inline-flex !important; }

  .mobile-menu{
    position: absolute;
    left: 0; right: 0; top: 100%;
    background: rgba(6,11,18,.94);
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 12px 4%;
    display: none;                 /* fechado por padrão */
    flex-direction: column;
    gap: 10px;
    backdrop-filter: blur(8px) saturate(120%);
    animation: menudown .18s ease;
  }
  .mobile-menu.is-open{ display: flex; } /* abre quando JS coloca a classe */

  @keyframes menudown{ from{ opacity:0; transform:translateY(-6px) } to{ opacity:1; transform:none } }
}
/* ===== TIME ===== */
.team { padding-top: 40px; padding-bottom: 64px; background:#fff; }

/* Faixa azul com cantos decorativos */
.team-strip{
  position: relative;
  margin-top: 18px;
  padding: 70px 0;            /* espaço para as fotos sobre a faixa */
  background:
    linear-gradient(0deg, #0A2342 0%, #0A2342 100%); /* faixa */
  overflow: hidden;
}
/* “picos” claros nos cantos superiores, para lembrar o visual da imagem enviada */
.team-strip::before,
.team-strip::after{
  content:"";
  position:absolute; top:-40px; width:220px; height:220px;
  background: linear-gradient(135deg, rgba(255,255,255,0.7), rgba(255,255,255,0));
  filter: blur(0.2px);
  transform: rotate(45deg);
}
.team-strip::before{ left:-70px; }
.team-strip::after{ right:-70px; transform: rotate(-45deg); }

.team-avatars{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap: clamp(16px, 3vw, 36px);
}

/* Cartão do membro */
.member{
  width: clamp(140px, 18vw, 210px);
  text-align:center; color:#fff; margin:0;
}
.member img{
  width: 100%; aspect-ratio: 1 / 1; object-fit: cover;
  border-radius: 999px;
  border: 6px solid #fff;                 /* aro branco */
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  /* faz a foto “sair” da faixa */
  transform: translateY(-38%);
}
.member figcaption{
  margin-top: -26%;                        /* aproxima o nome da foto */
}
.member h4{
  margin: 6px 0 2px; font-size: clamp(15px, 1.2vw, 18px); font-weight:700; color:#fff;
}
.member small{
  display:block; color:#d7e3ff; font-weight:500; letter-spacing:.2px;
}

/* Responsivo */
@media (max-width: 1100px){
  .team-avatars{ flex-wrap:wrap; justify-content:center }
  .member{ width: 170px }
}
@media (max-width: 720px){
  .team-strip{ padding: 90px 0 }
  .member{ width: 150px }
  .member img{ transform: translateY(-42%); border-width: 5px }
}
@media (max-width: 460px){
  .member{ width: 130px }
}
/* Força texto CLARO na seção do time (prioridade alta) */
.section.team .team-strip .member h4{
  color:#ffffff !important;        /* branco */
  text-shadow:0 2px 8px rgba(0,0,0,.45);
}
.section.team .team-strip .member small{
  color:#f1f6ff !important;        /* branco-azulado claro */
  text-shadow:0 2px 6px rgba(0,0,0,.4);
  opacity:1 !important;
}

/* Se ainda houver herança escurecendo, ative esta linha “modo bruto”:
.team-strip * { color:#ffffff !important; }
*/

/* (opcional) se você adicionou fundo no figcaption e quer tirar: */
.section.team .member figcaption{
  background:transparent;          /* remove cartuchinho */
  backdrop-filter:none;
}
/* Compensa a altura do topo (topbar + menu) ao rolar para #time */
#time{
  scroll-margin-top: 100px; /* ajuste fino: 120–180 conforme sua barra */
}
/* Compensa a altura do topo (topbar + menu) ao rolar para #servicos */
#servicos{
  scroll-margin-top: 100px; /* ajuste fino: 120–180 conforme sua barra */
}
/* Compensa o header ao rolar para o HERO (#inicio) */
#inicio{
  scroll-margin-top: 140px;   /* ajuste conforme a altura do topo */
}
/* Aproxima o HERO do topo sem afetar outras seções */
@media (min-width: 981px){
  .hero{
    padding-top: 28px;   /* antes era 80px */
  }
}

/* Se quiser ainda um pouco mais para cima, teste: 40px ou 36px */
.background::before,
.background::after {
  z-index: 0;
}
.team-member {
  position: relative;
  z-index: 5;
}

.team-photo {
  position: relative;
  z-index: 10;
}
.team-strip{
  position: relative;
  margin-top: 18px;
  padding: 70px 0;
  background: #0A2342;
  overflow: visible;
  z-index: 0;
}

.team-strip::before,
.team-strip::after{
  content:"";
  position:absolute;
  top:-60px;
  width:260px;
  height:260px;
  background: radial-gradient(260px 260px at 50% 50%,
              rgba(255,255,255,.55), rgba(255,255,255,0) 60%);
  transform: rotate(45deg);
  z-index: -1;            /* sempre atrás */
  pointer-events: none;
}
.team-strip::before{ left:-120px; }
.team-strip::after { right:-120px; }

.team-avatars{ position: relative; z-index: 5; }
.member{ position: relative; z-index: 6; }
.member img, .member figcaption{ position: relative; z-index: 7; }
