/* ---------------------------------------------------------
   20. About page
   --------------------------------------------------------- */
.about-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-xl);
  padding-block: var(--space-xl) var(--space-md);
  align-items: start;
}

.about-layout--text-only {
  grid-template-columns: 1fr;
}

.about-hero__meta {
  margin-block-start: 1rem;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-primary);
}

.about-portrait figure img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
}

.about-portrait {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  position: sticky;
  top: calc(var(--header-height) + 1rem);
  max-width: 300px;
}

.about-intro {
  font-family: var(--font-serif);
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  font-weight: 300;
  line-height: 1.45;
  color: var(--color-text-primary);
  margin-block-end: var(--space-md);
}

.about-intro p {
  margin-block-end: var(--space-md);
}

.about-bio { margin-block-end: var(--space-lg); }

.about-philosophy {
  margin-block: var(--space-md);
  padding: var(--space-md);
  background-color: var(--surface-muted);
  border-inline-start: 3px solid var(--accent-primary);
}

.about-philosophy h2,
.about-profile h2 {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-primary);
  margin-block-end: 1rem;
}

.about-profile { margin-block: var(--space-md); }

.about-profile--ruled {
  border-block-start: 1px solid var(--border-subtle);
  padding-block-start: var(--space-md);
}

.about-profile ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  max-width: 40ch;
}

.about-profile li {
  padding-inline-start: 1.25rem;
  position: relative;
  font-size: 0.9rem;
}

.about-profile li::before {
  content: '—';
  position: absolute;
  inset-inline-start: 0;
  color: var(--accent-primary);
}

@media (max-width: 900px) {
  .about-layout {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }
  .about-portrait { position: static; max-width: 380px; }
}

/* CTA seal — stone background with hairline anchors the page close */
.about-cta {
  background-color: var(--surface-muted);
  border-block-start: 1px solid var(--border-subtle);
}
