/* =====================================================
   Reset + base typography
   ===================================================== */

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

html { -webkit-text-size-adjust: 100%; }
html.lenis,
html.lenis body { height: auto; }
html.lenis-smooth { scroll-behavior: auto !important; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-display);
  margin: 0;
  color: var(--color-ink);
}

p { margin: 0; }

::selection { background: var(--color-rust); color: var(--color-bg); }

/* ---------- Utility primitives ---------- */
.container {
  width: 100%;
  max-width: var(--max-w-content);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-ink);
  font-weight: 500;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 36px;
  background: var(--color-rust);
  color: var(--color-paper);
  border-radius: var(--radius-pill);
  font-size: var(--fs-body);
  letter-spacing: var(--ls-button);
  transition: transform var(--dur-fast) var(--ease-out-soft),
              background var(--dur-fast) var(--ease-out-soft);
}
.btn:hover { transform: translateY(-1px); background: var(--color-rust-deep); }
.btn--ghost {
  background: transparent;
  color: var(--color-ink);
  border: 1px solid var(--color-line);
}
.btn--ghost:hover { background: rgba(33, 30, 26, 0.05); }
.btn--on-dark {
  background: var(--color-rust);
  color: var(--color-paper);
}
.btn--on-dark:hover { background: var(--color-rust-deep); }

/* ---------- Art card: white mat that holds monochrome artwork ---------- */
.art-card {
  background: var(--color-paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--art-shadow);
  overflow: hidden;
  display: block;
}
.art-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.art-card--contain { padding: clamp(12px, 2vw, 28px); }
.art-card--contain img { object-fit: contain; }

/* Heading sizes */
.h-hero    { font-size: var(--fs-display-hero); line-height: var(--lh-display); }
.h-display { font-size: var(--fs-display-xl);   line-height: var(--lh-display); }
.h-large   { font-size: var(--fs-display-lg);   line-height: var(--lh-display); }
.h-medium  { font-size: var(--fs-display-md);   line-height: var(--lh-heading); }
.h-section { font-size: var(--fs-heading);      line-height: var(--lh-heading); }

/* Body sizes */
.t-lg { font-size: var(--fs-body-lg); color: var(--color-ink-soft); }
.t-meta { font-size: var(--fs-meta); color: var(--color-ink-mute); }

/* Hairline divider */
.rule { height: 1px; background: var(--color-line); }

/* Reduce motion respect */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
