
:root {
  --ink: #181715;
  --paper: #fbfaf7;
  --mist: #f0ece4;
  --line: #ddd6ca;
  --clay: #9b5f4d;
  --sage: #697766;
  --night: #243448;
  --max: 1180px;
  --pad: clamp(1.25rem, 4vw, 4rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
  letter-spacing: 0;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-underline-offset: 0.22em; }
p { font-size: 1.03rem; line-height: 1.75; }
h1, h2, h3 { margin: 0 0 1rem; font-weight: 500; letter-spacing: 0; }
h1 { font-size: clamp(3.4rem, 8vw, 8.2rem); line-height: 0.92; }
h2 { font-size: clamp(2.15rem, 4.8vw, 4.9rem); line-height: 0.98; max-width: 900px; }
h3 { font-size: 1.24rem; }
.skip-link { position: absolute; left: -999px; top: 1rem; }
.skip-link:focus { left: 1rem; z-index: 10; background: var(--paper); padding: .5rem; }

.site-header {
  position: fixed;
  z-index: 5;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem var(--pad);
  background: rgba(251,250,247,.9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(24,23,21,.08);
}
.brand { font-size: 1.1rem; text-decoration: none; }
.site-header nav, .site-footer nav { display: flex; flex-wrap: wrap; gap: .9rem 1.2rem; }
.site-header nav a, .site-footer nav a { text-decoration: none; font-size: .86rem; }
.site-header nav a[aria-current="page"] { color: var(--clay); }

.hero {
  min-height: 100vh;
  display: grid;
  align-items: end;
  color: var(--paper);
  position: relative;
  overflow: hidden;
  padding: 8rem var(--pad) 4rem;
}
.hero picture, .hero picture::after { position: absolute; inset: 0; }
.hero picture::after {
  content: "";
  background: linear-gradient(90deg, rgba(0,0,0,.75), rgba(0,0,0,.25), rgba(0,0,0,.06));
}
.hero img { width: 100%; height: 100%; object-fit: cover; object-position: 60% center; }
.hero-copy { position: relative; max-width: 1060px; }
.hero-copy p { max-width: 650px; font-size: 1.18rem; }
.eyebrow {
  color: var(--clay);
  font-size: .76rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0;
  text-transform: uppercase;
}
.hero .eyebrow, .contact-cta .eyebrow { color: #f0b89e; }

.actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.5rem; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .8rem 1.1rem;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--paper);
  text-decoration: none;
  border-radius: 6px;
  font-size: .9rem;
}
.button.outline { background: transparent; color: var(--ink); }
.button.light { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.button.outline-light { background: transparent; color: var(--paper); border-color: rgba(251,250,247,.72); }
.text-link { font-weight: 700; }

.section, .statement { padding: clamp(4rem, 8vw, 8rem) var(--pad); }
.section > *, .statement > *, .site-footer > * { max-width: var(--max); margin-left: auto; margin-right: auto; }
.statement { text-align: center; }
.statement p { max-width: 790px; margin-left: auto; margin-right: auto; }
.section-intro { margin-bottom: 2.2rem; }
.section-intro p { max-width: 720px; }
.band { background: var(--mist); }
.split {
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.category-grid, .service-grid, .process-grid, .journal-grid, .price-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.category-card {
  min-width: 0;
  text-decoration: none;
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}
.category-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  margin-bottom: .9rem;
  background: var(--mist);
}
.category-card span, .work-grid h3 { font-size: 1.22rem; }
.category-card p { margin-bottom: 0; }

.work-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.work-grid article { position: relative; min-width: 0; overflow: hidden; background: var(--mist); }
.work-grid article:nth-child(5n + 1) { grid-row: span 2; }
.work-grid img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; transition: transform 280ms ease; }
.work-grid article:hover img { transform: scale(1.035); }
.work-grid div {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 1rem;
  color: white;
  background: linear-gradient(0deg, rgba(0,0,0,.62), transparent);
}
.work-grid p { margin: 0 0 .1rem; font-size: .78rem; text-transform: uppercase; }
.work-grid h3 { margin: 0; }

.service-grid article, .process-grid article, .price-grid article, .inquiry-panel {
  border-top: 1px solid var(--line);
  padding-top: 1.1rem;
}
.process-grid span { display: block; color: var(--sage); font-size: .82rem; font-weight: 700; margin-bottom: .8rem; }
.feature-image { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; background: var(--mist); }

.sub-hero {
  min-height: 76vh;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, .95fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  padding: 8rem var(--pad) 4rem;
}
.sub-hero img { width: 100%; height: min(680px, 70vh); object-fit: cover; }
.sub-hero div { padding-bottom: 2rem; }
.sub-hero p { max-width: 650px; }
.filter-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 2rem; }
.filter-row a {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: .6rem .9rem;
  text-decoration: none;
}

.journal-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; margin-bottom: 1rem; }
.contact-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding: clamp(4rem, 8vw, 8rem) var(--pad);
  background: var(--night);
  color: var(--paper);
}
.contact-cta > div { max-width: 920px; }
.contact-cta img { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; }
.inquiry-panel ul { margin: 0; padding-left: 1.1rem; line-height: 1.9; }

.site-footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 2rem;
  padding: 3rem var(--pad);
  border-top: 1px solid var(--line);
}
.fine-print { grid-column: 1 / -1; font-size: .82rem; color: var(--sage); }

@media (max-width: 920px) {
  .site-header { align-items: flex-start; flex-direction: column; position: absolute; background: rgba(251,250,247,.96); }
  .hero { padding-top: 11rem; }
  .split, .sub-hero, .contact-cta, .site-footer { grid-template-columns: 1fr; }
  .category-grid, .service-grid, .process-grid, .journal-grid, .price-grid, .work-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sub-hero img { height: 54vh; }
}

@media (max-width: 620px) {
  h1 { font-size: 3.35rem; }
  h2 { font-size: 2.35rem; }
  .hero { min-height: 92vh; }
  .hero img { object-position: 64% center; }
  .category-grid, .service-grid, .process-grid, .journal-grid, .price-grid, .work-grid { grid-template-columns: 1fr; }
  .work-grid img { min-height: 320px; }
  .work-grid article:nth-child(5n + 1) { grid-row: auto; }
}
