/* base.css: global typography, links, and utilities */
html {
  scroll-behavior: smooth;
}

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--ff-primary);
  font-size: var(--fs-sm);
  letter-spacing: 0.01em;
}

main {
  padding-bottom: var(--space-8);
}

h1,
h2,
h3 {
  font-family: var(--ff-secondary);
  font-weight: 400;
  letter-spacing: 0.01em;
}

p {
  color: var(--ink-soft);
  font-size: var(--fs-sm);
}

.kicker {
  font-size: var(--fs-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.text-link {
  position: relative;
  display: inline-flex;
  gap: var(--space-2);
  align-items: center;
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.text-link::after {
  content: "";
  width: 2.4rem;
  height: 1px;
  background: var(--ink);
  transform-origin: left;
  transition: transform var(--ease);
}

.text-link:hover::after,
.text-link:focus-visible::after {
  transform: scaleX(1.4);
}

button,
input,
textarea {
  color: inherit;
}

:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.not-found {
  min-height: 100svh;
  display: grid;
  place-content: center;
  gap: var(--space-4);
  text-align: center;
}
