.column_sec {
  font-size: 14px;
}
.column_sec table.table {
  margin-top: 20px;
}
.column_sec table.table th, .column_sec table.table td {
  border: 1px solid #000;
  padding: 10px;
}
.column_sec table.table th {
  background-color: #f1f1f1;
}
.column_sec h3.sub_ttl {
  margin-top: 30px;
}
.column_sec .flex {
  justify-content: space-between;
}
.column_sec .flex p {
  width: 55%;
}
.column_sec .flex figure {
  width: 40%;
}
.column_sec ol {
  margin: 20px 0;
}
.column_sec ol li {
  border-bottom: 1px dashed #000;
  font-weight: bold;
  padding: 6px 0;
}
.column_sec ol li span {
  display: inline-block;
  background-color: #005bac;
  border-radius: 100px;
  text-align: center;
  color: #fff;
  width: 20px;
  height: 20px;
  line-height: 20px;
  margin-right: 10px;
}

.meishi_recreate_01_sec .flex {
  border-bottom: 2px dashed #ccc;
  padding-bottom: 20px;
}
.meishi_recreate_01_sec .flex p {
  padding-top: 10px;
}

.meishi_recreate_02_sec {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
}
.meishi_recreate_02_sec .txt {
  font-size: 90%;
  width: 45%;
}
.meishi_recreate_02_sec figure {
  width: 50%;
  text-align: center;
}
.meishi_recreate_02_sec h4 {
  margin-top: 10px;
}

#data_page .option_sec dl dd {
  font-size: 90%;
  margin-top: 10px;
}

@media screen and (max-width: 480px) {
  .column_sec {
    font-size: 85%;
  }
  .column_sec .flex {
    flex-flow: column;
  }
  .column_sec .flex p {
    width: 100%;
    order: 2;
  }
  .column_sec .flex figure {
    order: 1;
    width: 80%;
    margin: 0 auto 20px auto;
  }
  .meishi_recreate_02_sec {
    flex-flow: column;
  }
  .meishi_recreate_02_sec .txt {
    width: 100%;
  }
  .meishi_recreate_02_sec figure {
    width: 100%;
    margin-top: 20px;
  }
}