/* ==========================================================
   Paximi — editorial light-mode design system
   ========================================================== */

@font-face {
  font-family: "EB Garamond";
  src: url("fonts/eb-garamond-latin-500-normal.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("fonts/eb-garamond-latin-600-normal.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("fonts/eb-garamond-latin-500-italic.woff2") format("woff2");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Source Serif 4";
  src: url("fonts/source-serif-4-latin-400-normal.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Serif 4";
  src: url("fonts/source-serif-4-latin-400-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Source Serif 4";
  src: url("fonts/source-serif-4-latin-600-normal.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root {
  --paper: #faf7f1;
  --paper-deep: #f3eee4;
  --ink: #1c1a17;
  --graphite: #57534b;
  --rule: #dcd6cc;
  --bronze: #8a6535;
  --bronze-dark: #6f4f27;
  --display: "EB Garamond", "Georgia", serif;
  --body: "Source Serif 4", "Georgia", serif;
  --label: "Source Serif 4", "Georgia", serif;
  --measure: 1060px;
}

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

html { scroll-behavior: smooth; }

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: 1.0625rem;
  line-height: 1.72;
  -webkit-font-smoothing: antialiased;
}

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

a { color: var(--bronze); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--bronze-dark); }

::selection { background: #e8dcc4; }

/* ---------- header ---------- */

.site-header { padding-top: 34px; }
.site-header .container {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 10px 24px;
  padding-bottom: 18px;
}
.masthead-rule {
  border: 0;
  border-top: 2px solid var(--ink);
  position: relative;
  max-width: calc(var(--measure) - 56px);
  margin: 0 auto;
}
.masthead-rule::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 3px;
  border-top: 1px solid var(--ink);
}

.wordmark {
  font-family: var(--display);
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: 0.30em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}
.wordmark:hover { color: var(--ink); }

.site-nav a {
  font-family: var(--label);
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--graphite);
  margin-left: 26px;
}
.site-nav a:first-child { margin-left: 0; }
.site-nav a:hover { color: var(--ink); }
.site-nav a[aria-current="page"] {
  color: var(--ink);
  border-bottom: 1px solid var(--bronze);
  padding-bottom: 2px;
}

/* ---------- shared blocks ---------- */

.kicker {
  font-family: var(--label);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-bottom: 18px;
}

h1, h2, h3 { font-family: var(--display); font-weight: 500; }

h1 {
  font-size: clamp(2.4rem, 5.4vw, 3.9rem);
  line-height: 1.12;
  letter-spacing: -0.005em;
}
h1 em, h2 em { font-style: italic; }

h2 {
  font-size: clamp(1.7rem, 3.4vw, 2.3rem);
  line-height: 1.2;
  margin-bottom: 22px;
}

h3 {
  font-size: 1.35rem;
  font-weight: 600;
  margin-bottom: 10px;
}

.lede {
  font-size: 1.22rem;
  line-height: 1.65;
  color: var(--graphite);
  max-width: 40em;
}

.prose p { margin-bottom: 1.15em; max-width: 42em; }
.prose p:last-child { margin-bottom: 0; }
.prose ul { margin: 0 0 1.15em 1.2em; max-width: 40em; }
.prose li { margin-bottom: 0.45em; }

.ornament {
  text-align: center;
  color: var(--bronze);
  font-family: var(--display);
  font-size: 1.1rem;
  letter-spacing: 1.4em;
  padding-left: 1.4em; /* recenter around letter-spacing */
  margin: 0;
  border: 0;
}
.ornament::before { content: "· · ·"; }

section, .page-section { padding: 78px 0; }
.hairline { border: 0; border-top: 1px solid var(--rule); max-width: calc(var(--measure) - 56px); margin: 0 auto; }

.btn {
  display: inline-block;
  font-family: var(--label);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--paper);
  background: var(--ink);
  padding: 15px 34px;
  border: 1px solid var(--ink);
  transition: background 0.15s ease, color 0.15s ease;
}
.btn:hover { background: transparent; color: var(--ink); }
.btn-outline {
  background: transparent;
  color: var(--ink);
}
.btn-outline:hover { background: var(--ink); color: var(--paper); }

/* ---------- hero ---------- */

