/* ─── Contact section ─── */
.contact-section { background: var(--bg); padding: 96px 0 120px; }

.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 96px; align-items: start; }

/* Left */
.contact-headline {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  font-weight: 400; color: var(--ink);
  line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 20px;
}
.contact-headline em { font-style: italic; color: var(--ink-2); }

.contact-subline {
  font-size: 0.95rem; font-weight: 300;
  color: var(--ink-2); line-height: 1.75; max-width: 380px; margin-bottom: 40px;
}

.contact-meta { display: flex; flex-direction: column; gap: 10px; }
.contact-meta-item {
  display: flex; align-items: center; gap: 12px;
  font-size: 0.83rem; font-weight: 300; color: var(--ink-3);
}
.contact-meta-item::before {
  content: ''; width: 4px; height: 4px;
  border-radius: 50%; background: var(--ink-3); flex-shrink: 0;
}

/* Right: cards */
.contact-cards { display: flex; flex-direction: column; gap: 12px; }

.contact-card {
  display: flex; align-items: center; gap: 20px;
  padding: 22px 24px;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  transition: all 0.22s ease;
}
.contact-card:hover { border-color: var(--ink-3); box-shadow: 0 8px 28px rgba(17,17,16,0.07); }

.contact-card-icon {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; background: var(--bg-alt);
}

/* SVG icons */
.contact-card-icon svg { width: 20px; height: 20px; }

.contact-card-body { flex: 1; }
.contact-card-label {
  display: block; font-size: 0.68rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 3px;
}
.contact-card-value {
  font-family: 'Instrument Serif', serif;
  font-size: 1.05rem; font-weight: 400; color: var(--ink); letter-spacing: -0.01em;
}

.contact-card-arrow {
  font-size: 0.95rem; color: var(--ink-3);
  transition: all 0.2s ease;
}
.contact-card:hover .contact-card-arrow { color: var(--ink); transform: translateX(4px); }

/* Bottom note */
.contact-note {
  text-align: center; margin-top: 64px;
  font-size: 0.83rem; font-weight: 300;
  color: var(--ink-3); line-height: 1.75;
}

/* ─── Mobile ─── */
@media (max-width: 768px) {
  .contact-layout { grid-template-columns: 1fr; gap: 56px; }
}
