﻿@import url('https://fonts.googleapis.com/css2?family=Philosopher:ital,wght@0,400;0,700;1,400;1,700&display=swap');

:root {
  --color-ink: #171717;
  --color-ink-soft: #3d3d3d;
  --color-muted: #6d6a66;
  --color-line: #ded7cf;
  --color-paper: #fffaf2;
  --color-surface: #ffffff;
  --color-stone: #eee8df;
  --color-red: #a43e39;
  --color-red-dark: #742c28;
  --color-sage: #526f65;
  --color-blue: #536a82;
  --color-gold: #b88645;
  --shadow-soft: 0 18px 48px rgba(20, 18, 16, 0.12);
  --radius-sm: 6px;
  --radius-md: 8px;
  --container: min(1120px, calc(100vw - 40px));
  --container-wide: min(1360px, calc(100vw - 40px));
  --font-main: "Philosopher", "Segoe UI", Arial, sans-serif;
  --font-display: Georgia, "Times New Roman", serif;
}

body {
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-main);
  font-size: 1.12rem;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
}

body.nav-open {
  overflow: hidden;
}

h1,
h2,
h3,
h4,
p {
  margin: 0;
}

h1,
.display-title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 7.5rem);
  font-weight: 500;
  line-height: 0.92;
}

h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 4.25rem);
  font-weight: 500;
  line-height: 1;
}

h3 {
  font-size: clamp(1.2rem, 2vw, 1.75rem);
  line-height: 1.2;
}

.eyebrow {
  color: var(--color-red);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.lead {
  color: var(--color-ink-soft);
  font-size: clamp(1.2rem, 1.8vw, 1.55rem);
  line-height: 1.55;
}

.muted {
  color: var(--color-muted);
}

.section-kicker {
  align-items: center;
  color: var(--color-red);
  display: inline-flex;
  font-size: 1.05rem;
  font-weight: 700;
  gap: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.section-kicker::before {
  background: currentColor;
  content: "";
  height: 1px;
  width: 42px;
}

.button {
  align-items: center;
  border: 1px solid transparent;
  border-radius: 999px;
  display: inline-flex;
  font-weight: 700;
  gap: 0.55rem;
  justify-content: center;
  min-height: 46px;
  padding: 0.78rem 1.15rem;
  text-decoration: none;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: var(--color-ink);
  color: var(--color-surface);
}

.button-primary:hover {
  background: var(--color-red-dark);
}

.button-secondary {
  border-color: var(--color-ink);
  color: var(--color-ink);
}

.button-secondary:hover {
  background: var(--color-ink);
  color: var(--color-surface);
}

.button-light {
  background: var(--color-surface);
  color: var(--color-ink);
}

.icon {
  display: inline-block;
  height: 1em;
  width: 1em;
}

.sr-only {
  clip: rect(0, 0, 0, 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 420ms ease, transform 420ms ease;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }

  [data-reveal] {
    opacity: 1;
    transform: none;
  }
}

