:root {
  --font-primary:   'Sora', 'Manrope', 'Nunito Sans', Arial, sans-serif;
  --font-secondary: 'Manrope', 'Nunito Sans', Arial, sans-serif;
  --font-support:   'Nunito Sans', 'Manrope', Arial, sans-serif;

  /* — Paleta — */
  --paper:          #f7f1e5;
  --paper-soft:     #fbf7ee;
  --surface:        #fffaf0;
  --surface-strong: #fffdf8;
  --green:          #173f35;
  --green-soft:     #47665c;
  --muted:          #758177;
  --line:           #e3d8c2;
  --gold:           #b88a2d;
  --gold-soft:      #ead8ad;

  /* — Elevação — */
  --shadow: 0 12px 32px rgba(47, 39, 22, 0.08);
  --radius: 8px;

  /* — Layout — */
  --max: 1120px;

  /* — Escala tipográfica — */
  --text-xs:   0.72rem;   /* labels/kickers uppercase */
  --text-sm:   0.80rem;   /* subtextos Manrope */
  --text-base: 0.88rem;   /* corpo padrão */
  --text-md:   0.96rem;   /* corpo levemente aumentado */
  --text-lg:   1.08rem;   /* títulos de card */
  --text-xl:   1.20rem;   /* títulos de seção */
  --text-2xl:  1.40rem;   /* títulos de página */

  /* — Espaçamento de letras — */
  --tracking-wide:  0.12em;
  --tracking-wider: 0.22em;

  /* — Entrelinha — */
  --leading-tight: 1.2;
  --leading-base:  1.5;
  --leading-loose: 1.7;

  color-scheme: light;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  background: var(--paper);
  color: var(--green);
  font-family: var(--font-primary);
  line-height: var(--leading-base);
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }

button,
textarea { font: inherit; }

.wrap {
  width: min(var(--max), calc(100% - 32px));
  margin-inline: auto;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
