/* ==========================================================================
   Sol e Lua Calçados — folha principal
   Importa variáveis + reset e aplica estilos globais.
   ========================================================================== */

@import url('./variaveis.css');
@import url('./reset.css');

/* ---------- Fontes self-hosted (assets/fontes/) ---------- */

@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fontes/jost-400.woff2') format('woff2');
}

@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fontes/jost-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fontes/cormorant-garamond-400.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fontes/cormorant-garamond-500.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fontes/cormorant-garamond-600.woff2') format('woff2');
}

/* ---------- Base ---------- */

html {
  font-size: 100%;  /* 16px padrão; respeita zoom do usuário (WCAG) */
}

body {
  font-family: var(--fonte-corpo);
  font-size: var(--fs-base);
  font-weight: 400;
  line-height: var(--lh-corpo);
  color: var(--cor-texto);
  background: var(--cor-fundo);
}

strong, b {
  font-weight: 700;
}

/* ---------- Tipografia de títulos ---------- */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--fonte-titulo);
  color: var(--cor-primaria);
  line-height: var(--lh-titulo);
}

h1 { font-size: var(--fs-h1); font-weight: 600; }
h1.hero { font-weight: 400; }
h2 { font-size: var(--fs-h2); font-weight: 500; }
h3 { font-size: var(--fs-h3); font-weight: 500; }
h4 { font-size: var(--fs-h4); font-weight: 400; }
h5 { font-size: var(--fs-h5); font-weight: 400; }
h6 { font-size: var(--fs-h6); font-weight: 400; }

/* ---------- Links ---------- */

a {
  color: var(--cor-acento);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--trans-rapida);
}

a:hover,
a:focus-visible {
  color: var(--cor-acento-hover);
}

a:focus-visible {
  outline: 2px solid var(--cor-primaria);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ---------- Container ---------- */

.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--esp-3);
}

@media (min-width: 768px) {
  .container {
    padding-inline: var(--esp-4);
  }
}

/* ---------- Botão primário ---------- */

.botao-primario {
  display: inline-block;
  padding: var(--esp-2) var(--esp-4);
  background: var(--cor-acento);
  color: var(--cor-fundo);
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--fonte-corpo);
  font-size: var(--fs-base);
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--trans-rapida);
}

.botao-primario:hover,
.botao-primario:focus-visible {
  background: var(--cor-acento-hover);
  color: var(--cor-fundo);
}

/* ---------- Rodapé ---------- */

.rodape {
  background: var(--cor-fundo-alternativo);
  color: var(--cor-texto);
  margin-top: var(--esp-8);
}

.rodape__container {
  max-width: var(--container);
  margin-inline: auto;
  padding: var(--esp-6) var(--esp-3);
}

.rodape__colunas {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--esp-5);
}

@media (min-width: 768px) {
  .rodape__colunas {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--esp-5);
  }
}

.rodape__titulo {
  font-size: var(--fs-h5);
  color: var(--cor-primaria);
  margin-bottom: var(--esp-3);
}

.rodape__coluna p,
.rodape__coluna address {
  font-style: normal;
  margin-bottom: var(--esp-2);
  line-height: var(--lh-corpo);
}

.rodape__coluna ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--esp-2);
}

