/* /contact PAGE — standalone Contact
   Decorative gold-band hero + 50/50 form & side panel + Google Maps embed.
   Matches REFERENCES/contact/index.html 1:1. */

/* ───────── HERO ───────── */
.contact-hero {
  text-align: center;
  margin: 48px auto 0;
  max-width: var(--max-w);
  padding: clamp(36px, 5vw, 72px) var(--gutter) clamp(28px, 4vw, 48px);
}

.contact-hero__band {
  display: flex;
  align-items: center;
  gap: 18px;
  justify-content: center;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.contact-hero__line {
  flex: 0 1 80px;
  height: 1px;
  background: var(--gold-line);
}

.contact-hero__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(32px, 4vw, 56px);
  color: var(--ivory);
  margin: 0;
  white-space: nowrap;
  line-height: 1.1;
}

.contact-hero__title em {
  background: var(--gold-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contact-hero__intro {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.55;
  color: var(--ivory-dim);
  margin: 14px auto 0;
  max-width: 640px;
}

/* ───────── FORM + SIDE PANEL (50/50) ───────── */
.contact-section {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: clamp(80px, 10vw, 140px) var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 7vw, 120px);
  align-items: start;
}

/* LEFT COLUMN — form */
.contact-form-col__head {
  margin-bottom: 36px;
}

.contact-form-col__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-mid);
  border-bottom: 1px solid var(--gold-faint);
  padding-bottom: 6px;
  margin-bottom: 18px;
}

.contact-form-col__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  color: var(--ivory);
  margin: 0;
  font-weight: 400;
}

.contact-form-col__title em {
  background: var(--gold-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contact-form-col__sub {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--ivory-dim);
  margin: 18px 0 0;
  max-width: 460px;
}

/* form fields */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-form__label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ivory-dim);
}

.contact-form__input,
.contact-form__select,
.contact-form__textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--gold-faint);
  padding: 10px 0;
  color: var(--ivory);
  font-family: var(--font-body);
  font-size: 16px;
  outline: none;
  transition: border-color 0.3s var(--ease-soft);
  width: 100%;
}

.contact-form__textarea {
  resize: vertical;
  min-height: 96px;
  font-family: var(--font-body);
}

.contact-form__select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--gold-mid) 50%),
    linear-gradient(135deg, var(--gold-mid) 50%, transparent 50%);
  background-position: calc(100% - 16px) 50%, calc(100% - 11px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px;
  cursor: pointer;
}

.contact-form__select option { background: var(--bg-primary); color: var(--ivory); }

.contact-form__input:focus,
.contact-form__select:focus,
.contact-form__textarea:focus {
  border-color: var(--gold-primary);
}

/* error state */
.contact-form__field--error .contact-form__input,
.contact-form__field--error .contact-form__select,
.contact-form__field--error .contact-form__textarea {
  border-color: #d65a4f;
}

.contact-form__error {
  font-family: var(--font-body);
  font-size: 11px;
  color: #d65a4f;
  letter-spacing: 0.04em;
  display: none;
}
.contact-form__field--error .contact-form__error { display: block; }

/* submit */
.contact-form__submit {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 30px;
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bg-primary);
  background: var(--gold-primary);
  border: 1px solid var(--gold-primary);
  border-radius: 999px;
  cursor: pointer;
  transition:
    background 0.3s var(--ease-soft),
    color 0.3s var(--ease-soft),
    transform 0.3s var(--ease-soft);
  margin-top: 8px;
}

.contact-form__submit:hover:not(:disabled) {
  background: transparent;
  color: var(--ivory);
  transform: translateY(-1px);
}

.contact-form__submit:disabled { opacity: 0.6; cursor: progress; }

.contact-form__submit span {
  display: inline-block;
  transition: transform 0.3s var(--ease-soft);
}
.contact-form__submit:hover:not(:disabled) span { transform: translateX(4px); }

.contact-form__footnote {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--ivory-dim);
  margin: 4px 0 0;
}

/* success / failure states */
.contact-form__success,
.contact-form__failure {
  display: none;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(20px, 2.4vw, 28px);
  color: var(--ivory);
  padding: 36px 0;
  border-top: 1px solid var(--gold-faint);
  border-bottom: 1px solid var(--gold-faint);
}

