:root {
  /* Align with existing theme variables (assets/css/main.css) */
  --green: var(--primary);
  --cream: var(--bg-light);
  --radius: 18px;
}

/* ================= HERO ================= */

.contact-hero {
  height: 70vh;
  background:
    linear-gradient(rgba(60,80,70,0.75), rgba(130,160,110,0.75)),
    url("../images/contact/hero.jpg") center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-hero-overlay {
  text-align: center;
  color: #fff;
  padding: 0 20px;
}

.contact-hero-overlay h1 {
  font-size: clamp(2.6rem, 5vw, 3.6rem);
  margin-bottom: 10px;
  color: #fff;
}

.contact-hero-overlay p {
  font-size: 1.05rem;
  color: #fff;
}

/* ================= LAYOUT ================= */

.contact-wrapper {
  background: var(--cream);
  padding: 90px 8%;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 60px;
}

/* ================= INFO ================= */

.contact-info h2 {
  margin-bottom: 25px;
}

.info-card {
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 25px;
  margin-bottom: 20px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

.info-card h4 {
  margin-bottom: 8px;
  color: var(--green);
}

.info-card p {
  color: var(--text-muted);
  line-height: 1.6;
}

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

.contact-form {
  background: #fff;
  border-radius: var(--radius);
  padding: 35px;
  box-shadow: 0 15px 35px rgba(0,0,0,0.1);
}

.contact-form h2 {
  margin-bottom: 25px;
}

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

.form-group label {
  font-size: 0.9rem;
  margin-bottom: 6px;
}

.form-group input,
.form-group textarea {
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid #dcdcdc;
  font-family: inherit;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px;
}

.send-btn {
  width: 100%;
  margin-top: 15px;
  padding: 14px;
  background: var(--green);
  color: #fff;
  border: none;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
}

.send-btn:hover {
  background: #6a8d3b;
}

/* ================= MAP ================= */

.contact-map iframe {
  width: 100%;
  height: 420px;
  border: none;
}

/* ================= RESPONSIVE ================= */

@media (max-width: 900px) {
  .contact-wrapper {
    grid-template-columns: 1fr;
    padding: 70px 20px;
  }

  .form-row {
    grid-template-columns: 1fr;
  }
}
