@charset "UTF-8";
/*------------------------------------------------------------------------ */
/*--------------------------------------------------------------- variable */
/*------------------------------------------------------------------------ */
/*--------------------------------------------------------------- mixin    */


.reference {
  background: #4e4e4e;
  padding: 2rem;
}
.reference p {
  font-size: 12px;
  margin-bottom: 0;
}

.authorboc {
  background: rgba(218, 55, 150, 0.04);
  padding: 1.5rem;
}
.authorboc .exp {
  font-size: 13px;
  margin-top: 1rem;
}
.authorboc .url {
  font-size: 11px;
}
.authorboc .author, .authorboc .author > a {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.authorboc .author figure, .authorboc .author > a figure {
  width: 40px;
  height: 40px;
  -moz-border-radius: 20px;
  -webkit-border-radius: 20px;
  border-radius: 20px;
  overflow: hidden;
}
.authorboc .author p, .authorboc .author > a p {
  width: calc(100% - 48px);
  font-size: 14px;
  line-height: 1.2;
  margin-bottom: 0;
}
.authorboc .author p span, .authorboc .author > a p span {
  display: block;
  font-size: 12px;
  margin-bottom: 0px;
}

.authorarea {
  padding-top: 2.5rem;
}


#blog h1 {
  font-weight: bold;
  width: 100%;
  text-align: left;
  margin-bottom: 1.5rem;
  font-size: 20px;
}
@media only screen and (min-width: 768px) {
  #blog h1 {
    font-size: 27px;
  }
}
#blog .posthead {
  margin-bottom: 2.5rem;
}
#blog .posthead .cat {
  margin-top: 2rem;
  font-size: 11px;
}
#blog .posthead .cat:after {
  content: "";
  width: 15px;
  height: 1px;
  display: block;
  margin: 1rem 0;
}
#blog .cont {
  text-align: left;
  margin-top: 2rem;
}
#blog .cont h2 {
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 1rem;
  margin-top: 2.5rem;
  padding: 1rem 1.5rem;
  border-left: 4px solid #da3796;
  background: rgba(218, 55, 150, 0.1);
  text-align: left;
}
#blog .cont h3 {
  margin-top: 1rem;
  margin-bottom: 1rem;
  font-size: 16px;
  font-weight: bold;
  padding-left: 1.5rem;
  position: relative;
  color: #da3796;
}
#blog .cont h3:before {
  content: "■ ";
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (min-width: 768px) {
  #blog .cont h3 {
    margin-top: 1.5em;
    margin-bottom: 1.5em;
  }
}
#blog .cont h4 {
  margin-top: 1em;
  margin-bottom: 1em;
  font-size: 16px;
  padding: 1rem;
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  #blog .cont h4 {
    margin-top: 1.5em;
    margin-bottom: 1.5em;
    padding: 1rem;
  }
}
#blog .cont h5 {
  margin-top: 1em;
  margin-bottom: 1em;
  font-size: 14px;
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  #blog .cont h5 {
    margin-top: 1.5em;
    margin-bottom: 1.5em;
    padding: 1rem;
  }
}
#blog .cont p {
  margin-bottom: 1em;
  font-size: 14px;
  line-height: 1.8;
}
@media only screen and (min-width: 768px) {
  #blog .cont p {
    margin-bottom: 1.5em;
  }
}
#blog .cont ul, #blog .cont ol {
  margin-bottom: 1.5em;
  padding: 1.2rem;
  background: rgba(218, 55, 150, 0.05);
}
@media only screen and (min-width: 768px) {
  #blog .cont ul, #blog .cont ol {
    padding: 1.8rem;
  }
}
#blog .cont ul li, #blog .cont ol li {
  position: relative;
  margin-bottom: 0.9em;
  padding-left: 1em;
  font-size: 14px;
  line-height: 1.7;
  color: #da3796;
  font-weight: bold;
}
#blog .cont ul li:last-child, #blog .cont ol li:last-child {
  margin-bottom: 0;
}
#blog .cont table {
  width: 100%;
  margin-bottom: 2.5rem;
}
#blog .cont table tr {
  border: rgba(34, 34, 34, 0.15) 1px dotted;
}
#blog .cont table th {
  padding: 1rem;
  font-weight: bold;
  font-size: 13px;
  background: rgba(34, 34, 34, 0.1);
  width: 25%;
}
#blog .cont table td {
  padding: 1rem;
  font-size: 13px;
}
#blog .cont ul li:before {
  content: "";
  position: absolute;
  padding-left: 0;
  margin-right: 0.6em;
  display: inline-block;
  width: 5px;
  height: 5px;
  vertical-align: 0.25em;
  background: #da3796;
  border-radius: 50%;
  left: 0;
  top: 10px;
}
#blog .cont ol {
  counter-reset: num;
}
#blog .cont ol li:before {
  counter-increment: num;
  content: counter(num) ".";
  position: absolute;
  color: #da3796;
  top: 0;
  left: 0;
  font-weight: 700;
}
#blog .cont blockquote {
  margin-bottom: 20px;
  padding: 10px;
  border: 1px solid rgba(34, 34, 34, 0.1);
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
}
#blog .cont blockquote p {
  margin: 0;
}
#blog .cont blockquote a {
  color: #4e4e4e;
}

