/* ============================================================
   DevCo · Contact page
   ------------------------------------------------------------
   A dedicated, multi-page Contact page (slug `contact`), built
   as native Elementor content on the editorial design system.

   Four bands:
     01  Intro      — dark. eyebrow, headline, lead line.
     02  Booking    — light. "Book a call" + a GHL calendar
                      embed slot (placeholder HTML widget until
                      the real GHL calendar embed code arrives).
     03  Enquiry    — dark. the custom enquiry form (shortcode
                      [devco_contact_form] from inc/contact-form.php).
     04  Details    — light. DevCo contact details + the
                      "Part of the HALCO Network" line.

   This stylesheet styles BOTH the raw form markup AND the
   Elementor container/widget structure. Every rule is scoped
   to .devco-site so it never touches wp-admin or other themes.
   Hard edges: zero border-radius, zero box-shadow. One warm
   accent (--rust), used sparingly.
   ============================================================ */

/* ------------------------------------------------------------
   0. Page shell — the Contact page is a stack of dc-section
      bands; each band carries a #contact-* id + ground class.
   ------------------------------------------------------------ */
.devco-site .contact-page .e-con { width: 100%; }

/* ============================================================
   01 — INTRO BAND  (#contact-intro, dark)
   ============================================================ */
.devco-site #contact-intro .contact-intro__shell.e-con {
  display: flex;
  flex-direction: column;
}
.devco-site #contact-intro .dc-eyebrow.e-con {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.devco-site #contact-intro .dc-eyebrow__rule { flex: none; }
.devco-site #contact-intro .dc-eyebrow__idx > span,
.devco-site #contact-intro .dc-eyebrow__label > span,
.devco-site #contact-intro .dc-eyebrow__rule > span { display: inline; }

.devco-site #contact-intro .contact-intro__headline .elementor-heading-title {
  font: inherit;
  margin: clamp(28px, 4vh, 44px) 0 0;
  font-size: clamp(2.6rem, 1.4rem + 4.6vw, 5.6rem);
  line-height: .98;
  letter-spacing: -.024em;
  color: inherit;
  max-width: 16ch;
}
.devco-site #contact-intro .contact-intro__headline em { font-style: italic; }

.devco-site #contact-intro .contact-intro__lead p {
  margin: clamp(22px, 3vh, 34px) 0 0;
  max-width: 52ch;
  font-family: var(--font-sans);
  font-size: var(--fs-lead);
  line-height: 1.62;
  color: inherit;
}

/* intro meta row — a hairline-ruled spec line, survey-document feel */
.devco-site #contact-intro .contact-intro__meta.e-con {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(16px, 3vw, 40px);
  margin-top: clamp(40px, 6vh, 72px);
  padding-top: 20px;
  border-top: var(--hair) solid var(--bone-hair);
}
.devco-site #contact-intro .contact-intro__meta span { display: inline; }
.devco-site #contact-intro .contact-intro__meta .dot { color: var(--accent); }

/* ============================================================
   02 — BOOKING BAND  (#contact-booking, light)
   "Book a call" — a slot for the GHL calendar embed.
   ============================================================ */
.devco-site #contact-booking .contact-booking__shell.e-con {
  display: flex;
  flex-direction: column;
}

/* heading row — label + headline + supporting line */
.devco-site #contact-booking .contact-booking__head.e-con {
  display: flex;
  flex-direction: column;
}
.devco-site #contact-booking .dc-eyebrow.e-con {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.devco-site #contact-booking .dc-eyebrow__rule { flex: none; }
.devco-site #contact-booking .dc-eyebrow__idx > span,
.devco-site #contact-booking .dc-eyebrow__label > span,
.devco-site #contact-booking .dc-eyebrow__rule > span { display: inline; }

