.container {
  max-width: 80vw !important;
}

#map {
  width: 80vw;
  height: 60vh;
  display: block; margin: 0 auto;	/* horizontal centering */
}

/* ******************** INFORMATION BLOCKS ******************** */

#location-error {
  display: none;
  // margin-top: 1em;
  color: red;
  text-align: center;
  font-size: 1rem;
  margin: 10px auto;
  max-width: 80vw;
}

#error-msg {
  // margin-bottom: 10px;
  color: red;
  text-align: center;
  font-size: 1rem;
  margin: 10px auto;
  max-width: 80vw;
}

#instructions {
  text-align: center;
  font-size: 1rem;
  margin: 10px auto;
  max-width: 80vw;
}

#getting-location {
  display: none;
  color: #383;
}

#spinner {
  display: inline-block;

  width: 0.8em;
  height: 0.8em;
  vertical-align: middle;
  margin: 0 0.4em;

  border: 2px solid #ccc;
  border-top: 2px solid #383;
  border-radius: 50%;
  animation: spin 1.0s linear infinite;	/* SPIN = keyframes below */
  background-color: #cfc;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ******************** FORM ******************** */

#form-container {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 20px;
  max-width: 90vw;
  margin: auto;
  align-items: stretch;
  justify-content: center;
}
.form-block {
  display: flex;
  flex-direction: column;
  min-width: 200px;
  max-width: 400px;
  justify-content: center;
}
.form-block label {
  margin-bottom: 5px;
}
.form-block input[type="text"] {
  padding: 6px;
}
.form-block input[type="checkbox"] {
  margin-top: 5px;
}

.req {
  color:red;
}

