/* contact.css — extends shared.css */

.contact-section {
  max-width: 960px;
  margin: 0 auto;
  padding: 3rem 1.5rem 5rem;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 3rem;
  align-items: start;
}
.contact-info h2 { font-size: 1.4rem; font-weight: 800; margin-bottom: 1.25rem; letter-spacing: -0.02em; }

.info-item { display: flex; align-items: flex-start; gap: 0.85rem; margin-bottom: 1.25rem; }
.info-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  background: var(--primary-light);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.info-text strong {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted-fg);
  margin-bottom: 0.2rem;
}
.info-text span { font-size: 0.9rem; color: var(--foreground); line-height: 1.6; }

.contact-form {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-md);
}
.contact-form h2 { font-size: 1.15rem; font-weight: 800; margin-bottom: 1.5rem; letter-spacing: -0.01em; }
.contact-form .btn-primary { width: 100%; justify-content: center; padding: 0.75rem; }

@media (max-width: 768px) {
  .contact-section { grid-template-columns: 1fr; gap: 2rem; padding: 2rem 1.25rem 4rem; }
}
@media (max-width: 480px) {
  .contact-section { padding: 1.75rem 1rem 3.5rem; }
  .contact-form { padding: 1.35rem; }
}