.devco-site #contact-booking .contact-booking__headline .elementor-heading-title {
  font: inherit;
  margin: clamp(22px, 3vh, 34px) 0 0;
  font-size: clamp(2rem, 1.3rem + 2.8vw, 3.6rem);
  line-height: 1.04;
  letter-spacing: -.02em;
  color: inherit;
}
.devco-site #contact-booking .contact-booking__headline em { font-style: italic; }

.devco-site #contact-booking .contact-booking__lead p {
  margin: clamp(16px, 2.4vh, 24px) 0 0;
  max-width: 56ch;
  font-family: var(--font-sans);
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: inherit;
}

/* — the calendar embed slot — */
.devco-site #contact-booking .contact-booking__embed.e-con {
  margin-top: clamp(40px, 6vh, 72px);
}
/* the HTML widget container holding the embed/placeholder */
.devco-site #contact-booking .contact-booking__embed .elementor-widget-container {
  width: 100%;
}

/* the calendar frame — sized for a GHL calendar iframe (~700px tall) */
.contact-cal {
  position: relative;
  width: 100%;
  min-height: 700px;
  border: var(--hair) solid var(--ink-hair);
  background: var(--paper);
}
/* survey-document corner ticks on the frame */
.contact-cal::before,
.contact-cal::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border: 0 solid var(--ink-faint);
  pointer-events: none;
  z-index: 3;
}
.contact-cal::before {
  top: 10px; left: 10px;
  border-top-width: var(--hair);
  border-left-width: var(--hair);
}
.contact-cal::after {
  bottom: 10px; right: 10px;
  border-bottom-width: var(--hair);
  border-right-width: var(--hair);
}
/* the code label, top-left */
.contact-cal__code {
  position: absolute;
  top: 16px;
  left: 22px;
  z-index: 3;
  font-family: var(--font-mono);
  font-size: var(--fs-mono-sm);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
/* when the real GHL iframe is dropped in, it fills the frame */
.contact-cal iframe {
  display: block;
  width: 100%;
  min-height: 700px;
  border: 0;
}

/* — placeholder state — shown until the real embed code is added — */
.contact-cal__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 18px;
  padding: clamp(32px, 6vw, 72px);
}
/* faint plotted grid behind the placeholder — survey-document texture */
.contact-cal__placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--ink-hair) var(--hair), transparent var(--hair)),
    linear-gradient(90deg, var(--ink-hair) var(--hair), transparent var(--hair));
  background-size: 48px 48px;
  opacity: .5;
  pointer-events: none;
}
.contact-cal__placeholder-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  max-width: 44ch;
}
.contact-cal__placeholder-tag {
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--accent);
}
.contact-cal__placeholder-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2.2rem);
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--ink);
}
.contact-cal__placeholder-note {
  font-family: var(--font-sans);
  font-size: var(--fs-body-sm);
  line-height: 1.7;
  color: var(--ink-soft);
}
.contact-cal__placeholder-spec {
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: var(--fs-mono-sm);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* ============================================================
   03 — ENQUIRY BAND  (#contact-enquiry, dark)
   The custom on-brand enquiry form.
   ============================================================ */
.devco-site #contact-enquiry .contact-enquiry__shell.e-con {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}

/* left rail — eyebrow, headline, supporting copy */
.devco-site #contact-enquiry .contact-enquiry__intro.e-con {
  display: flex;
  flex-direction: column;
}
.devco-site #contact-enquiry .dc-eyebrow.e-con {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.devco-site #contact-enquiry .dc-eyebrow__rule { flex: none; }
.devco-site #contact-enquiry .dc-eyebrow__idx > span,
.devco-site #contact-enquiry .dc-eyebrow__label > span,
.devco-site #contact-enquiry .dc-eyebrow__rule > span { display: inline; }

.devco-site #contact-enquiry .contact-enquiry__headline .elementor-heading-title {
  font: inherit;
  margin: clamp(22px, 3vh, 34px) 0 0;
  font-size: clamp(2rem, 1.3rem + 2.8vw, 3.6rem);
  line-height: 1.04;
  letter-spacing: -.02em;
  color: inherit;
}
.devco-site #contact-enquiry .contact-enquiry__headline em { font-style: italic; }

