/* Leyrer + Graf — base element styles & helpers
   Sets the page on warm grey, body type in dark grey, links in orange. */

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

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text-body);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  line-height: var(--lh-heading);
  color: var(--text-heading);
  margin: 0 0 var(--space-4);
  text-wrap: balance;
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); letter-spacing: var(--ls-wider); }

p { margin: 0 0 var(--space-4); text-wrap: pretty; }

a { color: var(--text-link); text-decoration: none; transition: color var(--dur-fast) var(--ease-standard); }
a:hover { color: var(--color-primary-hover); text-decoration: underline; }

strong, b { font-weight: var(--fw-bold); color: var(--text-strong); }

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

::selection { background: var(--lg-orange); color: #fff; }

/* Layout helpers */
.lg-container { max-width: var(--content-max); margin-inline: auto; padding-inline: var(--gutter); }
.lg-section { padding-block: var(--section-pad-y); }
.lg-on-dark { background: var(--surface-dark); color: var(--text-on-dark); }
.lg-on-dark h1, .lg-on-dark h2, .lg-on-dark h3, .lg-on-dark h4 { color: var(--lg-white); }
