:root{--bg:#0b1220;--alt:#0f172a;--card:#111827;--text:#e5e7eb;--muted:#94a3b8;--brand:#22c55e;--brand2:#06b6d4;--ring:rgba(34,197,94,.35)}
*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial;background:linear-gradient(180deg,var(--bg),var(--alt));color:var(--text);line-height:1.6}
a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 16px}.grid{display:grid;gap:16px}
.header{position:sticky;top:0;z-index:30;background:rgba(15,23,42,.8);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid rgba(148,163,184,.15)}
.header .row{display:flex;align-items:center;justify-content:space-between;padding:14px 0}.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.nav a{margin:0 8px;color:var(--text)}.btn{display:inline-block;padding:12px 16px;border-radius:14px;border:1px solid rgba(148,163,184,.25);font-weight:700}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#071a0e;border-color:transparent}
.hero{padding:56px 0;border-bottom:1px solid rgba(148,163,184,.12)}.hero h1{font-size:40px;line-height:1.1;margin:0 0 12px}
.section{padding:48px 0}.alt{background:rgba(2,6,23,.35)}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.card{background:rgba(17,24,39,.65);border-radius:18px;border:1px solid rgba(148,163,184,.15);padding:16px}
.footer{border-top:1px solid rgba(148,163,184,.12);padding:28px 0;background:#0b1220}.footer .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
input,textarea{background:#0b1220;color:var(--text);border:1px solid rgba(148,163,184,.25);border-radius:12px;padding:12px 14px;outline:none}input:focus,textarea:focus{box-shadow:0 0 0 6px var(--ring)}
.masonry{columns:4 240px;column-gap:16px}@media(max-width:900px){.hero h1{font-size:32px}.masonry{columns:2 200px}}
.breadcrumbs{color:var(--muted);font-size:14px;margin-bottom:8px}.toc{background:rgba(17,24,39,.6);padding:12px;border:1px solid rgba(148,163,184,.15);border-radius:12px}
.article h1{font-size:32px}.article h2{margin-top:18px}


/* --- QE2025 FIX PACK --- */
html, body { height: 100%; }
body { display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1 0 auto; }
.site-footer { flex-shrink: 0; background: #f8fafc; border-top: 1px solid #e5e7eb; padding: 24px 0; }
.footer-grid { display: grid; grid-template-columns: 1.2fr .8fr .8fr; gap: 24px; }
.footer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.footer-list a { text-decoration: none; color: #1f2937; }

.logo-grid { display: grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap: 16px; align-items: center; }
.logo-grid img { width: 100%; height: auto; background: #fff; border: 1px dashed #e5e7eb; border-radius: 12px; padding: 10px; }
.logo-grid.small { grid-template-columns: repeat(5, minmax(0,1fr)); }

.gallery { display: grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap: 10px; }
.gallery img { width: 100%; height: auto; border-radius: 12px; border: 1px solid #e5e7eb; }

.whatsapp-float { position: fixed; bottom: 18px; right: 18px; width: 56px; height: 56px; border-radius: 9999px; display: grid; place-items: center;
  background: #25D366; color: #fff; font-size: 28px; text-decoration: none; box-shadow: 0 8px 24px rgba(2,6,23,.25); z-index: 9999; }

/* Accessible skip link */
.skip-to-content{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-to-content:focus{position:static;width:auto;height:auto;display:inline-block;background:#000;color:#fff;padding:8px;border-radius:8px}

/* Basic container if not present */
.container { max-width: 1100px; margin: 0 auto; padding: 0 16px; }

/* Mobile responsiveness for nav, grids and footer */
@media (max-width: 900px){
  .footer-grid { grid-template-columns: 1fr; }
  .logo-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .logo-grid.small { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .gallery { grid-template-columns: repeat(3, minmax(0,1fr)); }
}



/* FIX13 - diminuir logos dos fornecedores */
.logo-grid img{max-height:72px; object-fit:contain}
@media (max-width:900px){ .logo-grid img{max-height:56px} }



/* FIX15 - padronizar tamanho das logos de fornecedores */
.logo-grid img {
  width: auto !important;
  height: 80px !important;   /* altura fixa padronizada */
  max-width: 100% !important;
  object-fit: contain !important;
  margin: 0 auto;
  display: block;
}
@media (max-width:900px){
  .logo-grid img{ height: 60px !important; }
}



/* FIX16 - alinhamento de galerias e clientes + footer robusto */
.gallery {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  align-items: stretch;
}
.gallery img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  display: block;
}

.logo-grid.small img {
  height: 72px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

@media (max-width: 900px){
  .gallery { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .logo-grid.small img { height: 56px; }
}

/* Footer stronger defaults */
.site-footer {
  background: #f8fafc;
  border-top: 1px solid #e5e7eb;
  padding: 32px 0 48px; /* extra bottom for WhatsApp float */
  color: #0f172a;
}
.site-footer .footer-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 24px;
}
.site-footer a { color: #1f2937; text-decoration: none; }
.site-footer a:hover { text-decoration: underline; }
.footer-copy { color: #6b7280; }

/* Ensure body/main layout so footer não "sobe" */
html, body { height: 100%; }
body { display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1 0 auto; }

/* WhatsApp float safe area */
.whatsapp-float { bottom: 18px; right: 18px; position: fixed; z-index: 9999; }



/* FIX17 - logos de fornecedores uniformes menores */
.logo-grid img {
  height: 60px !important;
  width: auto !important;
  max-width: 140px !important;
  object-fit: contain !important;
  display: block;
  margin: 0 auto;
  padding: 4px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
}
@media (max-width: 900px){
  .logo-grid img {
    height: 48px !important;
    max-width: 100px !important;
  }
}



/* FIX18 - padronizar logos de Clientes atendidos (.logo-grid.small) */
.logo-grid.small img {
  height: 56px !important;
  width: auto !important;
  max-width: 130px !important;
  object-fit: contain !important;
  display: block;
  margin: 0 auto;
  padding: 4px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
}
@media (max-width: 900px){
  .logo-grid.small img {
    height: 44px !important;
    max-width: 96px !important;
  }
}



/* === INÍCIO: Padronização de Logos de Parceiros (FIX28) === */
.parceiros-carousel img,
#parceiros img,
.section-parceiros img,
.parceiros img,
.partners img,
.logos-parceiros img,
.clients-logos img,
.marcas img,
[data-parceiros] img {
  width: 150px;
  height: 150px;
  object-fit: contain;
  background-color: #ffffff;
  border-radius: 12px;
  padding: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  display: inline-block;
}
/* Hover sutil opcional */
.parceiros-carousel img:hover,
#parceiros img:hover,
.section-parceiros img:hover,
.parceiros img:hover,
.partners img:hover,
.logos-parceiros img:hover,
.clients-logos img:hover,
.marcas img:hover,
[data-parceiros] img:hover {
  transform: scale(1.03);
  transition: transform .25s ease;
}
/* Garante alinhamento central em carrosséis ou grids comuns */
.parceiros-carousel,
#parceiros,
.section-parceiros,
.parceiros,
.partners,
.logos-parceiros,
.clients-logos,
.marcas,
[data-parceiros] {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
/* === FIM: Padronização de Logos de Parceiros (FIX28) === */