.devco-site #contact-enquiry .contact-enquiry__lead p {
  margin: clamp(16px, 2.4vh, 24px) 0 0;
  max-width: 38ch;
  font-family: var(--font-sans);
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: inherit;
}

.devco-site #contact-enquiry .contact-enquiry__aside p {
  margin: clamp(28px, 4vh, 44px) 0 0;
  max-width: 36ch;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.15rem, 1rem + .6vw, 1.45rem);
  line-height: 1.4;
  color: var(--bone-soft);
}

/* right column — the form (Shortcode widget) */
.devco-site #contact-enquiry .contact-enquiry__form-col.e-con {
  display: block;
}
.devco-site #contact-enquiry .contact__form-shortcode .elementor-shortcode {
  display: block;
}

/* — the form itself — */
.contact__form-wrap {
  border: var(--hair) solid var(--bone-hair);
  padding: clamp(26px, 3.4vw, 48px);
}
.contact__form {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2.6vh, 24px);
}
/* two-up row for name + phone */
.contact__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 2vw, 22px);
}
.contact__field {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact__label {
  color: var(--bone-faint);
}

/* inputs, select, textarea — shared editorial treatment */
.contact__input {
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  color: var(--bone);
  background: transparent;
  border: var(--hair) solid var(--bone-hair);
  border-radius: 0;
  padding: 15px 17px;
  transition: border-color .32s var(--ease), background .32s var(--ease);
}
.contact__input::placeholder { color: var(--bone-faint); }
.contact__input:hover { border-color: var(--bone-soft); }
.contact__input:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(237, 230, 214, .03);
}
.contact__input:focus-visible {
  outline: var(--hair) solid var(--accent);
  outline-offset: 3px;
}
.contact__input.is-invalid { border-color: var(--accent); }

.contact__textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.6;
}

/* select — strip native chrome, draw our own caret */
.contact__select-wrap {
  position: relative;
}
.contact__select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 44px;
  cursor: pointer;
}
.contact__select:invalid { color: var(--bone-faint); }
.contact__select option {
  color: var(--ink);
  background: var(--bone);
}
.contact__select-caret {
  position: absolute;
  right: 18px;
  top: 50%;
  width: 8px;
  height: 8px;
  margin-top: -6px;
  border-right: var(--hair) solid var(--bone-soft);
  border-bottom: var(--hair) solid var(--bone-soft);
  transform: rotate(45deg);
  pointer-events: none;
}

/* submit row */
.contact__submit-row {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.contact__submit { cursor: pointer; }
.contact__submit[aria-busy="true"] { opacity: .6; pointer-events: none; }
.contact__micro { flex: none; }

/* inline status message (error) */
.contact__status {
  margin-top: 16px;
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  line-height: 1.6;
}
.contact__status:empty { display: none; }
.contact__status.is-error { color: var(--accent); }

/* thank-you state — replaces the form on success */
.contact__thanks {
  border: var(--hair) solid var(--bone-hair);
  padding: clamp(32px, 4vw, 56px);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.contact__thanks-mark {
  width: 46px;
  height: 46px;
  flex: none;
  border: var(--hair) solid var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 18px;
  line-height: 1;
}
.contact__thanks-heading {
  margin: 4px 0 0;
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--bone-faint);
}
.contact__thanks-text {
  margin: 0;
  max-width: 34ch;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.2rem, 1.05rem + .6vw, 1.55rem);
  line-height: 1.4;
  color: var(--bone);
}

/* ============================================================
   04 — DETAILS BAND  (#contact-details, light)
   DevCo contact details + the HALCO Network line.
   ============================================================ */
.devco-site #contact-details .contact-details__shell.e-con {
  display: flex;
  flex-direction: column;
}

