*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

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

body {
  font-family: var(--font-sans);
  font-size: var(--body-size);
  line-height: 1.75;
  color: var(--color-gray-text);
  background: var(--color-white);
}

img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }

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

ul, ol { list-style: none; }

button, input, textarea, select { font-family: inherit; font-size: inherit; border: none; background: none; }

button { cursor: pointer; }

h1, h2, h3, h4, h5, h6 { font-family: var(--font-serif); line-height: 1.2; font-weight: 700; color: var(--color-navy); }
