@charset "UTF-8";

h2{
  padding-bottom: 1em;
}

#query{
  background-color: rgba(255,255,255,0.95);
  padding: 2em;
  margin: 2em 0;
  box-shadow: -1px -1px 5px rgba(0, 0, 0, 0.5) inset;
  border-radius: 10px;
}

#query p{
  text-align: center;
}

form{
  margin: 2em 20%;
}

form div{
  display: flex;
  justify-content: flex-start;
  margin-bottom: 1em;
}

form label{
  display: inline-block;
  flex-basis: 30%;
  line-height: 1.5em;
}

form input,
form textarea{
  flex-basis: 70%;
}

form input{
  line-height: 1.5em;
}

#kind{
  height: 2em;
}

.required::after{
  content: "※";
}

#btns{
  display: flex;
  justify-content: flex-end;
  margin-top: 1em;
}

#btns input{
  flex-basis: 10%;
  border-radius: 5px;
  background: #eee;
}

#btns input+input{
  margin-left: 1em;
}

#query_notes{
  text-align: right;
  font-size: 0.8em;
}

@media screen and (max-width:640px){
  #query{
    padding: 2em 0 0;
    margin-top: 4em;
    border-radius: 0;
    box-shadow: none;
  }

  #query p{
    padding: 0 1em;
    text-align: left;
  }

  h2{
    text-align: center;
  }

  form{
    margin: 0;
    padding: 1em;
  }

  form div{
    display: block;
  }

  form label{
    display: block;
    padding-bottom: 0.5em;
  }

  form input,
  form select,
  form textarea{
    width: 98%;
  }

  #btns{
    display: block;
  }

  #btns input{
    width: 100%;
    margin: 0;
    padding: 0;
    line-height: 3em;
    height: 30px;
  }

  #btns input+input{
    margin: 1em 0 0;
  }
}
