/* ============================================================================
   COMPONENTS.CSS - BEM Component Styles
   ============================================================================
   All component-specific styles using BEM naming convention.
   Load order: After layout.css, before utilities.css
   ============================================================================ */

/* ==============================================
   CONTACT PAGE STYLES
   Mobile-first responsive design with BEM naming
   ============================================== */

/* Contact Page Container */
.contact {
  padding: var(--spacing-8) 0;
  background-color: var(--color-neutral-50);
}

.contact__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--spacing-4);
}

/* Headings */
.contact__heading {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-neutral-900);
  margin-bottom: var(--spacing-6);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.contact__intro {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-neutral-700);
  margin-bottom: var(--spacing-8);
  line-height: var(--line-height-relaxed);
}

.contact__form-heading,
.contact__info-heading {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-neutral-900);
  margin-bottom: var(--spacing-6);
}

/* Success/Error Messages */
.contact__success-message,
.contact__error-message {
  padding: var(--spacing-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-6);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
}

.contact__success-message {
  background-color: var(--color-success-main);
  color: var(--color-neutral-white);
}

.contact__error-message {
  background-color: var(--color-primary-500);
  color: var(--color-neutral-white);
}

/* Content Layout */
.contact__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
}

.contact__form-section {
  flex: 1;
}

.contact__info-section {
  flex: 1;
}

/* Form Structure */
.contact__form-group {
  margin-bottom: var(--spacing-6);
}

.contact__label {
  display: block;
  font-family: var(--font-body);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  color: var(--color-neutral-900);
  margin-bottom: var(--spacing-2);
}

/* Form Inputs */
.contact__input,
.contact__textarea {
  width: 100%;
  padding: var(--spacing-3);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-neutral-900);
  background-color: var(--color-neutral-100);
  border: var(--border-width-default) solid var(--color-neutral-300);
  border-radius: var(--radius-sm);
  min-height: 44px;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.contact__input:focus,
.contact__textarea:focus {
  outline: none;
  background-color: var(--color-neutral-white);
  border-color: var(--color-primary-500);
  box-shadow: 0 0 0 3px rgba(102, 22, 82, 0.1);
}

.contact__textarea {
  min-height: 150px;
  resize: vertical;
  line-height: var(--line-height-relaxed);
}

/* Validation Errors */
.contact__validation-error {
  display: block;
  color: var(--color-primary-500);
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-2);
  line-height: var(--line-height-normal);
}

/* Submit Button */
.contact__button {
  width: 100%;
  padding: var(--spacing-3) var(--spacing-6);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-white);
  background-color: var(--color-primary-500);
  border: none;
  border-radius: var(--radius-sm);
  min-height: 44px;
  cursor: pointer;
  transition: background-color 0.2s ease, opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.contact__button:hover:not(:disabled) {
  background-color: var(--color-primary-700);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(102, 22, 82, 0.3);
}

.contact__button:active:not(:disabled) {
  background-color: var(--color-primary-800);
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(102, 22, 82, 0.2);
}

.contact__button:disabled {
  background-color: var(--color-neutral-400);
  color: var(--color-neutral-600);
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Business Info Section */
.contact__info-item {
  margin-bottom: var(--spacing-4);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-neutral-700);
  line-height: var(--line-height-relaxed);
}

.contact__info-item strong {
  display: block;
  color: var(--color-neutral-900);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-1);
}

/* Contact Links */
.contact__link {
  color: var(--color-primary-500);
  text-decoration: none;
  transition: color 0.2s ease;
}

.contact__link:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
}

.contact__link:focus {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.contact__link:active {
  color: var(--color-primary-800);
}

/* ==============================================
   RESPONSIVE: TABLET (≥640px)
   ============================================== */
@media (min-width: 640px) {
  .contact__container {
    padding: 0 var(--spacing-6);
  }

  .contact__content {
    gap: var(--spacing-10);
  }

  .contact__heading {
    font-size: var(--font-size-4xl);
  }

  .contact__form-heading,
  .contact__info-heading {
    font-size: var(--font-size-2xl);
  }

  .contact__button {
    width: auto;
    min-width: 200px;
  }
}

/* ==============================================
   RESPONSIVE: DESKTOP (≥1024px)
   ============================================== */
@media (min-width: 1024px) {
  .contact__container {
    padding: 0 var(--spacing-8);
  }

  .contact__content {
    flex-direction: row;
    gap: var(--spacing-12);
    align-items: flex-start;
  }

  .contact__form-section {
    flex: 0 0 60%;
  }

  .contact__info-section {
    flex: 0 0 35%;
  }

  .contact__heading {
    font-size: var(--font-size-5xl);
  }

  .contact__form-heading,
  .contact__info-heading {
    font-size: var(--font-size-3xl);
  }

  .contact__button {
    min-width: 240px;
  }
}

/* ==============================================
   CONTACT PAGE - MAP SECTION
   ============================================== */

/* Map Section Container */
.contact__map-section {
  margin-top: var(--spacing-8);
  padding-top: var(--spacing-8);
  border-top: var(--border-width-default) solid var(--color-neutral-300);
}

.contact__map-heading {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-neutral-900);
  margin-bottom: var(--spacing-4);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.contact__map-description {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-neutral-700);
  margin-bottom: var(--spacing-6);
  line-height: var(--line-height-relaxed);
}

/* Map Container */
.contact__map-container {
  width: 100%;
  height: 300px;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  margin-bottom: var(--spacing-6);
}

.contact__map-container iframe {
  display: block;
  width: 100%;
  height: 100%;
}

/* Map Link */
.contact__map-link-wrapper {
  text-align: center;
  margin-bottom: var(--spacing-6);
}

.contact__map-link {
  color: var(--color-primary-500);
  text-decoration: none;
  font-family: var(--font-body);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  transition: color 0.2s ease;
}

.contact__map-link:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
}

.contact__map-link:focus {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.contact__map-link:active {
  color: var(--color-primary-800);
}

/* ==============================================
   RESPONSIVE: TABLET (≥640px) - MAP SECTION
   ============================================== */
@media (min-width: 640px) {
  .contact__map-container {
    height: 350px;
  }

  .contact__map-heading {
    font-size: var(--font-size-2xl);
  }
}

/* ==============================================
   RESPONSIVE: DESKTOP (≥1024px) - MAP SECTION
   ============================================== */
@media (min-width: 1024px) {
  .contact__map-container {
    height: 450px;
  }

  .contact__map-heading {
    font-size: var(--font-size-3xl);
  }

  .contact__map-section {
    padding-top: var(--spacing-10);
  }
}
