#toc_container {
  margin-top: 60px;
  margin-bottom: 100px;
  padding: 0;
  width: 100%;
  border: 0;
}
#toc_container .toc_title {
  cursor: pointer;
  position: relative;
  margin-bottom: 0;
  padding: 10px 10px 10px 100px;
  border: solid 1px #eee;
}
#toc_container .toc_title::before {
  content: '';
  background-image: url("../../images/common/toc.png");
  position: absolute;
    content: '';
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  top: 50%;
  left: 4%;
  transform: translate(-4%, -50%);
  -webkit-transform: translate(-4%, -50%);
  -ms-transform: translate(-4%, -50%);
  width: 45px;
  height: 35px;
}
#toc_container .toc_title::after {
  position: absolute;
  right: 20px;
  content: "\f107";
  color: #8D8D8D;
  font-family: 'Font Awesome 6 Free';
  font-size: 18px;
  font-weight: bold;
}
#toc_container .toc_title.close::after { content: "\f106"; }
#toc_container .toc_list {
  /*display: none;*/
  list-style: none;
  margin: 0 !important;
  padding: 35px 45px !important;
  background: #F5F5F5;
  border: solid 1px #eee;
  border-top: 0;
}
#toc_container .toc_list li { margin-bottom: 30px; }
#toc_container .toc_list ol {
  list-style: none;
  margin-top: 10px;
  margin-left: 15px;
}
#toc_container .toc_list ol li { margin-bottom: 0; }
#toc_container .toc_list ol li ol {
  margin-top: 0;
  margin-left: 30px;
}
#toc_container .toc_list ol:last-child,
#toc_container .toc_list ol li ol:last-child { margin-bottom: 0; }
#toc_container .toc_list ol li::before {
  content: "-";
  margin-right: 3px;
}
#toc_container .toc_list ol li ol li::before {
  font-family: 'Font Awesome 6 Free';
  content: "\4c";
  position: relative;
  margin-right: 3px;
  top: -4px;
  font-size: 15px;
}
#toc_container .toc_list li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
#toc_container .toc_number {
  color: #16c69d;
  font-family: 'ZenKakuGothicNew-B';
}
#toc_container .toc_list li a {
  text-decoration: none !important;
  overflow-wrap: anywhere;
  color: #404040 !important;
}
#toc_container .toc_list li strong { font-weight: normal; }
.pc #toc_container .toc_list li a:hover {
  text-decoration: underline !important;
  color: #105AAF !important;
  opacity: 1;
  -webkit-opacity: 1;
  -moz-opacity: 1;
  -ms-opacity: 1;
  -o-opacity: 1;
}
@media screen and (max-width: 991px){
  #toc_container { margin: 5rem 0; }
  #toc_container .toc_title { padding-left: 20%; }
  #toc_container .toc_list{ padding: 3.5rem 1.5rem !important; }
}
