/* ============================================================
   Recital — base: design tokens, fonts, reset, typography
   ============================================================ */

/* Self-hosted EB Garamond (OFL) — vendored, no network fonts. */
@font-face {
  font-family: "EB Garamond";
  src: url("../vendor/fonts/EBGaramond-Regular.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("../vendor/fonts/EBGaramond-Italic.woff2") format("woff2");
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("../vendor/fonts/EBGaramond-Medium.woff2") format("woff2");
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("../vendor/fonts/EBGaramond-SemiBold.woff2") format("woff2");
  font-weight: 600; font-style: normal; font-display: swap;
}

:root {
  /* Palette — warm paper & ink, restrained gold/cordovan accents */
  --paper:      #f7f3ea;
  --paper-2:    #fffdf8;
  --card:       #fffdf8;
  --ink:        #211c16;
  --ink-soft:   #4b4339;
  --ink-faint:  #7c7264;
  --rule:       #e0d7c6;
  --rule-2:     #efe8db;
  --accent:     #7c2d2d;   /* cordovan */
  --accent-2:   #9a7b3f;   /* antique gold */
  --focus:      #2b6cb0;
  --shadow:     rgba(40, 30, 15, 0.10);

  --font-serif: "EB Garamond", Georgia, "Times New Roman", serif;
  --font-ui:    system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --maxw: 1080px;
  --radius: 10px;
  --radius-sm: 6px;
}

/* ---- reset ---- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 1.125rem;
  line-height: 1.55;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--accent); text-underline-offset: 2px; }
a:hover { color: #5c1f1f; }
h1, h2, h3 { line-height: 1.15; font-weight: 600; margin: 0; }
p { margin: 0 0 0.75em; }
button { font-family: inherit; }

/* ---- a11y helpers ---- */
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: 8px; top: -48px; z-index: 100;
  background: var(--ink); color: var(--paper-2); padding: 0.55em 1em;
  border-radius: var(--radius-sm); font-family: var(--font-ui); font-size: 0.9rem;
  text-decoration: none; transition: top 0.15s ease;
}
.skip-link:focus { top: 8px; color: var(--paper-2); }

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

/* ---- header ---- */
.site-header {
  background:
    radial-gradient(120% 140% at 50% -20%, rgba(154, 123, 63, 0.10), transparent 60%),
    var(--paper);
  border-bottom: 1px solid var(--rule);
}
.site-header__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 3.2rem 1.25rem 2.2rem;
  text-align: center;
}
.eyebrow {
  font-family: var(--font-ui); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 0.7rem; font-weight: 600; color: var(--ink-faint); margin: 0 0 0.5rem;
}
.wordmark {
  font-size: clamp(2.8rem, 7vw, 4.4rem);
  font-weight: 600; letter-spacing: 0.01em; margin: 0 0 0.35rem;
}
.wordmark::after {
  content: ""; display: block; width: 64px; height: 2px; margin: 0.5rem auto 0;
  background: linear-gradient(90deg, transparent, var(--accent-2), transparent);
}
.lede {
  max-width: 44ch; margin: 0.9rem auto 0; color: var(--ink-soft); font-size: 1.18rem;
}
.lede strong { color: var(--ink); font-weight: 600; }
.site-stats {
  font-family: var(--font-ui); font-size: 0.82rem; color: var(--ink-faint);
  margin: 1.1rem 0 0; letter-spacing: 0.02em;
}

/* ---- footer ---- */
.site-footer {
  border-top: 1px solid var(--rule); margin-top: 3rem;
  background: var(--paper-2);
}
.site-footer__inner {
  max-width: 60ch; margin: 0 auto; padding: 2.5rem 1.25rem 3.5rem;
}
.site-footer h2 {
  font-size: 1.35rem; margin-bottom: 0.6rem;
}
.site-footer p { color: var(--ink-soft); font-size: 1.02rem; }
.site-footer .fineprint { font-size: 0.9rem; color: var(--ink-faint); }
