* {
  box-sizing: border-box;
}
body {
  margin: 0;
  padding: 0;
  width: auto;
  height: auto;
  background-color: rgb(33, 34, 34);
  color: rgba(21, 129, 21, 0.685);
  font-family: Arial, Helvetica, sans-serif;
}
main {
  display: grid;
  grid-template-columns: 0.5fr 0.5fr 1fr;
  gap: 20px;
  margin: 0 auto 25px auto;
  padding: 0;
  box-sizing: border-box;
  width: 95vw;
  font-size: 1rem;
  height: auto;

  justify-content: center;
}
header {
  margin: 0;
  padding: 10px;
  text-align: center;
  width: 100vw;
}

.grid-column {
  display: block;
}
.grid-column > label,
input,
textarea,
select {
  width: 100%;
  resize: none;
  margin: 5px 0 5px 0;
  border-radius: 5px;
  font-size: 1rem;
}
button {
  margin: 15px;
}
input,
textarea,
select {
  background-color: rgb(189, 189, 189);
}

.stranger-danger {
  color: red;
  content: "*";
}
#program,
#hole-input > textarea {
  width: 100%;
  height: 75vh;
}

@media (width < 1000px) {
  main {
    display: block;
  }
  #inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    row-gap: 20px;
  }
  #hole-input,
  #output {
    margin-top: 15px;
  }
}
