/* ============================================================
   CONTACT.CSS — contact.html page styles
   ============================================================ */

/* ── Contact Grid ───────────────────────────────────────────── */
.contact__grid {
  display: grid; grid-template-columns: 1fr 1.3fr;
  gap: var(--space-16); align-items: start;
}

/* ── Contact Info ───────────────────────────────────────────── */
.contact__info-heading {
  font-family: var(--font-display); font-size: var(--text-2xl);
  font-weight: 500; margin-bottom: var(--space-4);
}
.contact__info-body {
  font-size: var(--text-base); color: var(--color-text-muted);
  line-height: 1.85; margin-bottom: var(--space-8);
}
.contact__channels { display: flex; flex-direction: column; gap: var(--space-4); margin-bottom: var(--space-8); }
.contact__channel {
  display: flex; gap: var(--space-4); padding: var(--space-5);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); transition: all var(--transition);
  text-decoration: none; color: inherit;
}
a.contact__channel:hover { border-color: var(--color-primary-border); transform: translateX(4px); }
.contact__channel-icon { font-size: 1.5rem; flex-shrink: 0; margin-top: 2px; }
.contact__channel-label {
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-faint); font-weight: 600; margin-bottom: 2px;
}
.contact__channel-val {
  font-size: var(--text-sm); font-weight: 600; color: var(--color-text);
  margin-bottom: 2px;
}
.contact__channel-note { font-size: var(--text-xs); color: var(--color-text-muted); }

.contact__trust {
  padding: var(--space-6); background: var(--color-primary-dim);
  border: 1px solid var(--color-primary-border); border-radius: var(--radius-xl);
}
.contact__trust-title {
  font-family: var(--font-display); font-size: var(--text-base);
  font-weight: 600; color: var(--color-primary); margin-bottom: var(--space-4);
}
.contact__trust-list {
  list-style: none; display: flex; flex-direction: column; gap: var(--space-2);
}
.contact__trust-list li {
  font-size: var(--text-sm); color: var(--color-text-muted); max-width: none;
}

/* ── Contact Form ───────────────────────────────────────────── */
.contact__form-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: clamp(var(--space-6), 4vw, var(--space-10));
  box-shadow: var(--shadow-md);
}
.contact__form-title {
  font-family: var(--font-display); font-size: var(--text-xl);
  font-weight: 600; margin-bottom: var(--space-2);
}
.contact__form-subtitle {
  font-size: var(--text-sm); color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-group { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
.form-group label {
  font-size: var(--text-xs); text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--color-text-muted); font-weight: 600;
}
.form-group input,
.form-group textarea,
.form-group select {
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); font-size: var(--text-sm);
  color: var(--color-text); transition: all var(--transition); width: 100%;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-dim);
}
.form-group textarea { resize: vertical; min-height: 110px; line-height: 1.6; }
.form-group select option { background: var(--color-surface); }
.form__submit {
  width: 100%; padding: var(--space-4);
  background: var(--color-primary); color: var(--color-text-inverse);
  border-radius: var(--radius-md); font-weight: 600;
  font-size: var(--text-base); transition: all var(--transition);
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  border: none; cursor: pointer;
}
.form__submit:hover { background: var(--color-primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.form__note { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-4); text-align: center; line-height: 1.5; }
.form__success {
  display: none; text-align: center; padding: var(--space-8);
  background: var(--color-primary-dim); border-radius: var(--radius-lg);
  border: 1px solid var(--color-primary-border); margin-bottom: var(--space-6);
}
.form__success.show { display: block; }
.form__success .checkmark { font-size: 2.5rem; display: block; margin-bottom: var(--space-3); }
.form__success h3 { font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-primary); margin-bottom: var(--space-2); }
.form__success p { font-size: var(--text-sm); color: var(--color-text-muted); max-width: none; }

/* ── FAQ ────────────────────────────────────────────────────── */
.faq__grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5);
}
.faq__item {
  padding: var(--space-6); background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: var(--radius-xl);
  transition: all var(--transition);
}
.faq__item:hover { border-color: var(--color-primary-border); }
.faq__q {
  font-family: var(--font-display); font-size: var(--text-lg);
  font-weight: 600; color: var(--color-text); margin-bottom: var(--space-3);
}
.faq__a { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.8; max-width: none; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  .contact__grid { grid-template-columns: 1fr; }
  .faq__grid { grid-template-columns: 1fr; }
}
@media (max-width: 540px) {
  .form-row { grid-template-columns: 1fr; }
}
