@media screen and (max-width: 480px) {
  .contact {
    padding: 3rem 0.25rem 1rem;
  }
  .contact__title {
    font-size: 1.1rem;
  }
  .contact__map-title {
    font-size: 1rem;
  }
}
.contact {
  padding: 6rem 0 3rem;
}

.contact__container {
  width: min(1100px, 92%);
  margin: 0 auto;
}

.contact__header { margin-bottom: 2rem; }
.contact__title { font-size: 2rem; font-weight: 700; }
.contact__subtitle { color: #555; }

.contact__alert {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: 1rem;
  border-radius: .5rem;
  margin-bottom: 1rem;
}
.contact__alert--success { background: #e9f8ee; color: #116d3b; }

.contact__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.form__field { display: flex; flex-direction: column; gap: .5rem; }
.form__field--full { grid-column: 1 / -1; }
.form__label { font-weight: 600; }
.form__input, .form__textarea {
  border: 1px solid #ddd;
  border-radius: .5rem;
  padding: .75rem 1rem;
  font-size: 1rem;
}
.form__input:focus, .form__textarea:focus { outline: none; border-color: #888; }
.form__submit {
  margin-top: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: #000;
  color: #fff;
  padding: .75rem 1.25rem;
  border: none;
  border-radius: .5rem;
  cursor: pointer;
}

.contact__info {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.info__card {
  display: flex;
  gap: .75rem;
  padding: 1rem;
  border: 1px solid #eee;
  border-radius: .75rem;
}
.info__icon { font-size: 1.5rem; }
.info__title { font-weight: 700; }
.info__text { color: #666; }

.contact__map { margin-top: 2rem; }
.contact__map-title { font-size: 1.5rem; font-weight: 700; margin-bottom: .25rem; }
.contact__map-address { color: #555; margin-bottom: .75rem; }
.map__embed { position: relative; padding-top: 56.25%; border-radius: .75rem; overflow: hidden; border: 1px solid #eee; }
.map__embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.map__directions { display: inline-block; margin-top: .75rem; background: #000; color: #fff; padding: .6rem 1rem; border-radius: .5rem; }

@media (max-width: 768px) {
  .contact__grid { grid-template-columns: 1fr; }
  .contact__info { grid-template-columns: 1fr; }
}