.contact-form.is-success .contact-form__success { display: block; }
.contact-form.is-success > *:not(.contact-form__success) { display: none; }
.contact-form.is-failed .contact-form__failure {
  display: flex;
  gap: 18px;
  align-items: center;
  flex-wrap: wrap;
}

.contact-form__failure-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  background: var(--gold-primary);
  color: var(--bg-primary);
  border: 1px solid var(--gold-primary);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

/* RIGHT COLUMN — side panel */
.contact-side {
  background: var(--bg-warm);
  border: 1px solid var(--gold-faint);
  padding: clamp(36px, 4vw, 56px);
  display: flex;
  flex-direction: column;
  gap: 28px;
  align-self: start;
}

.contact-side__heading {
  align-self: flex-start;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-mid);
  border-bottom: 1px solid var(--gold-faint);
  padding-bottom: 6px;
}

.contact-side__name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(22px, 2vw, 28px);
  color: var(--ivory);
  line-height: 1.2;
  margin: 0;
  font-weight: 400;
}

.contact-side__name em {
  background: var(--gold-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contact-side__address {
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 1.55;
  color: var(--ivory);
  margin: 0;
}

.contact-side__row {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contact-side__row a {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--ivory);
  text-decoration: none;
  transition: color 0.3s var(--ease-soft);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.contact-side__row a:hover { color: var(--gold-primary); }

.contact-side__icon {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--gold-faint);
  flex: 0 0 auto;
  transition: background 0.3s var(--ease-soft);
}
.contact-side__row a:hover .contact-side__icon { background: var(--gold-primary); }

.contact-side__whatsapp {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bg-primary);
  background: var(--gold-primary);
  border: 1px solid var(--gold-primary);
  border-radius: 999px;
  width: max-content;
  transition: all 0.3s var(--ease-soft);
  margin-top: 4px;
  text-decoration: none;
}

.contact-side__whatsapp:hover {
  background: transparent;
  color: var(--ivory);
}

.contact-side__whatsapp span { display: inline-block; transition: transform 0.3s var(--ease-soft); }
.contact-side__whatsapp:hover span { transform: translateX(4px); }

.contact-side__hours {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--ivory-dim);
  line-height: 1.6;
  border-top: 1px solid var(--gold-faint);
  padding-top: 18px;
}

.contact-side__social {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  border-top: 1px solid var(--gold-faint);
  padding-top: 18px;
}

.contact-side__social-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ivory);
  border: 1px solid var(--gold-faint);
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.3s var(--ease-soft);
}

.contact-side__social-btn:hover {
  color: var(--gold-primary);
  border-color: var(--gold-line);
}

.contact-side__social-count {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--gold-primary);
}

/* ───────── MAP SECTION ───────── */
.map-section {
  margin: 0 auto;
  max-width: var(--max-w);
  padding: 0 var(--gutter) clamp(80px, 10vw, 140px);
}

.map-section__head {
  margin-bottom: 28px;
  text-align: center;
}

.map-section__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-mid);
  border-bottom: 1px solid var(--gold-faint);
  padding-bottom: 6px;
  margin-bottom: 14px;
}

.map-section__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 2.4vw, 32px);
  color: var(--ivory);
  margin: 0;
  line-height: 1.2;
}

.map-section__title em {
  background: var(--gold-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.map-section__sub {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ivory-dim);
  margin: 12px 0 0;
}

.map-frame {
  aspect-ratio: 21 / 9;
  border: 1px solid var(--gold-line);
  overflow: hidden;
  position: relative;
  background: var(--bg-hero);
}

.map-frame iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  /* Slight grayscale + brightness reduction so the map blends with the dark theme */
  filter: grayscale(0.4) brightness(0.85) contrast(1.05);
  transition: filter 0.4s var(--ease-soft);
}

.map-frame:hover iframe {
  filter: grayscale(0) brightness(1) contrast(1);
}

/* ───────── RESPONSIVE ───────── */
@media (max-width: 880px) {
  .contact-section {
    grid-template-columns: 1fr;
    gap: 56px;
    padding: 64px var(--gutter);
  }

  .contact-hero__band { flex-direction: column; gap: 8px; }
  .contact-hero__line { width: 60px; flex: 0 0 auto; }

  .map-frame { aspect-ratio: 4 / 3; }

  .contact-form__submit {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 560px) {
  .contact-side {
    padding: 28px;
  }

  .contact-side__social {
    flex-direction: column;
  }

  .contact-side__social-btn {
    justify-content: center;
  }
}
