/* demo演示用 */
body,
html,
div {
  margin: 0;
  padding: 0;
}
.maincon {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.a,
.b,
.c,
.d {
  border: 1px solid #f00;
  width: 150px;
  margin: 20px;
}
.a {
  height: 120px;
}
.b {
  height: 100px;
}
.c {
  height: 40px;
}
.d {
  height: 200px;
  border-color: #00f;
}
@media (max-width: 640px) {
  .maincon {
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  .d {
    -webkit-box-ordinal-group: 0;
    -webkit-order: -1;
        -ms-flex-order: -1;
            order: -1;
  }
}
