/* ============== Index / Home page ============== */
.opening {
  padding-top: clamp(72px, 8vw, 120px);
}

.opening__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
  align-items: end;
}

.opening__copy { grid-column: 1 / span 7; }
.opening__copy h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-7);
  letter-spacing: -0.04em;
  line-height: 0.96;
}
.opening__meta {
  grid-column: 9 / span 4;
  display: flex; flex-direction: column; gap: 14px;
  font-size: 0.95rem; color: var(--fg-muted);
}

.opening__meta dl { display: grid; grid-template-columns: max-content 1fr; gap: 4px 18px; }
.opening__meta dt { color: var(--fg-subtle); font-family: var(--sans); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; align-self: center; }
.opening__meta dd { margin: 0; font-family: var(--serif); font-variation-settings: "opsz" 36, "wght" 380, "SOFT" 35; font-size: var(--fs-3); letter-spacing: -0.005em; color: var(--ink-soft); }

@media (max-width: 1100px) {
  .opening__copy, .opening__meta { grid-column: 1 / -1; }
  .opening__meta { margin-top: 32px; }
}

.featured-collection {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
  align-items: stretch;
}

.featured-collection__media {
  grid-column: 1 / span 7;
  position: relative;
  aspect-ratio: 5 / 4;
  overflow: hidden;
  background: var(--river-stone);
}

.featured-collection__media svg, .featured-collection__media img {
  width: 100%; height: 100%; object-fit: cover;
}

.featured-collection__copy {
  grid-column: 9 / span 4;
  display: flex; flex-direction: column; justify-content: center;
  gap: var(--sp-4);
}

.featured-collection__copy h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-6);
  letter-spacing: -0.035em;
  line-height: 1;
}

@media (max-width: 1100px) {
  .featured-collection__media, .featured-collection__copy { grid-column: 1 / -1; }
}

.service-promise {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
}

.service-promise__intro { grid-column: 1 / span 4; }
.service-promise__intro h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-5);
  letter-spacing: -0.03em;
  line-height: 1;
}

.service-promise__list { grid-column: 6 / span 7; }

.quiet-cta {
  text-align: center;
  padding-block: clamp(120px, 14vw, 240px);
}

.quiet-cta__line {
  display: block;
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 280, "SOFT" 100;
  font-size: clamp(2.4rem, 1.6rem + 4vw, 6rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: 22ch;
  margin: 0 auto 48px;
  color: var(--ink);
}

@media (max-width: 1100px) {
  .service-promise__intro, .service-promise__list { grid-column: 1 / -1; }
}

/* ============== Collections page ============== */
.collection-row {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
  border-top: 1px solid var(--line);
  padding-top: clamp(40px, 4vw, 72px);
  padding-bottom: clamp(40px, 4vw, 72px);
  align-items: start;
}

.collection-row__num {
  grid-column: 1 / span 1;
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 200, "SOFT" 100;
  font-size: 1.6rem;
  color: var(--accent-warm);
  letter-spacing: -0.02em;
}

.collection-row__title { grid-column: 2 / span 4; }
.collection-row__title h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-6);
  letter-spacing: -0.035em;
  line-height: 1;
}

.collection-row__title p { margin-top: 24px; max-width: 36ch; color: var(--fg-muted); }

.collection-row__partners {
  grid-column: 7 / span 6;
  display: flex; flex-wrap: wrap; gap: 10px;
  align-content: start;
}

.collection-row__partners span {
  display: inline-flex;
  padding: 8px 16px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-pill);
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}

@media (max-width: 1100px) {
  .collection-row__num { grid-column: 1 / -1; }
  .collection-row__title, .collection-row__partners { grid-column: 1 / -1; }
}

/* ============== Brand partners page ============== */
.standards {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
}

.standards__heading { grid-column: 1 / span 4; }
.standards__heading h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-5);
  letter-spacing: -0.03em;
  line-height: 1;
}

.standards__criteria { grid-column: 6 / span 7; }

@media (max-width: 1100px) {
  .standards__heading, .standards__criteria { grid-column: 1 / -1; }
}

.partner-section h3 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-5);
  letter-spacing: -0.03em;
  margin-bottom: 36px;
  line-height: 1.04;
}

/* ============== Service page ============== */
.service-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-6) var(--sp-5);
}

.service-grid__item { grid-column: span 4; padding-top: 28px; border-top: 1px solid var(--line); }
.service-grid__item h3 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 36, "wght" 380, "SOFT" 35;
  font-size: var(--fs-4);
  margin-bottom: 12px;
  letter-spacing: -0.005em;
}

.service-grid__item p { color: var(--fg-muted); margin: 0; font-size: 0.95rem; }

@media (max-width: 1100px) { .service-grid__item { grid-column: span 6; } }
@media (max-width: 600px) { .service-grid__item { grid-column: span 12; } }

/* ============== Journal ============== */
.journal-feature {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-5);
  padding-bottom: clamp(56px, 6vw, 120px);
  border-bottom: 1px solid var(--line);
  align-items: end;
}

.journal-feature__media { grid-column: 1 / span 7; aspect-ratio: 16 / 11; background: var(--river-stone); overflow: hidden; }
.journal-feature__media svg, .journal-feature__media img { width: 100%; height: 100%; object-fit: cover; }
.journal-feature__copy { grid-column: 8 / span 5; align-self: end; padding-bottom: 8px; }
.journal-feature__copy h2 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-6);
  letter-spacing: -0.035em;
  line-height: 1;
}

@media (max-width: 1100px) {
  .journal-feature__media, .journal-feature__copy { grid-column: 1 / -1; }
}

/* ============== Contact ============== */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-7) var(--sp-5);
}

.contact-grid__form { grid-column: 1 / span 8; }
.contact-grid__aside { grid-column: 9 / span 4; align-self: start; position: sticky; top: calc(var(--header-height) + 40px); }

.contact-aside h3 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-5);
  letter-spacing: -0.03em;
  line-height: 1;
}

.contact-aside p { color: var(--fg-muted); margin-top: 18px; }
.contact-aside .email-link {
  display: block;
  margin-top: 28px;
  font-family: var(--serif);
  font-variation-settings: "opsz" 36, "wght" 380, "SOFT" 50;
  font-size: var(--fs-4);
  letter-spacing: -0.005em;
  color: var(--ink);
  word-break: break-word;
  border-bottom: 1px solid var(--line);
  padding-bottom: 16px;
}

.contact-aside .email-link:hover { color: var(--accent-warm); }

@media (max-width: 1100px) {
  .contact-grid__form, .contact-grid__aside { grid-column: 1 / -1; }
  .contact-grid__aside { position: static; }
}

/* ============== 404 ============== */
.notfound {
  min-height: 80vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  padding: 160px 24px 120px;
}

.notfound__numeral {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 200, "SOFT" 100;
  font-size: clamp(8rem, 4rem + 18vw, 22rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
  color: var(--river-stone);
}

.notfound h1 {
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "wght" 320, "SOFT" 80;
  font-size: var(--fs-6);
  letter-spacing: -0.035em;
  margin-top: 12px;
}

.notfound p { margin-top: 28px; max-width: 44ch; margin-inline: auto; color: var(--fg-muted); }
.notfound .btn { margin-top: 40px; }

/* ============== Pagebody width helpers ============== */
.editorial-shell { padding-block: clamp(80px, 9vw, 160px); }
