/* ================= CONTACT PAGE ================= */

.page-title {
  font-family: 'Playfair Display', serif;
  font-size: 44px;
  margin-bottom: 10px;
}

.page-subtitle {
  max-width: 820px;
  margin: auto;
  font-size: 17px;
  color: #444;
}

/* Contact Info */
.contact-info {
  max-width: 900px;
}

.contact-info h2 {
  font-family: 'Playfair Display', serif;
  margin-bottom: 15px;
}

.contact-email {
  margin-top: 25px;
  font-size: 18px;
}

.contact-email a {
  text-decoration: none;
  color: #2a2a2a;
}

/* ================= CONTACT FORM ================= */

.contact-form-wrap {
  max-width: 720px;
}

.contact-form-wrap h2 {
  font-family: 'Playfair Display', serif;
}

.form-subtext {
  max-width: 600px;
  margin: 10px auto 35px;
  font-size: 15px;
  color: #555;
}

.contact-form {
  background: #ffffff;
  padding: 40px 42px;
  border-radius: 14px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.08);
}

/* Grid */
.form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}

.form-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 22px;
}

.form-group label {
  font-size: 14px;
  margin-bottom: 6px;
  color: #444;
}

.form-group input,
.form-group textarea {
  padding: 12px 14px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: #222;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.06);
}

.contact-form button {
  margin-top: 10px;
  padding: 12px 34px;
}

.note {
  margin-top: 18px;
  font-size: 14px;
  color: #666;
}

/* Social */
.social-text {
  margin-top: 10px;
  font-size: 15px;
  color: #555;
}

/* Responsive */
@media (max-width: 768px) {
  .form-row {
    grid-template-columns: 1fr;
  }

  .contact-form {
    padding: 28px 22px;
  }

  .page-title {
    font-size: 32px;
  }
}