.rodape__coluna a {
  color: var(--cor-primaria);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.rodape__coluna a:hover,
.rodape__coluna a:focus-visible {
  color: var(--cor-acento);
}

.rodape__cnpj {
  font-size: var(--fs-small);
  color: var(--cor-texto-claro);
}

.rodape__base {
  border-top: 1px solid var(--cor-borda);
  margin-top: var(--esp-5);
  padding-top: var(--esp-4);
  text-align: center;
  font-size: var(--fs-small);
  color: var(--cor-texto-claro);
}

/* ==========================================================================
   Página Sobre
   ========================================================================== */

/* Skip link — visível apenas em :focus-visible (acessibilidade) */
.skip-link {
  position: absolute;
  top: -40px;
  left: var(--esp-3);
  background: var(--cor-primaria);
  color: var(--cor-fundo);
  padding: var(--esp-2) var(--esp-3);
  border-radius: var(--radius-sm);
  text-decoration: none;
  z-index: 200;
  transition: top var(--trans-rapida);
}

.skip-link:focus-visible {
  top: var(--esp-3);
  color: var(--cor-fundo);
  outline: 2px solid var(--cor-secundaria);
  outline-offset: 2px;
}

/* Hero — coluna central, sem fundo decorativo */
.sobre__hero {
  text-align: center;
  padding-block: var(--esp-7) var(--esp-8);
}

.sobre__lead {
  margin-top: var(--esp-3);
  font-family: var(--fonte-titulo);
  font-weight: 400;
  font-size: var(--fs-large);
  color: var(--cor-texto-claro);
}

/* Seções — full-width (para alternância de fundo), conteúdo via .container interno */
.sobre__secao {
  padding-block: var(--esp-7);
}

.sobre__secao--alternada {
  background: var(--cor-fundo-alternativo);
}

.sobre__secao h2 {
  max-width: 65ch;
  margin-inline: auto;
  margin-bottom: var(--esp-4);
}

.sobre__secao p {
  max-width: 65ch;
  margin-inline: auto;
}

/* Highlight amarelo (marca-texto) — reseta default do browser e aplica
   sublinhado gordo via gradiente. Texto mantém a cor do parágrafo. */
.sobre mark {
  background: transparent;
  background-image: linear-gradient(to top, var(--cor-secundaria) 30%, transparent 30%);
  color: inherit;
  padding-inline: 0.05em;
}

/* CTA final — bloco centralizado, sem fundo */
.sobre__cta {
  text-align: center;
  padding-block: var(--esp-6);
}

/* ==========================================================================
   Página Trocas
   ========================================================================== */

/* Rolagem suave para navegação por âncoras — respeita prefers-reduced-motion */
html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

/* Hero — mesmo padrão do .sobre__hero, mas sem h1.hero especial */
.trocas__hero {
  text-align: center;
  padding-block: var(--esp-7) var(--esp-5);
}

.trocas__lead {
  max-width: 65ch;
  margin-inline: auto;
  margin-top: var(--esp-3);
  font-size: var(--fs-large);
  color: var(--cor-texto-claro);
}

/* Índice de âncoras — caixa creme destacada, centralizada, listagem vertical */
.trocas__indice {
  padding-block: var(--esp-5);
}

.trocas__indice .container {
  max-width: 65ch;
  background: var(--cor-fundo-alternativo);
  border-radius: var(--radius-md);
  padding: var(--esp-4) var(--esp-5);
}

.trocas__indice-titulo {
  font-size: var(--fs-h4);
  margin-bottom: var(--esp-3);
}

.trocas__indice ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--esp-2);
}

.trocas__indice a {
  color: var(--cor-acento);
  text-decoration: none;
  font-weight: 400;
}

.trocas__indice a:hover,
.trocas__indice a:focus-visible {
  text-decoration: underline;
  color: var(--cor-acento-hover);
}

/* Seções — compensam header sticky (~85px) ao rolar via âncora */
.trocas__secao {
  padding-block: var(--esp-6);
  scroll-margin-top: var(--esp-8); /* 96px — folga sobre header sticky */
}

.trocas__secao h2,
.trocas__secao h3,
.trocas__secao p,
.trocas__secao ul {
  max-width: 65ch;
  margin-inline: auto;
}

.trocas__secao h2 {
  margin-bottom: var(--esp-4);
}

.trocas__secao h3 {
  margin-top: var(--esp-5);
  margin-bottom: var(--esp-3);
}

.trocas__secao p + p,
.trocas__secao p + ul,
.trocas__secao ul + p {
  margin-top: var(--esp-3);
}

.trocas__secao ul {
  padding-left: var(--esp-5);
}

.trocas__secao li + li {
  margin-top: var(--esp-1);
}

/* Ressalva — "Válido apenas para compras em..." — discreta, sem competir com o corpo */
.trocas__ressalva {
  font-size: var(--fs-small);
  color: var(--cor-texto-claro);
  margin-top: var(--esp-4);
}

/* CTA final — mesmo padrão do .sobre__cta */
.trocas__cta {
  text-align: center;
  padding-block: var(--esp-6);
}

/* ==========================================================================
   Página Como Comprar
   ========================================================================== */

/* Hero — mesmo padrão do .trocas__hero */
.como-comprar__hero {
  text-align: center;
  padding-block: var(--esp-7) var(--esp-5);
}

.como-comprar__lead {
  max-width: 65ch;
  margin-inline: auto;
  margin-top: var(--esp-3);
  font-size: var(--fs-large);
  color: var(--cor-texto-claro);
}

/* Índice de âncoras — caixa creme, mesmo padrão da Trocas */
.como-comprar__indice {
  padding-block: var(--esp-5);
}

.como-comprar__indice .container {
  max-width: 65ch;
  background: var(--cor-fundo-alternativo);
  border-radius: var(--radius-md);
  padding: var(--esp-4) var(--esp-5);
}

.como-comprar__indice-titulo {
  font-size: var(--fs-h4);
  margin-bottom: var(--esp-3);
}

.como-comprar__indice ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--esp-2);
}

.como-comprar__indice a {
  color: var(--cor-acento);
  text-decoration: none;
  font-weight: 400;
}

.como-comprar__indice a:hover,
.como-comprar__indice a:focus-visible {
  text-decoration: underline;
  color: var(--cor-acento-hover);
}

/* Seções — compensam header sticky (~85px) ao rolar via âncora */
.como-comprar__secao {
  padding-block: var(--esp-6);
  scroll-margin-top: var(--esp-8); /* 96px — folga sobre header sticky */
}

