/* ─── Contact page ───────────────────────────────────── */
.contact-page {
  padding: 120px 40px 80px;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 60px 80px;
}

/* Photo — colonne gauche, pleine hauteur */
.contact-photo-wrap {
  grid-row: 1 / 3;
  position: relative;
  overflow: hidden;
}
.contact-photo-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(.9);
}

/* Bio — colonne droite ligne 1 */
.contact-bio {
  align-self: start;
}
.contact-bio p {
  font-size: 15px;
  line-height: 1.85;
  color: rgba(239,239,239,.65);
  font-weight: 300;
  margin-bottom: 18px;
}

/* Contact links — colonne droite ligne 2 */
.contact-links-wrap {
  align-self: end;
}

/* Footer */
footer {
  border-top: 1px solid var(--border);
  padding: 28px 40px;
  display: flex;
  justify-content: space-between;
}
footer span {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--dim);
}

/* ─── Responsive ─────────────────────────────────────── */
@media (max-width: 900px) {
  .contact-page {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    padding: 100px 24px 60px;
    gap: 48px;
  }
  .contact-photo-wrap { grid-row: auto; max-height: 60vw; }
  footer { padding: 24px; }
}
