/* app/assets/stylesheets/immo/contact.css */

#immo-page .contact {
  background: var(--charcoal);
  border-radius: 20px;
  padding: 72px 6vw;
  margin: 0 auto 80px;
  max-width: 1100px;
  text-align: center;
}

#immo-page .contact .immo-label { color: #f59e0b; }
#immo-page .contact h2 { color: var(--white); margin-bottom: 16px; }

#immo-page .contact > p {
  font-size: .92rem;
  color: rgba(253,250,245,.55);
  max-width: 480px;
  margin: 0 auto 36px;
}

#immo-page .contact__form {
  max-width: 640px;
  margin: 0 auto 32px;
  text-align: left;
}

#immo-page .contact__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

#immo-page .contact__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#immo-page .contact__field--full { margin-bottom: 16px; }

#immo-page .contact__label {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(253,250,245,.5);
}

#immo-page .contact__input {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-size: .92rem;
  padding: 12px 16px;
  transition: border-color .2s, background .2s;
  width: 100%;
}

#immo-page .contact__input::placeholder { color: rgba(253,250,245,.25); }

#immo-page .contact__input:focus {
  outline: none;
  border-color: var(--clay);
  background: rgba(255,255,255,.1);
}

#immo-page .contact__select { appearance: none; cursor: pointer; }
#immo-page .contact__select option { background: #2a2a2a; color: #fff; }
#immo-page .contact__textarea { resize: vertical; min-height: 120px; }

#immo-page .contact__submit { text-align: center; margin-top: 8px; }

#immo-page .contact__btn {
  display: inline-block;
  background: var(--clay);
  color: var(--white);
  border: none;
  cursor: pointer;
  padding: 16px 40px;
  border-radius: 40px;
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  font-weight: 500;
  letter-spacing: .04em;
  transition: background .2s, transform .2s;
}

#immo-page .contact__btn:hover {
  background: var(--terracotta);
  transform: translateY(-2px);
}

#immo-page .contact__flash {
  max-width: 640px;
  margin: 0 auto 24px;
  padding: 14px 20px;
  border-radius: 8px;
  font-size: .88rem;
  text-align: left;
}

#immo-page .contact__flash--success {
  background: rgba(134,239,172,.12);
  border: 1px solid rgba(134,239,172,.3);
  color: #86efac;
}

#immo-page .contact__flash--error {
  background: rgba(252,165,165,.12);
  border: 1px solid rgba(252,165,165,.3);
  color: #fca5a5;
}

#immo-page .contact__warning {
  margin-top: 20px;
  font-size: .75rem;
  color: rgba(253,250,245,.3);
}

@media (max-width: 600px) {
  #immo-page .contact__fields { grid-template-columns: 1fr; }
}