.ttl2 {
  color: #da3796;
  border-top: 0.15em solid #eee;
  padding-top: 20px;
}

.contents .flexbox #sidebar h3 {
  background: none;
  color: #da3796;
  border-top: 0.15em solid #eee;
  margin-bottom: 5px;
  padding-left: 0;
}

.contents .flexbox #sidebar .articlelist .articleblc h3 {
	border:none;
}

#sidebar #searchForm {
  position: relative;
  width: 100%;
  margin: 12px 10px 0 0;
}

#sidebar #searchForm input {
  border: solid 1px #ccc;
  width: 100%;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  border-radius: 5px;
  padding: 10px;
}

#sidebar #searchForm #SubmitBtn {
  position: absolute;
  top: 8px;
  right: 10px;
  border: 0px;
  width: 20px;
  height: 20px;
  border-radius: 0px;
  background: url(https://iefree.co.jp/wp-content/uploads/2022/01/search.png) no-repeat left top;
  background-size: 100%;
}

#sidebar .sidelist li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  margin-bottom: 15px;
  border: 2px #eee solid;
}

#sidebar .sidelist li:last-child {
  margin-bottom: 0;
}

#sidebar .sidelist li .photo {
  width: 80px;
  height: 80px;
  overflow: hidden;
  object-fit: cover;
}

#sidebar .sidelist li .photo a img {
  -moz-transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
  -webkit-transform: scale(1, 1);
  -moz-transform: scale(1, 1);
  -o-transform: scale(1, 1);
  -ms-transform: scale(1, 1);
  transform: scale(1, 1);
  object-fit: cover;
  width: 80px;
  height: 80px;
}

#sidebar .sidelist li .photo a:hover img {
  -webkit-transform: scale(1.1, 1.1);
  -moz-transform: scale(1.1, 1.1);
  -o-transform: scale(1.1, 1.1);
  -ms-transform: scale(1.1, 1.1);
  transform: scale(1.1, 1.1);
}

#sidebar .sidelist li .desc {
  width: calc(100% - 87px);
  font-weight: normal;
  margin-bottom: 5px;
  line-height: 1.2;
  font-size: 11px;
  padding: 5px 5px 0;
  position: relative;
}

#sidebar .sidelist li .desc a {
  text-decoration: none;
  position: relative;
}

#sidebar .sidelist li .desc a.wpp-post-title {
  display: block;
  max-height: 3.8em;
  overflow: hidden;
}

