/* Contact page — Urban Solar */

/* ===== Page wrapper ===== */
.contact-page {
  background: var(--us-bg-light);
}
.contact-inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ===== Title block ===== */
.contact-title {
  text-align: center;
  padding: 100px 24px 40px;
}
.contact-title h1 {
  font-size: 48px;
  color: var(--us-navy);
  font-weight: 600;
  margin: 0;
  line-height: 1.15;
}

/* ===== Address / Email / Phone row ===== */
.contact-meta {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  text-align: center;
  padding-bottom: 40px;
}
.contact-meta-item .ic {
  width: 40px;
  height: 40px;
  margin: 0 auto 10px;
  color: var(--us-orange);
  display: flex;
  align-items: center;
  justify-content: center;
}
.contact-meta-item .ic svg {
  width: 32px;
  height: 32px;
  fill: currentColor;
}
.contact-meta-item .label {
  color: var(--us-orange);
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px;
}
.contact-meta-item .lines,
.contact-meta-item .lines a {
  color: var(--us-navy);
  font-size: 14px;
  line-height: 1.55;
}
.contact-meta-item .lines a:hover {
  color: var(--us-orange);
}
.contact-meta-item .lines div {
  margin-bottom: 2px;
}

/* ===== How Can We Help? ===== */
.contact-help {
  padding: 40px 0 24px;
  text-align: center;
}
.contact-help h2 {
  font-size: 36px;
  color: var(--us-navy);
  font-weight: 600;
  margin: 0 0 10px;
  line-height: 1.2;
}
.contact-help .subtitle {
  font-size: 16px;
  color: var(--us-text-muted);
  margin: 0 0 28px;
}
.contact-help-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}
.help-card {
  background: var(--us-navy);
  color: var(--us-white);
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.help-card h3 {
  color: var(--us-white);
  font-size: 24px;
  font-weight: 600;
  margin: 0 0 12px;
  line-height: 1.25;
}
.help-card p {
  color: rgba(255,255,255,.85);
  font-size: 14px;
  line-height: 1.6;
  margin: 0 0 22px;
  max-width: 320px;
}
.help-card .btn {
  align-self: center;
}

/* ===== Send Us A Message ===== */
.contact-form-section {
  padding: 40px 0 80px;
  text-align: center;
}
.contact-form-section h2 {
  font-size: 36px;
  color: var(--us-navy);
  font-weight: 600;
  margin: 0 0 10px;
  line-height: 1.2;
}
.contact-form-section .subtitle {
  font-size: 16px;
  color: var(--us-text-muted);
  margin: 0 0 28px;
}

.contact-form-card {
  background: var(--us-white);
  border-radius: 16px;
  box-shadow: 0 4px 30px rgba(0,0,0,.06);
  padding: 36px 40px;
  text-align: left;
}
.contact-form-card .required-note {
  font-size: 13px;
  color: var(--us-text-muted);
  margin: 0 0 20px;
}
.contact-form-card .required-note .req {
  color: #e02b1d;
  font-weight: 600;
}

.contact-form-card .checkbox-row {
  font-size: 12px;
  line-height: 1.5;
  color: var(--us-text-muted);
}

.contact-form-card .legal-row {
  text-align: center;
  margin: 18px 0 22px;
  font-size: 14px;
}
.contact-form-card .legal-row a {
  color: var(--us-orange);
  margin: 0 8px;
}
.contact-form-card .legal-row a:hover {
  color: var(--us-orange-hover);
}
.contact-form-card .submit-row {
  text-align: center;
}

/* ===== Responsive ===== */
@media (max-width: 760px) {
  .contact-title { padding: 80px 24px 28px; }
  .contact-title h1 { font-size: 36px; }
  .contact-meta { grid-template-columns: 1fr; gap: 28px; }
  .contact-help h2, .contact-form-section h2 { font-size: 28px; }
  .contact-help-grid { grid-template-columns: 1fr; }
  .help-card { padding: 32px 24px; }
  .contact-form-card { padding: 28px 22px; }
}
