/* ==========================================================================
   Contact-Form Pattern — wiederverwendbares Form-Layout — funktionaler Layer.
   Grid-Mechanik (Section-Layout 2-col + responsive Stack), Form-Field-Mechanik
   (Select-Reset mit SVG-Arrow, Focus-Reset, Checkbox-Layout), Status-Block-
   Display-Toggle (display:none/block), Hint-Flex-Layout.
   Wird genutzt von r2go4-contact-Section, contact-drawer, egp-brochure,
   kaeuferfinder, mieterfinder.
   ========================================================================== */

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 60%) minmax(0, 1fr);
  align-items: start;
}

@media (max-width: 1023px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
}

.contact-info > * {
  margin: 0;
}

.contact-info__logo img {
  height: auto;
}

address,
.contact-info__address {
  font-style: normal;
}

.contact-info__details p {
  margin: 0;
}

.contact-info__social {
  display: flex;
}

.contact-info__social a {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: color var(--transition);
}

.contact-form {
  display: flex;
  flex-direction: column;
}

.contact-form > * {
  margin: 0;
}

.contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.contact-form .form-row--thirds {
  grid-template-columns: 1fr 1fr 1fr;
}

.form-field {
  margin: 0;
}

@media (max-width: 768px) {
  .contact-form .form-row,
  .contact-form .form-row--thirds {
    grid-template-columns: 1fr;
  }
  .contact-form > *:last-child,
  .contact-form .form-row .form-field:last-child {
    margin-bottom: 0;
  }
}

.form-field select,
.form-field input,
.form-field textarea {
  width: 100%;
  transition: border-color var(--transition);
}

.form-field select {
  appearance: none;
  -webkit-appearance: none;
  /* Einheitlicher Chevron-Pfeil wie im Immobilienfilter (Objektart). */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.875rem center;
  padding-right: 2.25rem;
  cursor: pointer;
}

.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
  outline: none;
}

.form-field--checkbox {
  display: flex;
  align-items: flex-start;
}

.form-field--checkbox label {
  display: flex;
  align-items: flex-start;
  cursor: pointer;
}

.form-field--checkbox input[type="checkbox"] {
  width: auto;
  flex-shrink: 0;
}

.contact-form .btn {
  margin-left: auto;
  display: flex;
}

.contact-form__hint {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.contact-form__hint-left {
  display: flex;
  align-items: flex-start;
}

.contact-form__hint-left svg {
  flex-shrink: 0;
}

.contact-form__hint-right {
  flex-shrink: 0;
  white-space: nowrap;
}

.contact-form__status {
  display: none;
}

.contact-form__status--success,
.contact-form__status--error {
  display: block;
}

.contact-form__download-link {
  display: inline-block;
}
/* ==========================================================================
   Contact-Form Pattern — r2go4 visueller Layer.
   Drift bereinigt:
     - #ccc → --color-border (1:1)
     - #fff → --color-white (1:1)
     - #e8f5e9 → --color-success-bg (Material-Green-50 → unser Pastell)
     - #2e7d32 → --color-success (1:1)
     - #a5d6a7 → --color-success-border (NEU)
     - #fce4ec → --color-danger-bg (Material-Pink-50 → unser Pastell)
     - #c62828 → --color-danger (1:1)
     - #ef9a9a → --color-danger-border (NEU)
     - var(--color-primary, #b8960c) → var(--color-primary) (veralteter Fallback entfernt)
     - var(--color-primary-dark, #8a7009) → var(--color-primary-dark) (entfernt)
   ========================================================================== */

.section--contact {
  background: var(--color-bg-warm);
}

.section--warm + .section--contact {
  background: var(--color-white);
}

/* Zebra-Fortsetzung über .footer-frames-Wrapper hinweg: letzter Footer-Frame
   ist via :nth-child(odd) beige → Kontakt soll weiß sein (Sibling-Selektor
   greift sonst nicht durch den Wrapper). */
.footer-frames:has(> .footer-frames__item:last-child:nth-child(odd)) + .section--contact {
  background: var(--color-white);
}

.section--contact h2 {
  text-align: left;
}

.contact-grid {
  gap: 7.5rem;
}

@media (min-width: 1024px) and (max-width: 1399px) {
  .contact-grid {
    gap: var(--space-2xl);
  }
}

@media (max-width: 1023px) {
  .contact-grid {
    gap: var(--space-xl);
  }
}

.contact-info {
  text-align: left;
}

.contact-info > * + * {
  margin-top: var(--space-sm);
}

.contact-info > .contact-info__company {
  margin-top: var(--space-lg);
}

.contact-info > .contact-info__social {
  margin-top: var(--space-lg);
}

/* Firmenblock (ein oder mehrere Rechtsträger). Erster Block bekommt den Abstand
   zum Logo; mehrere Blöcke werden durch Linie + Abstand getrennt. */
.contact-info > .contact-info__entity {
  margin-top: var(--space-lg);
}

.contact-info__entity > * + * {
  margin-top: var(--space-sm);
}

.contact-info__entity + .contact-info__entity {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid #e5e5e5;
}

.contact-info__logo img {
  max-width: 13.75rem;
}

address,
.contact-info__address {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-text);
  padding: 0;
  text-indent: 0;
  text-align: left;
}

.contact-info__details {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-text);
}

.contact-info__details a {
  color: var(--color-text);
}

.contact-info__email {
  margin-bottom: var(--space-xs);
}

.contact-info__email a {
  color: var(--color-primary);
}

.contact-info__social {
  gap: 1.2rem;
}

.contact-info__social a {
  width: 2.125rem;
  height: 2.125rem;
  background: var(--color-border);
  color: var(--color-white);
}

.contact-info__social a svg {
  width: 16px;
  height: 16px;
}

.contact-info__social a:hover {
  color: var(--color-primary);
}

.contact-form {
  gap: var(--space-sm);
}

.contact-form .form-row {
  gap: var(--space-sm);
}

@media (max-width: 768px) {
  .contact-form,
  .contact-form .form-row,
  .contact-form .form-row--thirds {
    gap: 0;
  }
  .contact-form > *,
  .contact-form .form-row .form-field {
    margin-bottom: 0.75rem;
  }
}

.form-field select,
.form-field input,
.form-field textarea {
  padding: 0.7rem 1rem;
  border: 1px solid var(--color-border);
  /* background-color (NICHT background-Shorthand) — sonst wird der
     Select-Chevron (background-image) überschrieben/gelöscht. */
  background-color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-text);
}

.form-field select {
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
  border-color: var(--color-primary);
}

.form-field--checkbox {
  gap: 0.5rem;
}

.form-field--checkbox label {
  gap: 0.5rem;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--color-text-dark);
}

.form-field--checkbox input[type="checkbox"] {
  margin-top: 0.2rem;
}

.contact-form__hint {
  gap: 4rem;
  font-size: 0.82rem;
  color: var(--color-text-light);
  line-height: 1.6;
}

.contact-form__hint-left {
  gap: 0.4rem;
}

.contact-form__hint-left svg {
  margin-top: 0.15rem;
}

.contact-form__status {
  padding: 0.75rem 1rem;
  border-radius: 4px;
  font-size: 0.9rem;
  line-height: 1.5;
}

.contact-form__status--success {
  background: var(--color-success-bg);
  color: var(--color-success);
  border: 1px solid var(--color-success-border);
}

.contact-form__status--error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border: 1px solid var(--color-danger-border);
}

.contact-form__download-link {
  margin-top: 0.5rem;
  font-weight: 600;
  color: var(--color-primary);
}

.contact-form__download-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}
