/* Resets, element defaults, layout helpers, utility classes. */

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

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-sans);
  font-size: var(--type-body-md-size);
  font-weight: var(--type-body-md-weight);
  line-height: var(--type-body-md-line);
  color: var(--text-primary);
  background: var(--surface-page);
  min-height: 100vh;
}

/* Headings */
h1, .display {
  font-family: var(--font-serif);
  font-size: var(--type-display-size);
  font-weight: var(--type-display-weight);
  line-height: var(--type-display-line);
  letter-spacing: var(--type-display-spacing);
  color: var(--text-primary);
  text-wrap: pretty;
}
h2 {
  font-family: var(--font-serif);
  font-size: var(--type-headline-lg-size);
  font-weight: var(--type-headline-lg-weight);
  line-height: var(--type-headline-lg-line);
  color: var(--text-primary);
  text-wrap: pretty;
}
h3 {
  font-family: var(--font-serif);
  font-size: var(--type-headline-md-size);
  font-weight: var(--type-headline-md-weight);
  line-height: var(--type-headline-md-line);
  color: var(--text-primary);
}
h4 {
  font-family: var(--font-sans);
  font-size: var(--type-label-md-size);
  font-weight: var(--type-label-md-weight);
  line-height: var(--type-label-md-line);
  letter-spacing: var(--type-label-md-spacing);
  text-transform: uppercase;
  color: var(--text-muted);
}
h5, h6 {
  font-family: var(--font-sans);
  font-size: var(--type-label-sm-size);
  font-weight: var(--type-label-sm-weight);
  line-height: var(--type-label-sm-line);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

p {
  font-size: var(--type-body-md-size);
  line-height: var(--type-body-md-line);
  color: var(--text-primary);
  text-wrap: pretty;
}
p.large { font-size: var(--type-body-lg-size); line-height: var(--type-body-lg-line); }
p.muted { color: var(--text-muted); }

strong, b { font-weight: 600; }
em, i     { font-style: italic; }

a {
  text-decoration: none;
  transition: var(--transition);
}
a:not(.btn) { color: var(--action-primary); }
a:not(.btn):hover { color: var(--action-primary-hover); text-decoration: underline; }
a:focus-visible {
  outline: 2px solid var(--border-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  background: var(--surface-chrome);
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  padding: 2px 6px;
}

pre {
  font-family: var(--font-mono);
  font-size: 0.875em;
  background: var(--surface-well);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 1rem;
  overflow-x: auto;
  color: var(--text-primary);
}

label {
  font-family: var(--font-sans);
  font-size: var(--type-label-md-size);
  font-weight: var(--type-label-md-weight);
  letter-spacing: var(--type-label-md-spacing);
  color: var(--text-muted);
  display: block;
}

/* Utilities */
.overline {
  font-family: var(--font-sans);
  font-size: var(--type-label-sm-size);
  font-weight: var(--type-label-md-weight);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.text-accent { color: var(--gold-text); }
.text-muted  { color: var(--text-muted); }
.text-serif  { font-family: var(--font-serif); }
.text-center { text-align: center; }
.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;
}

hr, .divider {
  border: none;
  border-top: 1px solid var(--border-subtle);
  margin: var(--space-3) 0;
}

.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.glass {
  background: var(--surface-rail);
  border-bottom: 1px solid var(--border-subtle);
}

/* Spacing helpers */
.stack > * + * { margin-top: var(--space-2); }
.stack-lg > * + * { margin-top: var(--space-4); }

/* Logo */
.logo-mark {
  display: inline-flex;
  align-items: center;
  height: 36px;
}
.logo-mark img,
.logo-mark .logo-svg {
  height: 100%;
  width: auto;
  display: block;
}
