/* ============================================
   FOURYR — Contact Page Styles
   ============================================ */

/* ── Contact Info Cards ─────────────────────── */
.contact-info-section {
  padding: var(--space-12) 0 0;
  background: var(--off-white);
}

.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.contact-info-grid--two {
  grid-template-columns: repeat(2, 1fr);
  max-width: 640px;
  margin: 0 auto;
}

.contact-info-card {
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--r-xl);
  padding: var(--space-7);
  text-align: center;
  transition: all var(--t-base) var(--ease);
}
.contact-info-card:hover {
  border-color: var(--blue-pale);
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.contact-info-card__icon {
  width: 52px; height: 52px;
  background: var(--blue-ghost);
  border-radius: var(--r-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  margin: 0 auto var(--space-4);
  transition: all var(--t-base) var(--ease);
}
.contact-info-card__icon svg { width: 24px; height: 24px; }
.contact-info-card:hover .contact-info-card__icon {
  background: var(--blue);
  color: var(--white);
}

.contact-info-card h3 {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: var(--space-1);
}

.contact-info-card p {
  font-size: 0.875rem;
  color: var(--gray-400);
  margin-bottom: var(--space-3);
}

.contact-info-card__link {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--blue);
  transition: color var(--t-fast) var(--ease);
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.contact-info-card__link:hover { color: var(--blue-mid); text-decoration: underline; }

/* ── Contact Form Section ───────────────────── */
.contact-form-section {
  padding: var(--space-16) 0 var(--space-20);
  background: var(--off-white);
}

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: var(--space-12);
  align-items: start;
}

/* Sidebar */
.contact-sidebar__title {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
}

.contact-sidebar__desc {
  font-size: 0.9375rem;
  color: var(--gray-500);
  line-height: 1.7;
  margin-bottom: var(--space-8);
  width: 100%;
}

.contact-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.contact-sidebar__list li {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.contact-sidebar__icon {
  width: 40px; height: 40px;
  background: var(--blue-ghost);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  flex-shrink: 0;
}
.contact-sidebar__icon svg { width: 18px; height: 18px; }

.contact-sidebar__list li strong {
  display: block;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 2px;
}
.contact-sidebar__list li p {
  font-size: 0.875rem;
  color: var(--gray-400);
}

.contact-sidebar__response {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--r-lg);
  font-size: 0.875rem;
  color: var(--gray-600);
}
.contact-sidebar__response svg { width: 18px; height: 18px; color: var(--blue); flex-shrink: 0; }
.contact-sidebar__response strong { color: var(--ink); }

/* Form card */
.contact-form-card {
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--r-2xl);
  padding: var(--space-10);
  box-shadow: var(--shadow-lg);
}

.form-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: 0.875rem;
  color: var(--gray-500);
  cursor: pointer;
  line-height: 1.5;
}
.form-check input[type="checkbox"] {
  width: 18px; height: 18px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gray-200);
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 1px;
  background: var(--white);
  transition: all var(--t-fast) var(--ease);
  position: relative;
}
.form-check input[type="checkbox"]:checked {
  background: var(--blue);
  border-color: var(--blue);
}
.form-check input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  left: 4px; top: 2px;
  width: 6px; height: 9px;
  border: 2px solid white;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}
.form-check a { color: var(--blue); font-weight: 600; }
.form-check a:hover { text-decoration: underline; }

.contact-form__submit {
  width: 100%;
  justify-content: center;
  margin-top: var(--space-6);
  position: relative;
}
.contact-form__submit .btn-arrow { transition: transform var(--t-base) var(--ease); }
.contact-form__submit:hover .btn-arrow { transform: translateX(4px); }
.contact-form__submit.loading .btn-text,
.contact-form__submit.loading .btn-arrow { display: none; }
.contact-form__submit.loading .spinner { display: block; }

/* ── Location Section ───────────────────────── */
.location-section {
  padding: 0 0 var(--space-20);
  background: var(--off-white);
}

.location-map-placeholder {
  width: 100%;
  min-height: 220px;
  background: linear-gradient(160deg, var(--ink) 0%, var(--navy) 100%);
  border-radius: var(--r-2xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding: var(--space-10) var(--space-12);
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(37,99,235,0.2);
}
.location-map-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.08) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

.location-map-placeholder__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
  position: relative;
  color: rgba(255,255,255,0.6);
}
.location-map-placeholder__content svg { width: 36px; height: 36px; color: var(--blue-light); }
.location-map-placeholder__content h3 { font-size: 1.125rem; color: var(--white); font-weight: 700; }
.location-map-placeholder__content p  { font-size: 0.9375rem; }

/* Divider between location and email */
.location-map-placeholder::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 20%;
  height: 60%;
  width: 1px;
  background: rgba(255,255,255,0.1);
  transform: translateX(-50%);
  pointer-events: none;
}

/* ── Location Email Card ─────────────────────── */
.location-email-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
  position: relative;
  z-index: 1;
  min-width: 0;
}

.location-email-card__icon {
  width: 44px;
  height: 44px;
  background: rgba(37,99,235,0.25);
  border: 1px solid rgba(37,99,235,0.4);
  border-radius: var(--r-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-light);
  flex-shrink: 0;
  margin-bottom: var(--space-1);
}
.location-email-card__icon svg { width: 20px; height: 20px; }

.location-email-card__label {
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

.location-email-card__address {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.02em;
  transition: color var(--t-fast) var(--ease);
  word-break: break-all;
}
.location-email-card__address:hover { color: var(--blue-light); }

.location-email-card__note {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.4);
}

.location-email-card__btn {
  margin-top: var(--space-1);
}
.location-email-card__btn svg {
  width: 14px;
  height: 14px;
}

/* ── Responsive ─────────────────────────────── */
@media (max-width: 1024px) {
  .contact-info-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-sidebar { max-width: 100%; }
  .location-map-placeholder { padding: var(--space-8); }
}

@media (max-width: 768px) {
  .contact-info-grid,
  .contact-info-grid--two { grid-template-columns: 1fr; }
  .contact-form-card { padding: var(--space-6); }
  .location-map-placeholder {
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-7) var(--space-6);
    gap: var(--space-8);
  }
  .location-map-placeholder::after { display: none; }
  .location-map-placeholder__content { align-items: flex-start; }
  .location-email-card__address { font-size: 1.0625rem; }
}
