/* Marchenholm — forms.css : contact form + compare select form. */

.mh-form {
  max-width: 560px;
  display: flex;
  flex-direction: column;
  gap: var(--space-item);
}
.mh-form__row { display: flex; flex-direction: column; gap: 6px; }
.mh-form__row label {
  font-family: var(--f-mono);
  font-size: var(--f-label);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-accent);
}
.mh-form__row input[type="text"],
.mh-form__row input[type="email"],
.mh-form__row select,
.mh-form__row textarea {
  background: var(--c-paper);
  border: 1px solid var(--c-ink);
  border-radius: var(--r-sm);
  padding: 12px 14px;
  font-family: var(--f-body);
  font-size: var(--f-body);
  color: var(--c-ink);
  transition: border-color 0.15s;
}
.mh-form__row textarea { min-height: 160px; resize: vertical; font-family: var(--f-body); }
.mh-form__row input:focus,
.mh-form__row select:focus,
.mh-form__row textarea:focus { border-color: var(--c-accent); }

.mh-form__privacy {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: var(--f-body-s);
  color: var(--c-ink);
  line-height: 1.5;
}
.mh-form__privacy input[type="checkbox"] { margin-top: 4px; accent-color: var(--c-accent); }
.mh-form__privacy a { color: var(--c-accent); border-bottom: 1px solid transparent; }
.mh-form__privacy a:hover { border-bottom-color: var(--c-accent); }

.mh-form__submit-row { display: flex; justify-content: flex-start; }

.mh-form__status {
  font-family: var(--f-mono);
  font-size: var(--f-caption);
  padding: 12px 16px;
  border-radius: var(--r-sm);
  display: none;
}
.mh-form__status--error {
  display: block;
  background: rgba(232, 155, 26, 0.12);
  color: var(--c-secondary);
  border: 1px solid var(--c-secondary);
}
.mh-form__status--success {
  display: block;
  background: rgba(27, 142, 79, 0.12);
  color: var(--c-success);
  border: 1px solid var(--c-success);
}

/* Compare form (inline, horizontal) */
.mh-compare-form {
  display: flex;
  gap: var(--space-item);
  flex-wrap: wrap;
  align-items: flex-end;
  margin-bottom: var(--space-block);
}
.mh-compare-form__field { display: flex; flex-direction: column; gap: 6px; min-width: 220px; }
.mh-compare-form__field label {
  font-family: var(--f-mono);
  font-size: var(--f-label);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--c-accent);
}

/* Audit month selector */
.mh-audit-selector {
  margin-bottom: var(--space-block);
  display: flex;
  gap: var(--space-item);
  align-items: flex-end;
  flex-wrap: wrap;
}
.mh-audit-selector label {
  font-family: var(--f-mono);
  font-size: var(--f-label);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--c-accent);
  display: block;
  margin-bottom: 6px;
}

/* Contact page 2-col */
.mh-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-block);
}
.mh-contact-direct h3 {
  font-family: var(--f-mono);
  font-size: var(--f-label);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: 12px;
  margin-top: var(--space-item);
}
.mh-contact-direct dl { display: grid; grid-template-columns: 140px 1fr; gap: 8px 16px; margin-bottom: var(--space-item); }
.mh-contact-direct dt { font-family: var(--f-mono); font-size: var(--f-caption); color: var(--c-stone); }
.mh-contact-direct dd { font-family: var(--f-body); font-size: var(--f-body-s); color: var(--c-ink); }
.mh-contact-direct dd a { color: var(--c-accent); border-bottom: 1px solid transparent; }
.mh-contact-direct dd a:hover { border-bottom-color: var(--c-accent); }

/* Map (keyless Google Maps iframe, consent-gated) */
.mh-map {
  aspect-ratio: 16/9;
  background: var(--c-paper-alt);
  border: 1px solid var(--c-ink);
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
}
.mh-map iframe { width: 100%; height: 100%; border: 0; display: block; }
.mh-map__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
  padding: 24px;
  background: var(--c-paper-alt);
}
.mh-map__placeholder strong {
  font-family: var(--f-mono);
  font-size: var(--f-body);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--c-ink);
}
.mh-map__placeholder p { font-size: var(--f-body-s); color: var(--c-ink-muted); }

.mh-map--accepted .mh-map__placeholder { display: none; }

.mh-map-link { margin-top: 16px; display: inline-block; }
