/* =========================
   Contact Us Page Styles
========================= */
.contact-main {
  padding-top: var(--space-10);
  padding-bottom: var(--space-10);
}
.contact-title {
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-4);
  color: var(--color-primary);
}
.contact-intro {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-8);
  color: var(--color-gray-700);
}
.contact-section {
  margin-bottom: var(--space-12);
}
.contact-info .contact-details {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--font-size-md);
}
.contact-icon {
  display: inline-block;
  width: 1.25em;
  margin-right: var(--space-2);
  color: var(--color-primary);
  font-size: 1.3em;
}
.social-media {
  margin-top: var(--space-4);
}
.social-links {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-1);
  align-items: center;
}
.social-links img {
  width: 28px;
  height: 28px;
  filter: grayscale(0.2);
  transition: filter 0.2s;
}
.social-links a:hover img,
.social-links a:focus img {
  filter: grayscale(0) drop-shadow(0 2px 8px var(--color-primary-hover));
}
.support-hours {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  max-width: 440px;
}
.support-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--font-size-base);
}
.support-list li {
  margin-bottom: var(--space-2);
}
.live-chat-trigger {
  color: var(--color-success);
  font-weight: 600;
  text-decoration: underline;
}
.live-chat-trigger:hover, .live-chat-trigger:focus {
  color: var(--color-primary);
  text-decoration: none;
}
.faq-list details {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-3);
  border: 1px solid var(--color-gray-100);
  transition: box-shadow 0.15s;
  cursor: pointer;
}
.faq-list details[open] {
  box-shadow: var(--shadow-md);
}
.faq-list summary {
  font-size: var(--font-size-md);
  font-weight: 600;
  color: var(--color-primary);
  outline: none;
  cursor: pointer;
  margin-bottom: var(--space-2);
}
.faq-list details > div {
  color: var(--color-text);
  padding-top: var(--space-2);
}
 /* Contact Form Styles */
.contact-form-section {
  max-width: 640px;
}
.contact-form.card {
  padding: var(--space-6) var(--space-8);
  box-shadow: var(--shadow-lg);
  background: var(--color-surface);
}
.form-group {
  margin-bottom: var(--space-5);
}
.form-group label {
  font-weight: 600;
  display: block;
  margin-bottom: var(--space-2);
}
.form-group input,
.form-group textarea {
  width: 100%;
}
.form-checkbox {
  display: flex;
  align-items: flex-start;
}
.form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-right: var(--space-2);
  margin-top: 2px;
}
.form-checkbox label {
  font-weight: 400;
  margin: 0;
}
.form-feedback {
  display: block;
  margin-top: var(--space-3);
  min-height: 1.2em;
  font-size: var(--font-size-sm);
  color: var(--color-success);
}
.form-feedback.error {
  color: var(--color-danger);
}
.contact-map {
  max-width: 800px;
}
.map-responsive {
  overflow: hidden;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  aspect-ratio: 16/6;
  margin-bottom: var(--space-2);
}
.map-note {
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
  margin-top: 0;
}
.privacy-policy-link {
  text-align: center;
  color: var(--color-gray-500);
  margin-bottom: var(--space-2);
}
.privacy-policy-link a {
  color: var(--color-primary);
  font-weight: 600;
}
/* ============================
   Mobile Responsive Styles for Contact Page
============================ */
@media (max-width: 767px) {
  .contact-main {
    padding-top: var(--space-8);
    padding-bottom: var(--space-8);
  }
  
  .contact-title {
    font-size: 1.75rem;
    text-align: center;
  }
  
  .contact-intro {
    font-size: var(--font-size-base);
    text-align: center;
  }
  
  .contact-section {
    margin-bottom: var(--space-8);
  }
  
  /* Contact info mobile */
  .contact-map, 
  .contact-form-section, 
  .support-hours {
    max-width: 100%;
  }
  
  .support-hours {
    padding: var(--space-4);
  }
  
  /* Social links mobile */
  .social-links {
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .social-links img {
    width: 32px;
    height: 32px;
  }
  
  /* Form mobile */
  .contact-form.card {
    padding: var(--space-4);
  }
  
  .form-group {
    margin-bottom: var(--space-4);
  }
  
  /* FAQ mobile */
  .faq-list details {
    padding: var(--space-3) var(--space-4);
  }
  
  .faq-list summary {
    font-size: var(--font-size-base);
  }
  
  /* Map mobile */
  .map-responsive {
    aspect-ratio: 16/10;
  }
}

@media (max-width: 480px) {
  .contact-main {
    padding-top: var(--space-6);
    padding-bottom: var(--space-6);
  }
  
  .contact-title {
    font-size: 1.5rem;
  }
  
  .contact-intro {
    font-size: var(--font-size-sm);
  }
  
  .contact-form.card {
    padding: var(--space-3);
  }
  
  .support-hours {
    padding: var(--space-3);
  }
  
  .faq-list details {
    padding: var(--space-2) var(--space-3);
  }
  
  .map-responsive {
    aspect-ratio: 16/12;
  }
}