#sidebar .sidelist li .desc a:after {
  content: "";
  display: block;
  width: 100%;
  height: 50%;
  position: absolute;
  bottom: 0;
  left: 0;
}

#sidebar .sidelist li:first-child .photo {
  width: 100%;
  height: auto;
}

#sidebar .sidelist li:first-child .photo a img {
  width: 100%;
  height: auto;
}

#sidebar .sidelist li:first-child .desc {
  width: 100%;
  font-size: 14px;
  padding: 0px 10px 0;
}

#sidebar .sidelist li:first-child .desc span {
  top: 0;
}

#sidebar .sidelist li:first-child .desc .cat {
  font-size: 10px;
}

#sidebar .sidelist li:first-child .desc .data {
  font-size: 10px;
}

#sidebar .ranking {
  counter-reset: num;
}

#sidebar .ranking li {
  counter-increment: num;
  position: relative;
}

#sidebar .ranking li:after {
  content: counter(num);
  position: absolute;
  top: 5px;
  left: -5px;
  width: 20px;
  font-size: 10px;
  height: 20px;
  line-height: 20px;
  background: #da3796;
  color: #fff;
  text-align: center;
}

#sidebar .category li {
  border-bottom: 1px rgba(0, 0, 0, 0.1) solid;
}

#sidebar .category li a {
  display: block;
  padding: 15px 0;
}

@media screen and (max-width: 750px) {
  .box {
    padding-top: 2.5em;
  }
}
#blog #toc_container {
  border-top: 0.15rem solid rgba(34, 34, 34, 0.1);
  border-bottom: 0.15rem solid rgba(34, 34, 34, 0.1);
  padding: 1em;
}
#blog #toc_container .toc_title {
  font-size: 13px;
}
#blog #toc_container .toc_list {
  background: none;
}
#blog #toc_container .toc_list .toc_number {
  position: relative;
  padding-right: 0.5rem;
}
@media screen and (max-width: 750px) {
  #blog #toc_container .toc_list {
    padding: 0;
  }
}
#blog #toc_container .toc_list ul {
  padding: 0;
  background: none;
  margin: 0;
}
#blog #toc_container .toc_list ul .toc_number {
  padding-left: 1rem;
}
#blog #toc_container .toc_list ul li {
  padding: 0;
  font-weight: normal;
  position: relative;
  margin: 0;
}
#blog #toc_container .toc_list ul li:before {
  display: none;
}
#blog #toc_container .toc_list ul ul {
  padding: 0;
  padding-left: 1rem;
  margin: 0;
}
#blog #toc_container .toc_list ul ul li {
  padding-left: 1rem;
}
#blog #toc_container .toc_list a {
  text-decoration: none;
}
#blog #toc_container .toc_list li {
  font-weight: normal;
  padding: 0;
  margin: 0;
}
#blog #toc_container .toc_list li:before {
  display: none;
}
#blog .supervision {
  background: rgba(34, 34, 34, 0.01);
  padding: 25px 25px 0;
}
@media only screen and (max-width: 768px) {
  #blog .supervision {
    display: block;
  }
}
#blog .supervision figure {
  width: 90px;
  height: 90px;
  -moz-border-radius: 45px;
  -webkit-border-radius: 45px;
  border-radius: 45px;
  overflow: hidden;
}
@media only screen and (max-width: 768px) {
  #blog .supervision figure {
    margin: auto;
  }
}
#blog .supervision figure img {
  object-fit: cover;
  width: 90px;
  height: 90px;
}
#blog .supervision .prof {
  margin-bottom: 10px;
  width: calc(100% - 110px);
}
@media only screen and (max-width: 768px) {
  #blog .supervision .prof {
    width: calc(100%);
  }
}
#blog .supervision .prof p {
  font-size: 13px;
}
#blog .supervision .prof .prof-name {
  font-weight: bold;
}
#blog .supervision .prof .prof-text {
  font-size: 12px;
  font-weight: normal;
}
