
/* altura total da página */
html, body {
  height: 100%;
  margin: 0;
}

/* o body é o flex container principal */
body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}


/* WRAPPER PRINCIPAL */
.page-wrapper {
  min-height: 100vh;          /* ocupa pelo menos a altura da janela */
  display: flex;
  flex-direction: column;     /* header, conteúdo, footer em coluna */
}

/* CONTEÚDO CRESCE, EMPURRA O FOOTER */
.page-wrapper .content {
  flex: 1;                    /* ocupa o espaço que sobra */
}

/* FOOTER */
footer.footer {
  background: #C6A522;
   color: #fff;
   width: 100%;
   position: static;
   margin-top: auto;
}

/* ===== Variante compacta (só ativa quando metes .footer--compact no HTML) ===== */
.footer--compact {
  --footer-padding-block: clamp(14px, 2.2vw, 25px);
  --footer-padding-inline: 40px;
  --footer-gap: 12px;
  --footer-heading-size: 1.5rem;
  --footer-text-size: 1.4rem;
  --footer-icons-size: 1.2rem;
}


.footer-container {
  max-width: 2000px;
  margin: 0 auto;
 padding: var(--footer-padding-block) var(--footer-padding-inline);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--footer-gap);
 }


.footer-column h3 {
  font-size: var(--footer-heading-size);
  margin-bottom: 10px;
  color: #fff;
}

.footer-column ul {
 list-style: none;
 padding: 0;
}

.footer-column ul li {
 margin-bottom: 10px;
}

.footer-column a {
 color: #ccc;
 text-decoration: none;
}

.footer-column a:hover {
 color: #fff;
}

.social-icons a {
  margin-right: 8px;
  color: #ccc;
  font-size: var(--footer-icons-size);
}

.footer-bottom {
  text-align: center;
  margin-top: 0px;
  font-size: 14px;
  border-top: 1px solid #333;
  padding-top: 10px;
}

.footer-bottom p,
.footer-bottom span {
    color: #000;
    font-size: 14px;
}

.footer-column {
  flex: 1 1 220px;
  min-width: 220px;  /* um pouco mais estreito para quebrar mais cedo */
  font-size: var(--footer-text-size);
}

/* botão topo (se quiseres manter) */
.scroll-top { position: fixed; bottom: 20px; right: 20px; }
.scroll-top a { background:#ffc107; color:#000; padding:8px 10px; border-radius:4px; text-decoration:none; }



