/* --- CONTACT PAGE STYLES --- */

/* Contact Header */
.contact-header {
  background-color: var(--primary);
  color: white;
  text-align: center;
  padding: 60px 20px 80px 20px; /* Extra padding bottom for spacing */
}
.contact-header h1 { font-size: 2.2rem; margin-bottom: 10px; }
.contact-header p { opacity: 0.9; font-size: 1rem; }

/* Contact Methods Grid (Floating) */
.contact-methods-section {
  margin-top: -40px; /* Pulls up to overlap or sit close to header */
  padding-bottom: 60px;
}
.methods-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.method-card {
  background: white;
  padding: 30px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.method-icon {
  width: 50px; height: 50px;
  background: #EAF7F5; color: var(--primary);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  margin-bottom: 5px;
}
.method-card h3 { font-size: 1.1rem; margin: 0; }
.method-card p { font-size: 0.9rem; color: #666; margin-bottom: 10px; }
.btn.outline-green-text {
  border: 1px solid var(--primary); color: var(--primary); background: white;
}

/* Contact Layout (Form + Sidebar) */
.contact-layout {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 30px;
}

/* Contact Form */
.contact-form-card {
  background: white;
  padding: 40px;
  border-radius: var(--radius-lg);
  box-shadow: 0 2px 10px rgba(0,0,0,0.03);
}
.contact-form-card h3 { font-size: 1.5rem; margin-bottom: 5px; }
.form-sub { margin-bottom: 25px; color: #666; font-size: 0.95rem; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { margin-bottom: 20px; }
.form-group label {
  display: block; font-weight: 600; font-size: 0.9rem; margin-bottom: 8px; color: #333;
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  padding: 12px 16px;
  background: #F8F9FA;
  border: 1px solid #eee;
  border-radius: 8px;
  font-family: var(--font-family);
  font-size: 0.95rem;
  outline: none; transition: 0.2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--primary); background: white;
}

/* Contact Sidebar */
.contact-sidebar { display: flex; flex-direction: column; gap: 20px; }

/* Office Info Card */
.office-card {
  background: white; padding: 30px; border-radius: var(--radius-lg);
}
.office-card h3 { font-size: 1.2rem; margin-bottom: 20px; }
.info-item { display: flex; gap: 15px; margin-bottom: 20px; align-items: flex-start; }
.info-icon {
  width: 40px; height: 40px; background: #EAF7F5; color: var(--primary);
  border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.info-item strong { display: block; font-size: 0.95rem; margin-bottom: 2px; }
.info-item p { margin: 0; font-size: 0.9rem; color: #555; line-height: 1.5; }

/* Map Card */
.map-card {
  background: #eee;
  border-radius: var(--radius-lg);
  height: 250px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; color: #888; gap: 10px;
}

/* Responsive for Contact Page */
@media (max-width: 900px) {
  .contact-layout { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
}