/* ===== FOOTER ===== */
footer{
  background:#264e64;
  color:#e2e8f0;
  margin-top:44px;
  padding-bottom: var(--safe-bottom);
}

/* respiro lateral consistente com safe-areas */
footer .wrap{
  padding-left: max(var(--mx), 16px, env(safe-area-inset-left));
  padding-right: max(var(--mx), 16px, env(safe-area-inset-right));
}

.footer-top{
  padding:32px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.footer-cols{ display:grid; gap:22px; }
@media (min-width:720px){
  .footer-cols{ grid-template-columns: 1.2fr 1fr 1fr 1fr; }
}

footer h4{ margin:0 0 10px; font-size:15px; color:#fff; }
footer a{ color:#e2e8f0; }
.btn-foot{
  display:inline-block; padding:12px 14px; border-radius:10px; font-weight:800;
  background:var(--brand); color:#fff; border:2px solid var(--brand);
}

.legal{
  padding:14px 0; font-size:14px; color:#93A3B8;
  display:flex; gap:12px; justify-content:space-between; flex-wrap:wrap;
}

/* listas simples do footer */
.list-plain{ list-style:none; padding:0; margin:0; opacity:.95; }
.list-plain li{ margin:4px 0; }

/* prevenção de overflow em colunas estreitas */
footer img, footer svg{ max-width:100%; height:auto; }
footer p, footer a, footer li{ overflow-wrap:anywhere; }
