/* =========================
   CONTACTS PAGE (BEM)
   File: /assets/css/contacts.css
   Notes:
   - Loaded only on /contacts/
   - Low specificity by design (no .page-contacts prefix)
========================= */

/* =========================
   Page head
========================= */
.contacts-head {
  padding: var(--space-48) 0 var(--space-24);
}

.contacts-head__title {
  margin: 0;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: var(--lh-title);
  letter-spacing: -0.03em;
  color: var(--color-text);
}

.contacts-head__text {
  margin: var(--space-12) 0 0;
  max-width: 70ch;
  color: var(--color-muted);
  line-height: var(--lh-text);
}

/* =========================
   Contacts + form layout
========================= */
.contacts {
  padding: var(--space-24) 0 var(--space-48);
}

.contacts__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-32);
  align-items: start;
}

/* Left column */
.contacts__info {
  display: grid;
  gap: var(--space-16);
  min-width: 0;
}

/* Right column */
.contacts__form {
  width: 100%;
  min-width: 0;
}

/* IMPORTANT:
   On this page the form wrapper class is ".contacts-form"
   and inside you include markup that uses ".contact-form__*"
   from app.css. We make it stretch and not “cap” width. */
.contacts-form,
.contacts__form .contact-form__form,
.contacts__form .contact-form__head {
  width: 100%;
  max-width: none;
}

/* Keep fields fluid inside the right column */
.contacts__form .field,
.contacts__form .field__control,
.contacts__form .field__control--textarea {
  width: 100%;
  max-width: none;
}

/* Slight page-specific tone */
.contacts__form .contact-form__note {
  margin: var(--space-16) 0 0;
  color: var(--color-muted);
  font-size: var(--text-sm);
  line-height: 1.5;
}

/* If your request-page.php contains a 2-column grid for fields,
   make it always 1 column on contacts page (safe & predictable). */
.contacts__form .contact-form__form .contact-form__grid,
.contacts__form .contact-form__form .form-grid {
  grid-template-columns: 1fr;
}

/* =========================
   Contact cards
========================= */
.contact-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-20);
  box-shadow: var(--shadow-sm);
  min-width: 0;
}

.contact-card--primary {
  background: var(--color-surface-muted);
  border-color: var(--color-border-accent);
}

.contact-card__title {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.contact-card__rows {
  margin-top: var(--space-16);
  display: grid;
  gap: var(--space-12);
}

.contact-card__row {
  display: grid;
  gap: var(--space-4);
}

.contact-card__label {
  font-size: var(--text-sm);
  color: var(--color-muted);
}

.contact-card__value {
  font-size: var(--text-md);
  color: var(--color-text);

  /* Prevent long addresses/emails from forcing horizontal scroll */
  overflow-wrap: anywhere;
  word-break: break-word;
}

.contact-card__value--muted {
  color: var(--color-muted);
}

/* Link polish (mail/site) */
.contact-card__value a,
.contact-card__value[href] {
  color: inherit;
  text-decoration: none;
}

.contact-card__value a:hover,
.contact-card__value a:focus-visible,
.contact-card__value[href]:hover,
.contact-card__value[href]:focus-visible {
  outline: none;
  color: var(--color-link-hover);
  text-decoration: underline;
}

/* Note divider */
.contact-card__note {
  margin-top: var(--space-16);
  padding-top: var(--space-16);
  border-top: 1px solid var(--color-border);
  color: var(--color-muted);
  line-height: var(--lh-text);
}

/* Make <address> not italic */
.contact-card address {
  font-style: normal;
}

/* Optional: make phone clickable without changing HTML
   (only if you later turn phone into <a href="tel:...">) */
.contact-card__value[href^="tel:"] {
  white-space: nowrap;
}

/* =========================
   Maps
========================= */
.maps {
  padding: var(--space-48) 0;
  background: var(--color-surface-muted);
  border-top: 1px solid var(--color-border);
}

.maps__head {
  margin-bottom: var(--space-24);
}

.maps__title {
  margin: 0;
  font-size: var(--text-xl);
  line-height: var(--lh-title);
  letter-spacing: -0.02em;
  color: var(--color-text);
}

.maps__text {
  margin: var(--space-12) 0 0;
  max-width: 80ch;
  color: var(--color-muted);
  line-height: var(--lh-text);
}

/* Map card */
.map-card--full {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

/* The constructor script injects a block with inline height.
   We make the wrapper stable and responsive. */
.map-card__frame {
  padding: var(--space-16);
  width: 100%;
  display: block;
  min-height: 360px;
  overflow: hidden;
}

/* Make injected map take full width and not overflow */
.map-card__frame > * {
  max-width: 100%;
}

/* Actions row */
.map-card__actions {
  padding: 0 var(--space-16) var(--space-16);
  display: flex;
  gap: var(--space-12);
  flex-wrap: wrap;
}

/* If you don’t have button--secondary in app.css,
   this keeps it looking like a “surface” button. */
.button--secondary {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.button--secondary:hover {
  border-color: var(--color-border-accent-strong);
  transform: translateY(-1px);
}

.button--secondary:active {
  transform: translateY(0);
}

.button--secondary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--color-accent-soft);
}

/* =========================
   Responsive
========================= */
@media (max-width: 980px) {
  .contacts-head {
    padding: var(--space-40) 0 var(--space-20);
  }

  .contacts__layout {
    grid-template-columns: 1fr;
    gap: var(--space-24);
  }

  /* Put contact cards first, form second (natural DOM already does this) */
  .contacts {
    padding: var(--space-20) 0 var(--space-48);
  }
}

@media (max-width: 680px) {
  .contacts-head {
    padding: var(--space-32) 0 var(--space-16);
  }

  .contacts-head__text {
    max-width: 62ch;
  }

  .contact-card {
    padding: var(--space-16);
  }

  .maps {
    padding: var(--space-40) 0;
  }

  .map-card__frame {
    min-height: 300px;
    padding: var(--space-12);
  }

  .map-card__actions {
    padding: 0 var(--space-12) var(--space-12);
  }

  .map-card__actions .button {
    width: 100%;
  }
}

@media (max-width: 420px) {
  .contacts__layout {
    gap: var(--space-16);
  }

  .map-card__frame {
    min-height: 260px;
  }
}