.hero { padding: 90px 0 84px; }
.hero .container {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(240px, 1fr);
  gap: 64px;
  align-items: start;
}
.hero .lede { margin-top: 26px; }
.hero .btn { margin-top: 38px; }

/* portrait frame — shows a monogram until images/headshot.jpg exists */
.portrait { margin: 0; }
.portrait-img {
  aspect-ratio: 4 / 5;
  border: 1px solid var(--ink);
  outline: 1px solid var(--rule);
  outline-offset: 6px;
  background-color: var(--paper-deep);
  background-image: url("images/headshot.jpg");
  background-size: cover;
  background-position: center top;
  display: flex;
  align-items: center;
  justify-content: center;
}
.portrait-img .monogram {
  font-family: var(--display);
  font-size: 4.6rem;
  font-weight: 500;
  color: var(--rule);
  letter-spacing: 0.08em;
}
.portrait figcaption {
  font-family: var(--label);
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--graphite);
  text-align: center;
  margin-top: 16px;
}

/* ---------- service teasers / numbered sections ---------- */

.teasers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 44px;
  margin-top: 14px;
}
.teaser .num {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--bronze);
  display: block;
  margin-bottom: 12px;
}
.teaser h3 { margin-bottom: 12px; }
.teaser p { color: var(--graphite); font-size: 0.99rem; margin-bottom: 14px; }
.teaser a {
  font-family: var(--label);
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.svc {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 28px;
  padding: 64px 0;
}
.svc + .svc { border-top: 1px solid var(--rule); }
.svc .num {
  font-family: var(--display);
  font-size: 2.2rem;
  font-style: italic;
  color: var(--bronze);
  line-height: 1;
}
.svc h2 { margin-bottom: 18px; }
.svc h4 {
  font-family: var(--label);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--graphite);
  margin: 26px 0 10px;
}

/* ---------- process / steps ---------- */

.steps { margin-top: 10px; }
.step {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 22px;
  padding: 24px 0;
  border-bottom: 1px solid var(--rule);
}
.step:last-child { border-bottom: 0; }
.step .num {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--bronze);
}
.step p { color: var(--graphite); font-size: 0.99rem; max-width: 44em; }

/* ---------- disciplines strip ---------- */

.disciplines {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 0;
  font-family: var(--label);
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--graphite);
  text-align: center;
}
.disciplines span { padding: 0 22px; }
.disciplines span + span { border-left: 1px solid var(--rule); }

/* ---------- CTA band ---------- */

.cta-band { text-align: center; padding: 88px 0; }
.cta-band h2 { margin-bottom: 14px; }
.cta-band p { color: var(--graphite); max-width: 36em; margin: 0 auto 34px; }

/* ---------- FAQ ---------- */

.faq { max-width: 46em; }
.faq dt {
  font-family: var(--display);
  font-size: 1.25rem;
  font-weight: 600;
  margin-top: 30px;
}
.faq dd { margin: 8px 0 0; color: var(--graphite); }

/* ---------- about / two-column ---------- */

.two-col {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(0, 1.8fr);
  gap: 64px;
  align-items: start;
}

/* ---------- contact ---------- */

.contact-email {
  font-family: var(--display);
  font-size: clamp(1.5rem, 3.4vw, 2.2rem);
  font-weight: 500;
}

/* ---------- footer ---------- */

.site-footer { padding: 46px 0 56px; }
.site-footer .container {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px 24px;
  font-family: var(--label);
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--graphite);
}
.site-footer a { color: var(--graphite); }
.site-footer a:hover { color: var(--ink); }

/* ---------- page head (interior pages) ---------- */

.page-head { padding: 78px 0 64px; }
.page-head .lede { margin-top: 22px; }

/* ---------- responsive ---------- */

@media (max-width: 820px) {
  .hero .container { grid-template-columns: 1fr; gap: 48px; }
  .portrait { max-width: 320px; }
  .two-col { grid-template-columns: 1fr; gap: 44px; }
  .two-col .portrait { max-width: 300px; }
  .svc { grid-template-columns: 1fr; gap: 8px; }
  section, .page-section { padding: 58px 0; }
  .hero { padding: 64px 0 58px; }
}

@media (max-width: 560px) {
  .site-header .container { flex-direction: column; align-items: flex-start; }
  .site-nav a { margin-left: 0; margin-right: 20px; }
  .disciplines span { border: 0 !important; padding: 0 12px; }
}
