/* ── Contact Page ─────────────────────────────────────────────────────────────── */

/* Two-column layout */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr var(--layout-sidebar-width);
  gap: var(--layout-sidebar-gap);
  align-items: start;
}

/* Left info panel */
.contact-info h2 { margin-bottom: var(--space-4); }
.contact-info > p { font-size: var(--text-md); color: var(--color-text-3); max-width: 460px; line-height: var(--leading-relaxed); margin-bottom: var(--space-10); }

.contact-channels {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-10);
}
.contact-channel {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  text-decoration: none;
  color: inherit;
  cursor: default;
  transition: border-color var(--ease-base), transform var(--ease-base);
}
.contact-channel:hover { border-color: var(--color-accent-muted); }
.contact-channel__icon {
  width: 40px; height: 40px;
  background: var(--color-accent-light);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-accent);
  font-size: var(--text-lg);
  flex-shrink: 0;
}
.contact-channel__label { font-size: var(--text-xs); font-weight: var(--weight-semi); letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-text-4); margin-bottom: var(--space-1); }
.contact-channel__value { font-size: var(--text-base); font-weight: var(--weight-semi); color: var(--color-text); }
.contact-channel__note  { font-size: var(--text-xs); color: var(--color-text-4); margin-top: 2px; }

/* Only slide transform on pointer devices */
@media (hover: hover) {
  .contact-channel:hover { transform: translateX(4px); }
}

/* Response promise */
.response-promise {
  padding: var(--space-6);
  background: var(--color-accent-light);
  border: 1px solid rgba(26,63,168,.15);
  border-radius: var(--radius-lg);
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}
.response-promise__icon { font-size: var(--text-xl); flex-shrink: 0; margin-top: 2px; }
.response-promise h5 { font-size: var(--text-sm); font-weight: var(--weight-semi); color: var(--color-accent); margin-bottom: var(--space-1); }
.response-promise p  { font-size: var(--text-sm); color: var(--color-text-3); margin: 0; line-height: var(--leading-relaxed); }

/* FAQ on contact page */
.contact-faq { padding-block: var(--space-20); background: var(--color-surface); border-top: 1px solid var(--color-border-soft); }
.faq-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  max-width: 960px;
}
.faq-item {
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}
.faq-item h5 { font-size: var(--text-base); font-weight: var(--weight-semi); color: var(--color-text); margin-bottom: var(--space-3); }
.faq-item p  { font-size: var(--text-sm); color: var(--color-text-3); line-height: var(--leading-relaxed); margin: 0; }

/* Form card */
.contact-form-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-10);
  box-shadow: var(--shadow-lg);
  position: sticky;
  top: calc(var(--nav-height) + var(--space-6));
}
.contact-form-card__header { margin-bottom: var(--space-8); }
.contact-form-card__header h3 { font-size: var(--text-xl); margin-bottom: var(--space-2); }
.contact-form-card__header p  { font-size: var(--text-sm); color: var(--color-text-3); margin: 0; }

@media (max-width: 1024px) {
  .contact-layout { grid-template-columns: 1fr; }
  .contact-form-card { position: static; }
  .faq-list { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .contact-form-card {
    padding: var(--space-6);
    border-radius: var(--radius-xl);
  }
  .contact-form-card__header { margin-bottom: var(--space-5); }
}

/* .booking-faq accordion styles live in components/utilities.css */

/* Contact page viz section spacing fix */
.contact-faq { padding-block: var(--space-16); background: var(--color-surface); border-top: 1px solid var(--color-border-soft); }

/* Numberd steps spacing fix */
.mt-10 { margin-top: var(--space-10); }

/* ── Sectors served tile grid ────────────────────────────────────────────────── */
.sectors-grid {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}

.sectors-grid__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.sectors-grid__title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  color: var(--color-text);
}
.sectors-grid__note {
  font-size: var(--text-xs);
  color: var(--color-text-4);
}

.sectors-grid__tiles {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.sector-tile {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px var(--space-3);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  color: var(--color-text-3);
  background: var(--color-bg-soft);
  white-space: nowrap;
  transition: border-color var(--ease-base), color var(--ease-base), background var(--ease-base);
  cursor: default;
  line-height: 1;
}
.sector-tile:hover {
  border-color: var(--color-accent-muted);
  color: var(--color-accent);
  background: var(--color-accent-light);
}

.sector-tile__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: .5;
  width: 13px;
  height: 13px;
}
.sector-tile:hover .sector-tile__icon { opacity: 1; }

.sectors-grid__footer {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-soft);
  font-size: var(--text-xs);
  color: var(--color-text-4);
  font-style: italic;
  margin-bottom: 0;
}