.como-comprar__secao h2,
.como-comprar__secao h3,
.como-comprar__secao p,
.como-comprar__secao ul {
  max-width: 65ch;
  margin-inline: auto;
}

.como-comprar__secao h2 {
  margin-bottom: var(--esp-4);
}

.como-comprar__secao h3 {
  margin-top: var(--esp-5);
  margin-bottom: var(--esp-3);
}

.como-comprar__secao p + p,
.como-comprar__secao p + ul,
.como-comprar__secao ul + p,
.como-comprar__secao ul + h3,
.como-comprar__secao p + h3 {
  margin-top: var(--esp-3);
}

.como-comprar__secao ul {
  padding-left: var(--esp-5);
}

.como-comprar__secao li + li {
  margin-top: var(--esp-1);
}

/* CTA final — mesmo padrão do .trocas__cta */
.como-comprar__cta {
  text-align: center;
  padding-block: var(--esp-6);
}

/* ==========================================================================
   Página Contato
   ========================================================================== */

/* Hero — mesmo padrão do .sobre__hero (sem h1.hero especial, sem índice) */
.contato__hero {
  text-align: center;
  padding-block: var(--esp-7) var(--esp-8);
}

.contato__lead {
  margin-top: var(--esp-3);
  max-width: 65ch;
  margin-inline: auto;
  font-family: var(--fonte-titulo);
  font-weight: 400;
  font-size: var(--fs-large);
  color: var(--cor-texto-claro);
}

/* Seções — full-width para alternância de fundo (clone do padrão Sobre) */
.contato__secao {
  padding-block: var(--esp-7);
}

.contato__secao--alternada {
  background: var(--cor-fundo-alternativo);
}

.contato__secao h2 {
  max-width: 65ch;
  margin-inline: auto;
  margin-bottom: var(--esp-4);
}

.contato__secao p {
  max-width: 65ch;
  margin-inline: auto;
}

/* Formulário — coluna estreita centralizada, gap entre grupos */
.contato__form {
  max-width: 65ch;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--esp-4);
}

/* Grupo label + input em coluna */
.contato__form-grupo {
  display: flex;
  flex-direction: column;
  gap: var(--esp-1);
}

.contato__form-grupo label {
  font-weight: 700;
  color: var(--cor-primaria);
}

.contato__form-grupo input,
.contato__form-grupo select,
.contato__form-grupo textarea {
  width: 100%;
  padding: var(--esp-2) var(--esp-3);
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-sm);
  font-family: var(--fonte-corpo);
  font-size: var(--fs-base);
  color: var(--cor-texto);
  background: var(--cor-fundo);
  transition: border-color var(--trans-rapida);
}

.contato__form-grupo input:focus-visible,
.contato__form-grupo select:focus-visible,
.contato__form-grupo textarea:focus-visible {
  outline: 2px solid var(--cor-primaria);
  outline-offset: 2px;
  border-color: var(--cor-primaria);
}

.contato__form-grupo textarea {
  min-height: 8rem;
  resize: vertical;
}

/* Botão submit — estende .botao-primario para reset de estilos default de <button> */
.contato__form button.botao-primario {
  align-self: flex-start;
}

.contato__form button.botao-primario:disabled {
  background: var(--cor-borda);
  color: var(--cor-texto-claro);
  cursor: not-allowed;
}

.contato__form button.botao-primario:disabled:hover,
.contato__form button.botao-primario:disabled:focus-visible {
  background: var(--cor-borda);
  color: var(--cor-texto-claro);
}

/* Honeypot — off-screen, não detectável por bots simplistas
   Razão: display:none é facilmente detectado e ignorado por bots. */
.contato__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* Lista de canais diretos (e-mail, WhatsApp, horário) */
.contato__canais {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 65ch;
  display: flex;
  flex-direction: column;
  gap: var(--esp-3);
}

.contato__canais a {
  font-weight: 700;
}

/* Bloco <address> com razão social, CNPJ, endereço */
.contato__dados {
  max-width: 65ch;
  margin-inline: auto;
  font-style: normal;
  line-height: 1.6;
}

/* Banner de status pós-submit (sucesso, erro, erro rate limit).
   Renderizado pelo PHP no topo da contato__secao#formulario. */
.contato__banner {
  max-width: 65ch;
  margin: 0 auto var(--esp-4);
  padding: var(--esp-3) var(--esp-4);
  border-radius: var(--radius-sm);
  border-left: 4px solid;
  line-height: var(--lh-corpo);
}

.contato__banner--sucesso {
  background: var(--cor-fundo-alternativo);
  border-left-color: var(--cor-primaria);
  color: var(--cor-primaria);
}

.contato__banner--erro {
  background: #fdecea;
  border-left-color: #c62828;
  color: #6e1d18;
}

.contato__banner a {
  color: inherit;
  font-weight: 700;
  text-decoration: underline;
}
