/* Styles for contact page */
.contact-hero { padding: 56px 0 24px 0; text-align: center; background: #ffffff; color: #231c17; /* match body */ }


/* restore default text colors for light background */
.contact-hero .hero-title,
.contact-hero .hero-sub { color: #231c17; }
.hero-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.hero-title { font-family: 'Playfair Display', serif; font-size: 2.8rem; margin: 0 0 8px; color: #231c17; }
.hero-sub { margin: 0 auto; color: #544b45; max-width: 820px; font-size: 1.05rem; }

.contact-section { max-width: 1200px; margin: 28px auto 64px; padding: 0 24px; }
.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: 28px; align-items: start; }

/* Card base */
.card { background: #fff; border-radius: 12px; box-shadow: 0 8px 28px rgba(0,0,0,0.06); padding: 20px; }

.contact-form .form-title { font-family: 'Playfair Display', serif; font-size: 1.25rem; margin: 0 0 6px; }
.contact-form .form-intro { color: #6b655f; margin: 0 0 12px; }
.contact-form .two-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.form-row label { font-weight: 600; color: #2b2320; font-size: 0.95rem; }
.form-row input,
.form-row select,
.form-row textarea {
  border: 1px solid #e6e0d8; padding: 10px 12px; border-radius: 8px; font-size: 0.95rem; font-family: 'Montserrat', Arial, sans-serif; color: #231c17; background: #fff; outline: none;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus { box-shadow: 0 4px 14px rgba(35,28,23,0.06); border-color: #c8b59a; }

.form-actions { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.hero-btn { background: #231c17; color: #f5e8d6; border: none; padding: 10px 18px; border-radius: 8px; cursor: pointer; font-weight: 700; }
.hero-btn:hover { background: #3a2e22; }
.form-message { color: #231c17; }

/* contact info */
.contact-info .info-block { margin-bottom: 14px; }
.contact-info h3 { margin: 0 0 8px; font-size: 1.05rem; }
.contact-info p { margin: 0; color: #544b45; }
.map-block .map-placeholder { background: #f3f1ef; height: 160px; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #9a8f82; }

/* Highlight phone & email in the contact panel */
.contact-info a[href^="tel"], .contact-info a[href^="mailto"] {
  color: #bca98a; /* brand accent */
  font-weight: 700;
  text-decoration: none;
}
.contact-info a[href^="tel"]:hover, .contact-info a[href^="mailto"]:hover {
  color: #9f8a68;
  text-decoration: underline;
}
body:has(.about-page) .navbar .fav-btn svg,
body:has(.about-page) .navbar .fav-btn svg path {
  fill: none !important;
  stroke: #000000 !important;
  stroke-width: 1.5 !important;
}

/* Small screens */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-section { margin: 16px auto 48px; }
  .hero-title { font-size: 2rem; }
  .contact-form .two-cols { grid-template-columns: 1fr; }
}

/* Accessibility focus helpers */
.form-row input:focus-visible,
.form-row textarea:focus-visible,
.form-row select:focus-visible { outline: 3px solid rgba(188,170,138,0.22); }
