/* Reset box-sizing and margins */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Main section container */
.contact-section {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
  max-width: 1200px;
  width: 100%;
  min-height: 100vh; /* fill viewport height */
  margin: 0 auto;
  padding: 1.5rem; /* consistent with card padding */
  background-color: #fff;
}

/* Info and form cards */
.contact-info,
.contact-form {
  flex: 1 1 45%;
  min-width: 360px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

/* Form fills card */
.contact-form form {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: 0.8rem;
}

/* Inputs and textarea */
.contact-form input,
.contact-form textarea {
  padding: 0.8rem;
  border: 1px solid #ccc;
  border-radius: 5px;
  font-size: 1rem;
  width: 100%;
}

/* Textarea stretches vertically */
.contact-form textarea {
  flex-grow: 1;
  resize: vertical;
}

/* Button styling */
.contact-form button {
  padding: 0.8rem;
  background-color: #007BFF;
  color: #fff;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 1rem;
  transition: background 0.3s ease;
}

/* Hover effect */
.contact-form button:hover {
  background-color: #0056b3;
}

/* Map section */
.map {
  max-width: 1200px;
  width: 96%;
  margin: 1rem auto; /* same spacing as cards */
  padding: 1rem;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  background-color: #fff;
}

/* Map iframe fills parent */
.map iframe {
  width: 100%;
  height: 300px;
  border: 1px solid #ccc; /* gray border */
  border-radius: 8px;
  display: block;
}

/* Responsive layout */
@media (max-width: 768px) {
  .contact-section {
    flex-direction: column;
    min-height: auto;
    padding: 1rem;
  }

  .contact-info,
  .contact-form,
  .map {
    flex: 1 1 100%;
    min-width: 100%;
    height: auto;
    padding: 1rem;
    border-radius: 0;
    box-shadow: none;
    border: none;
    margin-bottom: 1rem; /* spacing between stacked sections */
  }

  .contact-form form {
    flex-grow: 0;
  }
}
