/* ── Contact page layout ── */
.contact {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(32px, 5vw, 96px);
  align-items: start;
  padding-top: clamp(48px, 6vw, 80px);
}
.contact__intro { position: sticky; top: 98px; }

/* ── Intro text ── */
.contact__title {
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: 0.96;
  letter-spacing: -0.035em;
  margin: 18px 0 16px;
  color: var(--ink);
}
.contact__title .en {
  display: block;
  font-size: 0.3em;
  font-weight: 500;
  color: var(--ink-3);
  margin-top: 0.5em;
  letter-spacing: 0.01em;
}
.contact__lead {
  font-size: 1rem;
  color: var(--ink-2);
  line-height: 1.6;
  max-width: 34ch;
}

/* ── Info block ── */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.ci { display: flex; flex-direction: column; gap: 4px; }
.ci .k {
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
}
.ci a, .ci .v { font-weight: 600; font-size: 1rem; color: var(--ink); }
.ci a { border-bottom: 1.5px solid transparent; transition: border-color .2s; width: fit-content; }
.ci a:hover { border-color: var(--accent); }

/* ── Social pills ── */
.contact-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}
.social-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink-2);
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.social-pill:hover { border-color: var(--ink); color: var(--ink); background: var(--paper); }
.social-pill__icon {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: var(--ink-3);
}

/* ── Form card ── */
.form-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: clamp(24px, 3.5vw, 44px);
}
.form-stack { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-actions {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 28px;
}
.form-note { font-size: 0.83rem; color: var(--ink-3); }

/* ── Success state ── */
.success {
  text-align: center;
  padding: clamp(30px, 5vw, 60px) 20px;
}
.success .ic {
  width: 68px; height: 68px; border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-ink);
  display: grid; place-items: center;
  margin: 0 auto 20px;
  font-size: 1.8rem;
}

/* ── Responsive ── */
@media (max-width: 860px) {
  .contact { grid-template-columns: 1fr; }
  .contact__intro { position: static; }
  .form-row { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .form-row { grid-template-columns: 1fr; }
}
