/* =============================================================================
   base.css
   ----------------------------------------------------------------------------
   Reset leve + estilos globais (tipografia, links, foco, imagens, utilitários).
   Depende de tokens.css — importar tokens.css ANTES deste arquivo no HTML.
   ============================================================================= */

/* ----------------------------------------------------------------------------
   1. Reset minimalista
   ---------------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

/* Respeita usuários que preferem menos movimento. */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

body {
  min-height: 100vh;
  background-color: var(--bg-pagina);
  color: var(--cor-texto);
  font-family: var(--fonte-corpo);
  font-size: var(--fs-base);
  line-height: var(--lh-corpo);
  font-weight: var(--fw-regular);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ----------------------------------------------------------------------------
   2. Tipografia
   ---------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--fonte-titulo);
  color: var(--cor-titulo);
  line-height: var(--lh-titulo);
  font-weight: var(--fw-medium);
  text-wrap: balance;
}

h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }

p {
  max-width: var(--largura-texto);
  color: var(--cor-texto-suave);
  text-wrap: pretty;
}

p + p {
  margin-top: var(--space-4);
}

ul, ol {
  padding-left: 1.25rem;
  color: var(--cor-texto-suave);
}

li + li {
  margin-top: var(--space-2);
}

/* ----------------------------------------------------------------------------
   3. Links e foco
   ---------------------------------------------------------------------------- */
a {
  color: var(--cor-link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  transition: color var(--transicao-rapida);
}

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

:focus-visible {
  outline: 2px solid var(--cor-foco);
  outline-offset: 3px;
  border-radius: var(--raio-pequeno);
}

/* ----------------------------------------------------------------------------
   4. Mídia
   ---------------------------------------------------------------------------- */
img, picture, svg, video {
  display: block;
  max-width: 100%;
  height: auto;
}

/* ----------------------------------------------------------------------------
   5. Container central com largura máxima
   ---------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--largura-max);
  margin-inline: auto;
  padding-inline: var(--padding-lateral);
}

/* ----------------------------------------------------------------------------
   6. Skip link (acessibilidade — pular para o conteúdo)
   ---------------------------------------------------------------------------- */
.skip-link {
  position: absolute;
  left: var(--space-4);
  top: var(--space-4);
  background: var(--cor-azul-marinho);
  color: var(--cor-off-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--raio-medio);
  z-index: 1000;
  transform: translateY(-200%);
  transition: transform var(--transicao-media);
  text-decoration: none;
}

.skip-link:focus {
  transform: translateY(0);
  color: var(--cor-off-white);
}

/* ----------------------------------------------------------------------------
   7. Âncoras — garante que o título alvo não fique escondido atrás do header
   ---------------------------------------------------------------------------- */
:target,
section[id] {
  scroll-margin-top: calc(var(--altura-header) + var(--space-4));
}

/* ----------------------------------------------------------------------------
   8. Utilitário visualmente oculto (mas lido por leitores de tela)
   ---------------------------------------------------------------------------- */
.visualmente-oculto {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