.devco-site #contact-details .dc-eyebrow.e-con {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.devco-site #contact-details .dc-eyebrow__rule { flex: none; }
.devco-site #contact-details .dc-eyebrow__idx > span,
.devco-site #contact-details .dc-eyebrow__label > span,
.devco-site #contact-details .dc-eyebrow__rule > span { display: inline; }

.devco-site #contact-details .contact-details__headline .elementor-heading-title {
  font: inherit;
  margin: clamp(22px, 3vh, 34px) 0 clamp(40px, 6vh, 64px);
  font-size: clamp(2rem, 1.3rem + 2.8vw, 3.6rem);
  line-height: 1.04;
  letter-spacing: -.02em;
  color: inherit;
}
.devco-site #contact-details .contact-details__headline em { font-style: italic; }

/* the detail grid — hairline-ruled cells, survey-document layout */
.devco-site #contact-details .contact-details__grid.e-con {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: var(--hair) solid var(--ink-hair);
  border-left: var(--hair) solid var(--ink-hair);
}
.devco-site #contact-details .contact-details__cell.e-con {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: clamp(26px, 3vw, 40px);
  border-right: var(--hair) solid var(--ink-hair);
  border-bottom: var(--hair) solid var(--ink-hair);
}
.devco-site #contact-details .contact-details__cell-label span {
  display: inline;
  color: var(--ink-faint);
}
.devco-site #contact-details .contact-details__cell-value p,
.devco-site #contact-details .contact-details__cell-value {
  margin: 0;
}
.devco-site #contact-details .contact-details__cell-value p {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1.05rem + .8vw, 1.65rem);
  line-height: 1.3;
  letter-spacing: -.012em;
  color: var(--ink);
}
.devco-site #contact-details .contact-details__cell-value a {
  color: var(--ink);
  border-bottom: var(--hair) solid var(--ink-hair);
  transition: border-color .3s var(--ease);
}
.devco-site #contact-details .contact-details__cell-value a:hover {
  border-color: var(--accent);
}
.devco-site #contact-details .contact-details__cell-note p {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body-sm);
  line-height: 1.6;
  color: var(--ink-soft);
}

/* — the HALCO Network line — a closing hairline-ruled statement — */
.devco-site #contact-details .contact-details__network.e-con {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  flex-wrap: wrap;
  gap: clamp(12px, 2vw, 24px);
  margin-top: clamp(48px, 7vh, 88px);
  padding-top: clamp(28px, 4vh, 44px);
  border-top: var(--hair) solid var(--ink-hair);
}
.devco-site #contact-details .contact-details__network-mark span {
  display: inline;
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.devco-site #contact-details .contact-details__network-text span {
  display: inline;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.25rem, 1rem + 1vw, 1.85rem);
  line-height: 1.32;
  color: var(--ink-soft);
}
.devco-site #contact-details .contact-details__network-text em {
  font-style: italic;
  color: var(--ink);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 920px) {
  .devco-site #contact-enquiry .contact-enquiry__shell.e-con {
    grid-template-columns: 1fr;
    gap: clamp(36px, 6vh, 56px);
  }
  .devco-site #contact-enquiry .contact-enquiry__lead p,
  .devco-site #contact-enquiry .contact-enquiry__aside p {
    max-width: 52ch;
  }
  .devco-site #contact-details .contact-details__grid.e-con {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .contact__row {
    grid-template-columns: 1fr;
  }
  .contact__submit-row {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }
  .contact__submit { justify-content: center; }
  .contact__micro { text-align: center; }
  .devco-site #contact-details .contact-details__grid.e-con {
    grid-template-columns: 1fr;
  }
  .contact-cal,
  .contact-cal iframe { min-height: 620px; }
}

@media (prefers-reduced-motion: reduce) {
  .contact__input,
  .devco-site #contact-details .contact-details__cell-value a {
    transition: none;
  }
}
