@charset "utf-8";

/* ------------------------------------------------------------------------------
     post
-------------------------------------------------------------------------------*/
.post-wrap {
  padding: 20px 30px 30px;
}

/* 2022.08.08修正 */
@media screen and (max-width:767px) {
  .post-wrap {
    /* margin: 28px -10px 0; */
    padding: 26px 15px;
    border-left: none;
    border-right: none;
    border-radius: 0;
  }
}
.main-post-title {
  font-size: 20px;
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .main-post-title {
    font-size: 19px;
    font-weight: bold;
    line-height: 1.2;
  }
}
.subtitle {
  font-weight: bold;
  font-size: 18px;
}
@media screen and (max-width:767px) {
  .subtitle {
    margin-top: 5px;
    font-size: 17px;
  }
}
.post-data {
  margin: 0 0 20px;
  padding-bottom: 10px;
  border-bottom: 2px dotted #c2cad5;
  color: #5e6570;
  font-size: 16px;
  text-align: right;
}
@media screen and (max-width:767px) {
  .post-data {
    margin: 10px 0 20px;
    padding-bottom: 14px;
    border-bottom: 2px dotted #c2cad5;
    color: #5e6570;
    font-size: 15px;
  }
}
.post-date {
  margin-left: 10px;
}
.post-sns-share-sp {
  display: flex;
  margin-top: 16px;
}
@media screen and (min-width:768px) {
  .post-sns-share-sp {
    display: none;
  }
}
.post-sns-share-sp > div + div {
  margin-left: 8px;
}
@media screen and (min-width:768px) {
  .post-lead {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (max-width:767px) {
  .post-lead::after {
    content: "";
    display: block;
    clear: both;
  }
}
.post-lead-text {
  width: 325px;
  font-size: 17px;
}
@media screen and (max-width:767px) {
  .post-lead-text {
    float: left;
    width: 100%;
    font-size: 16px;
  }
  .post-lead-text > p {
    line-height: 1.8;
  }
}
.post-lead-img {
  width: 300px;
}
@media screen and (max-width:767px) {
  .post-lead-img {
    float: right;
    width: 49%;
    margin: 0 0 10px 10px;
  }
}
.post-lead-img-text {
  margin-top: 10px;
  font-size: 15px;
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .post-lead-img-text {
    font-size: 14px;
  }
}

/* 2022.08.23追記 */
#post-top {
  height: auto;
  overflow: hidden;
}


/* 目次 */
/* 2022.09.15追記 */
.toc-wrap {
  clear: both;
  position: relative;
  border: 1px  solid #bbc6d6;
  border-radius: 7px;
  padding: 0px 15px 10px 15px;
  margin-top: 24px;
}

.toc-wrap p {
  font-size: 14px;
  margin-left: -2px;
}
@media screen and (max-width:767px) {
  .toc-wrap {
    margin-top: 24px;
    padding: 0px 14px 20px;
  }
}
.toc-list {
  margin-top: 20px;
}
.toc > dt {
  font-size: 14px;
  font-weight: normal;
  line-height: 1;
}

/* 2022.09.15追記 */
.toc dt {
  position: absolute;
  top: -0.5em;
  left: 8px;
  background: #F5F9FF;
  color: #333333;
  padding: 0 0.5em;
}

.toc-list > li {
  position: relative;
  padding-left: 16px;
  font-size: 15px;
}
.toc-list > li + li {
  margin-top: 5px;
}
.toc-list > li::before {
  content: "";
  top: 3px;
  left: 0;
  position: absolute;
  display: block;
  width: 3px;
  height: 18px;
  margin: auto;
  background: #90aad0;
}

/* 2022.09.22追記 */
.enc-wrap {
  /* width: calc(100% - 170px);
  margin-left: 175px; */
  padding: 0px 12px;
  border: 2px solid #bbc6d6;
  font-size: 15px;
  font-weight: normal;
  clear: both;
}

@media screen and (max-width:767px){
  .enc-wrap {
    width: 100%;
    margin-left: 0px;
    clear: both;
  }
}

/* 2022.09.15追記 */
.enc-wrap p {
  display: block;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  /* text-indent: 1em; */
}

.post-download-text {
  margin-top: 16px;
  font-size: 14px;
  text-align: right;
}

/* PDFダウンロードリンク */
.pdf-download-link {
  margin-top: 22px;
  font-size: 14px;
}
@media screen and (max-width:767px) {
  .pdf-download-link {
    margin-top: 12px;
    font-size: 13px;
  }
}
.pdf-download-link > a {
  color: #0e3283;
}
.pdf-download-link > .icon-pdf {
  position: relative;
  top: -3px;
  margin-left: 10px;
  vertical-align: middle;
}

.post-main h2 {
  position: relative;
  margin-top: 16px;
  margin-bottom: 16px;
  padding-left: 20px;
  padding-top: 2px;
  font-size: 20px;
  font-weight: bold;
  /* vertical-align: bottom; */
  /* height: 32px; */
  /* display: grid;
  place-items: start; */
}

@media screen and (max-width:767px) {
  .post-main h2 {
    margin-top: 17px;
    padding-left: 12px;
    /* border-left: 5px solid #0e3283; */
  }
}
.post-main h2::before {
  content: "";
  top: 0; bottom: 0;
  left: 0;
  position: absolute;
  display: block;
  width: 5px;
  height: 32px;
  background: #0e3283;
}
@media screen and (max-width:767px) {
  .post-main h2::before {
    /* content: none; */
    content: "";
    top: 0; bottom: 0;
    left: 0;
    position: absolute;
    display: block;
    width: 5px;
    height: 32px;
    background: #0e3283;
  }
}
.post-main > p {
  display: block;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  text-indent: 1em;
}
@media screen and (max-width:767px) {
  .post-main > p {
    margin-top: 16px;
    /* font-size: 16px; */
    /* line-height: 1.8; */
  }
}

/* 2022.09.15追記 */
.post-main > blockquote p {
  display: block;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  text-indent: 1em;
}

.post-main > blockquote p:last-child {
  padding-bottom: 0px;
}

@media screen and (max-width:767px){
  .post-main > blockquote {
    margin: 17px 20px;
  }
}

@media screen and (max-width:767px) {
  .post-main > blockquote {
    margin: 17px 20px;
  }
}



/* 2022.07.25追記 */
.post-main > div.document p:first-child {
  padding-top: 16px;
}

.post-main > div.document p {
  padding-bottom: 7.5px;
}

/* 2022.07.22追記 */
.post-img {
  width: 200px;
  margin-top: 30px;
  margin-right: 30px;
  float: left;
}


@media screen and (max-width:767px) {
  .post-img {
    width: 50%;
    margin-top: 30px;
    float: left;
  }
}
.post-img > p {
  font-size: 14px;
  font-weight: bold;
}
.post-img > p + p {
  margin-top: 10px;
}
.post-bottom-logo {
  margin: -3px 0 0 5px;
  vertical-align: middle;
}

.post-user-only {
  margin-top: 80px;
  padding: 24px 28px 60px;
  clear: both;
}
@media screen and (max-width:767px) {
  .post-user-only {
    margin: 40px -25px 0;
    padding: 16px 40px 30px;
    border-left: none;
    border-right: none;
    border-radius: 0;
  }
}
.post-user-only-title {
  padding-bottom: 20px;
  border-bottom: 1px solid #cccccc;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media screen and (max-width:767px) {
  .post-user-only-title {
    padding-bottom: 10px;
    font-size: 17px;
  }
}
@media screen and (max-width:767px) {
  .post-user-only-title {
    font-size: 14px;
  }
}
.icon-only {
  padding-left: 40px;
  background: url(../images/icon_only.png) no-repeat left center;
}
@media screen and (max-width:767px) {
  .icon-only {
    padding-left: 30px;
  }
}
.post-user-only-text {
  margin-top: 20px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  line-height: 2;
}
@media screen and (max-width:767px) {
  .post-user-only-text {
    font-size: 16px;
    line-height: 1.8;
  }
}
@media screen and (min-width:768px) {
  .post-user-only-list {
    display: flex;
    justify-content: center;
    margin-top: 10px;
    font-size: 16px;
  }
}
@media screen and (max-width:767px) {
  .post-user-only-list {
    margin-top: 32px;
    font-size: 14px;
  }
}
@media screen and (min-width:768px) {
  .post-user-only-list > li + li {
    padding-left: 20px;
  }
}
.post-user-only-img {
  background: #f6f9fe;
}
@media screen and (min-width:768px) {
  .post-user-only-img {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
    padding: 24px 0;
    background: #f6f9fe;
  }
}
@media screen and (max-width:767px) {
  .post-user-only-img {
    margin-top: 20px;
    padding: 18px 14px;
  }
}
@media screen and (min-width:768px) {
  .post-user-only-img-item {
    width: calc(100% / 3);
    padding: 0 30px;
    text-align: center;
    margin-bottom: 10px;
  }
}
@media screen and (min-width:768px) {
  .post-user-only-img-item + .post-user-only-img-item:not(.no-border) {
    border-left: 1px solid #cccccc;
  }
}
@media screen and (max-width:767px) {
  .post-user-only-img-item + .post-user-only-img-item {
    margin-top: 12px;
    padding-top: 18px;
    border-top: 1px solid #cccccc;
  }
}
@media screen and (min-width:768px) {
  .post-user-only-img-item-img {
    min-height: 117px;
  }
}
.post-user-only-img-item > p {
  font-size: 12px;
  text-align: center;
}
.post-user-only-img-item > p + p {
  margin-top: 10px;
  font-size: 12px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .post-user-only-img-item > p + p {
    margin-top: 14px;
    text-align: left;
  }
}

.post-user-only-button-list {
  margin-top: 40px;
}
@media screen and (max-width:767px) {
  .post-user-only-button-list {
    margin-top: 30px;
  }
}

.post-user-only-button-list > li {
  width: 450px;
  margin: 0 auto;
  font-size: 16px;
}
@media screen and (max-width:767px) {
  .post-user-only-button-list > li {
    width: auto;
    margin: 0 auto;
    font-size: 14px;
  }
}
.post-user-only-button-list > li + li {
  margin-top: 20px;
}

.post-user-only-button-dl {
  margin-top: 30px;
}
.post-user-only-button-dl > dt {
  font-size: 14px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .post-user-only-button-dl > dt {
    font-size: 12px;
  }
}
.post-user-only-button-dl > dd {
  margin-top: 10px;
}

.button-01 {
  display: block;
  padding: 20px;
  /* background: #0e3283; */
  border: 1px solid #0e3283;
  border-radius: 8px;
  color: #0e3283;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-01 {
    padding: 16px 10px 16px 28px;
  }
}
.button-02 {
  display: block;
  padding: 20px;
  background: #0e3283;
  border: 1px solid #0e3283;
  border-radius: 8px;
  color: #ffffff;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-02 {
    padding: 16px 10px 16px 28px;
  }
}
.button-02:hover {
  color: #ffffff;
}
.user-only-button {
  background: #0e3283 url(../images/icon_user.png) no-repeat left 20px center;
}
@media screen and (max-width:767px) {
  .user-only-button {
    background: #0e3283 url(../images/icon_user.png) no-repeat left 10px center;
  }
}
.user-only-login-button {
  background: url(../images/icon_login_02.png) no-repeat left 20px center;
}
@media screen and (max-width:767px) {
  .user-only-login-button {
    background: url(../images/icon_login_02.png) no-repeat left 10px center;
  }
}
.user-only-newpost-button {
  background: url(../images/icon_mail_02.png) no-repeat left 20px center;
  border: 1px solid #000000;
  color: #000000;
}
@media screen and (max-width:767px) {
  .user-only-newpost-button {
    background: url(../images/icon_mail_02.png) no-repeat left 6px center;
  }
}

.post-user-only-sns {
  margin-top: 36px;
}
.post-user-only-sns-text {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
}
.post-user-only-sns-icon {
  margin-top: 16px;
  font-size: 0;
  text-align: center;
}
.post-user-only-sns-icon-item {
  display: inline-block;
}
.post-user-only-sns-icon-item + .post-user-only-sns-icon-item {
  margin-left: 20px;
}

.document-dl-link {
  margin-top: 40px;
  padding-bottom: 26px;
  border-bottom: 1px solid #c2cede;
  font-size: 15px;
}
@media screen and (max-width:767px) {
  .document-dl-link {
    margin-top: 30px;
    padding-bottom: 16px;
    font-size: 14px;
  }
}
.document-dl-link-title {
  color: #0e3283;
  font-weight: bold
}
@media screen and (max-width:767px) {
  .document-dl-link-title {
    font-size: 15px;
  }
}
.document-dl-link-login {
  margin-top: 10px;
  font-weight: bold
}
.document-dl-link-login > a {
  color: #0e3283;
  text-decoration: underline;
}
.document-dl-link-list > li {
  margin-top: 5px;
}

/* 2022.09.15追記 */
.document-download-link {
  width: auto;
  margin-top: 30px;
  color: #000000;
  font-size: 15px;
  font-weight: bold;
}

.related-projects-link {
  width: auto;
  margin-top: 30px;
  color: #000000;
  font-size: 15px;
  font-weight: bold;
}

/* 2022.07.31追記 */
.related-projects-link p {
  color: #000;
}




@media screen and (max-width:767px) {
  .related-projects-link {
    margin-top: 20px;
  }
}
.related-projects-link a {
  color: #0e3283;
  font-weight: bold;
  display: inline-block;
  line-height: 1;
}
@media screen and (max-width:767px) {
  .related-projects-link a {
    color: #0e3283;
    font-weight: bold;
    display: block;
    line-height: 2;
  }
}
@media screen and (min-width:768px) {
  .related-projects-link a {
    margin-right: 20px;
  }
}


.link-icon-01 {
  position: relative;
  padding-left: 30px;
}
.link-icon-01::before {
  content: "";
  position: absolute;
  top: -4px; bottom: 0;
  left: 0;
  display: block;
  width: 16px;
  height: 16px;
  margin: auto;
  background: #0e3283;
}
.link-icon-01::after {
  content: "";
  position: absolute;
  top: -4px; bottom: 0;
  left: 4px;
  display: block;
  width: 6px;
  height: 6px;
  margin: auto;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  transform: rotate(45deg);
}

/* ------------------------------------------------------------------------------
     コメントエリア
-------------------------------------------------------------------------------*/
.comment-area {
  margin-top: 30px;
}
@media screen and (max-width:767px) {
  .comment-area {
    margin: 40px 15px 0px;
  }
}
.comment-title {
  padding-left: 45px;
  font-size: 18px;
  font-weight: bold;
  line-height: 34px;
}
.comment-title-twitter {
  background: url(../images/icon_twitter_04.png) no-repeat;
}
.comment-title-hatena {
  background: url(../images/icon_hatena_03.png) no-repeat;
}
.comment-title-facebook {
  background: url(../images/icon_facebook_04.png) no-repeat;
}
.comment-title-user {
  background: url(../images/icon_user_03.png) no-repeat;
}
.comment-wrap + .comment-wrap {
  margin-top: 10px;
}
.comment {
  display: flex;
  padding-top: 10px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f1f1f1;
  /* transform: scale(1);
  transition: 1s; */
}
.comment-twitter {
  display: flex;
  padding-top: 10px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f1f1f1;
  /* transform: scale(1);
  transition: 1s; */
}
.comment-img {
  width: 80px;
}
.comment-text {
  width: calc(100% - 80px);
  padding-left: 24px;
}
.comment-data > span {
  color: #7d7d7d;
  font-size: 14px;
}
.comment-name {
  font-weight: bold;
}
.comment-name > a {
  margin: 0;
  padding: 0;
}
.comment-name > a:hover {
  color: inherit;
  text-decoration: underline !important;
}
.comment-name > a:link,
.comment-name > a:visited,
.comment-name > a:active,
.comment-name > a:focus {
  color: inherit;
  text-decoration: none;
}

.comment-date > a {
  margin: 0;
  padding: 0;
}
.comment-date {
  margin-left: 16px;
}
.comment-date > a:hover {
  color: inherit;
  text-decoration: underline !important;
}
.comment-date > a:link,
.comment-date > a:visited,
.comment-date > a:active,
.comment-date > a:focus {
  color: inherit;
  text-decoration: none;
}
.comment-body {
  margin-top: 5px;
}
.comment-body > p {
  font-size: 14px;
  line-height: 1.8;
}
.comment-more-button,
.comment-close-button {
  margin-top: 30px;
  padding: 4px;
  background: #f8f8f8;
  border: 2px solid #eeeeee;
  border-radius: 4px;
  text-align: center;
  cursor: pointer;
}
.comment-close-button {
  display: none;
}

.comment-more-button-twitter,
.comment-close-button-twitter {
  margin-top: 30px;
  padding: 4px;
  background: #f8f8f8;
  border: 2px solid #eeeeee;
  border-radius: 4px;
  text-align: center;
  cursor: pointer;
}
.comment-close-button-twitter {
  display: none;
}

.comment-more-button-text,
.comment-close-button-text {
  position: relative;
  font-weight: bold;
  font-size: 15px;
  letter-spacing: 0.2em;
}
.comment-more-button-text::after,
.comment-more-button-text::before,
.comment-close-button-text::after {
  content: "";
  position: absolute;
  top: -3px; bottom: 0;
  right: -16px;
  display: block;
  width: 10px;
  height: 2px;
  margin: auto;
  background: #333333;
}
.comment-more-button-text::before {
  transform: rotate(-90deg);
}
.comment-more {
  display: none;
}
.comment-user .comment-img {
  display: none;
}
.comment-user .comment-text {
  width: 100%;
  padding-left: 0;
}
.comment .comment-mark {
  display: inline-block;
  margin-left: 16px;
  padding: 0 16px;
  border: 1px solid #0e3283;
  border-radius: 18px;
  color: #0e3283;
  font-size: 13px;
}

/* ------------------------------------------------------------------------------
     コメントフォーム
-------------------------------------------------------------------------------*/
.comment-form {
  display: none;
  margin-top: 40px;
  padding: 40px 50px;
  background: #f8f8f8;
}
@media screen and (max-width:767px) {
  .comment-form {
    margin-top: 30px;
    padding: 30px 15px;
  }
}
.comment-form-text {
  font-size: 17px;
  font-weight: bold;
}
.comment-form-text > span {
  margin-left: 30px;
  font-size: 14px;
  font-weight: normal;
}
@media screen and (max-width:767px) {
  .comment-form-text > span {
    margin-left: 15px;
    font-size: 13px;
  }
}
.comment-form-text a {
  color: #0e3283;
}
.comment-form-input {
  margin-top: 16px;
}
@media screen and (max-width:767px) {
  .comment-form-input {
    margin-top: 8px;
  }
}
.comment-form-input + .comment-form-text {
  margin-top: 28px;
}
.comment-form input:not([type="radio"]):not([type="checkbox"]), optgroup, textarea {
  display: block;
  width: 100%;
  padding: 4px 10px;
  background: #fff;
  border: 1px solid #dfdfdf;
}
@media screen and (max-width:767px) {
  .comment-form input:not([type="radio"]):not([type="checkbox"]), optgroup, textarea {
    padding: 10px 10px;
  }
}
.comment-form-button {
  display: block;
  width: 240px;
  margin: 34px auto 0;
  padding: 14px;
  background: #0e3283;
  border-radius: 4px;
  color: #fff;
  text-align: center;
  font-weight: bold;
}

/* ------------------------------------------------------------------------------
     関連記事ボタン
-------------------------------------------------------------------------------*/
.related-article-btn {
  display: block;
  margin: 40px 15px 0px;
  padding: 12px;
  background: #dce5f3;
  border-radius: 8px;
  color: #0e3283;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
}
.related-article-btn:visited,.related-article-btn:active {
  color: #0e3283;
}
.related-article-btn > span {
  position: relative;
}
.related-article-btn > span::after {
  content: "";
  position: absolute;
  top: -5px; bottom: 0;
  right: -20px;
  margin: auto;
  display: block;
  border-bottom: solid 2px #0e3283;
  border-right: solid 2px #0e3283;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
}

/* ------------------------------------------------------------------------------
     コメント下SNSシェアボタン
-------------------------------------------------------------------------------*/
.post-sns-share-btn {
  margin-top: 40px;
}
@media screen and (min-width:768px) {
  .post-sns-share-btn {
    margin-top: 30px;
  }
}
.post-sns-share-btn-list {
  font-size: 0;
}
@media screen and (min-width:768px) {
  .post-sns-share-btn-list > li {
    display: inline-block;
    width: 24.1%;
  }
  .post-sns-share-btn-list > li + li {
    margin-left: 1.2%;
  }
}
@media screen and (max-width:767px) {
  .post-sns-share-btn-list > li {
    display: inline-block;
    width: 49%;
  }
  .post-sns-share-btn-list > li:nth-child(even) {
    margin-left: 2%;
  }
  .post-sns-share-btn-list > li:nth-child(n+3) {
    margin-top: 2%;
  }
}
.post-sns-share-btn-list-user > a {
  display: block;
  background: #0e3283 url(../images/icon_user_03.png) no-repeat left 6px center;
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
}
.post-sns-share-btn-list-user > a > span {
  display: block;
  margin-left: 40px;
  padding: 10px;
  border-left: 1px solid #fff;
  text-align: center;
}
.post-sns-share-btn-list-twitter > a {
  display: block;
  background: #1da1f1 url(../images/icon_twitter_04.png) no-repeat left 6px center;
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
}
.post-sns-share-btn-list-twitter > a > span {
  display: block;
  margin-left: 40px;
  padding: 10px;
  border-left: 1px solid #fff;
  text-align: center;
}
.post-sns-share-btn-list-hatena > a {
  display: block;
  background: #00a5df url(../images/icon_hatena_03.png) no-repeat left 6px center;
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
}
.post-sns-share-btn-list-hatena > a > span {
  display: block;
  margin-left: 40px;
  padding: 10px;
  border-left: 1px solid #fff;
  text-align: center;
}
.post-sns-share-btn-list-facebook > a {
  display: block;
  background: #1a77f2 url(../images/icon_facebook_04.png) no-repeat left 6px center;
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
}
.post-sns-share-btn-list-facebook > a > span {
  display: block;
  margin-left: 40px;
  padding: 10px;
  border-left: 1px solid #fff;
  text-align: center;
}
@media screen and (max-width:370px) {
  .post-sns-share-btn-list > li a {
    font-size: 12px;
  }
}
@media screen and (max-width:335px) {
  .post-sns-share-btn-list > li a {
    font-size: 10px;
  }
}

/* ------------------------------------------------------------------------------
     記者からの追加情報
-------------------------------------------------------------------------------*/
.add-info {
  margin-top: 50px;
}
@media screen and (max-width:767px) {
  .add-info {
    margin-top: 40px;
  }
}
.add-info-title {
  padding-bottom: 5px;
  border-bottom: 1px solid #ccc;
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .add-info-title {
    font-size: 18px;
  }
}
.add-info-dl {
  margin-top: 16px;
  font-size: 0;
}
.add-info-dl > dt {
  display: inline-block;
  width: 14%;
  font-size: 17px;
  font-weight: normal;
  vertical-align: top;
}
@media screen and (max-width:767px) {
  .add-info-dl > dt {
    display: inline-block;
    width: 105px;
    font-size: 16px;
  }
}
.add-info-dl > dd {
  display: inline-block;
  width: calc(100% - 105px);
  font-size: 17px;
  vertical-align: top;
}
@media screen and (max-width:767px) {
  .add-info-dl > dd {
    display: inline-block;
    width: calc(100% - 110px);
    font-size: 17px;
  }
}
.add-info-text {
  margin-top: 10px;
  font-size: 17px;
}

.add-info-text a {
  font-weight: bold;
}

@media screen and (max-width:767px) {
  .add-info-text {
    margin-top: 16px;
    font-size: 16px;
  }
}

@media screen and (max-width:767px) {
  .add-info-text a {
    font-weight: bold;
  }
}

/* ------------------------------------------------------------------------------
     情報提供
-------------------------------------------------------------------------------*/
.post-provision {
  margin-top: 16px;
  font-size: 16px;
}
@media screen and (min-width:768px) {
  .post-provision {
    display: none;
  }
}
.post-provision-link {
  display: block;
  position: relative;
  padding: 0 0 0 40px;
  background: #0e3283 url(../images/icon_pen_04.png) no-repeat left 10px center;
  background-size: 20px;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 1px;
}
.post-provision-link:visited {
  color: #fff;
}
.post-provision-link > span {
  display: inline-block;
  padding: 8px 0 8px 10px;
  border-left: 3px solid #f8f8f8;
}
.post-provision-text {
  margin-top: 15px;
}

/* ------------------------------------------------------------------------------
     左側追従SNSシェアボタン
-------------------------------------------------------------------------------*/
.sns-share-left {
  position: absolute;
  margin-left: -35px;
  text-align: center;
  z-index: 100;
}
/* シェア数が4桁と5桁の場合は、少し左寄せにする */
.sns-share-left.digit4 {
  margin-left: -38px;
}
.sns-share-left.digit5 {
  margin-left: -38px;
}

.sns-share-left.fixed {
  position: fixed;
  top: 20px;
}
.sns-share-left span {
  display: block;
  margin: 6px 0;
  font-size: 12px;
  font-weight: bold;
}
/* シェア数が5桁の場合はフォントを下げる */
.sns-share-left.digit5 span {
  font-size: 9px;
  margin-right: 3px;
}
.sns-share-hatena a {
  color: #00a5df;
}
@media screen and (max-width:767px) {
  .sns-share-hatena a img {
    padding-top: 0;
  }
}
.sns-share-twitter a {
  color: #1da1f1;
}
@media screen and (max-width:767px) {
  .sns-share-twitter a img {
    padding-top: 0;
  }
}
.sns-share-facebook a {
  color: #1a77f2;
}
@media screen and (max-width:767px) {
  .sns-share-facebook a img {
    padding-top: 0;
  }
}
@media screen and (max-width:767px) {
  .sns-share-provision a img {
    padding-top: 0;
  }
}


/* 2022.08.08追加 */
@media screen and (max-width:767px) {
  .sns-share-left {
    display: none;
  }
}


/* ------------------------------------------------------------------------------
     関連記事
-------------------------------------------------------------------------------*/
.related-article-list {
  margin-top: 20px;
}
.related-article-list > li + li {
  margin-top: 14px;
}
.related-article-inner {
  display: flex;
  align-items: center;
  padding: 0px 10px 10px;
}
.related-article-image {
  width: 75px;
  height: auto;
}

.related-article-summary {
  position: relative;
  width: calc(100% - 75px);
  padding-left: 12px;
  margin-top: 10px;
}
.related-article-title {
  font-size: 13px;
  font-weight: bold;
  line-height: 1.4;
}
.related-article-date {
  display: block;
  margin-top: 5px;
  color: #5e6b88;
  font-size: 12px;
}

/* ------------------------------------------------------------------------------
     ランキング
-------------------------------------------------------------------------------*/
.access-ranking-menu-02 {
  margin-top: 20px;
  border: 1px solid #0e3283;
  font-size: 0;
}
.access-ranking-menu-02 > li {
  display: inline-block;
  width: 50%;
  padding: 12px;
  color: #0e3283;
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
}
.access-ranking-menu-02 > li.is-active {
  background: #0e3283;
  color: #fff;
}

.access-ranking-inner img {

}

/* ------------------------------------------------------------------------------
     main
-------------------------------------------------------------------------------*/
.main {
  padding: 25px 20px 40px 40px;
}
@media screen and (max-width:767px) {
  .main {
    padding: 0px 0px 70px;
  }
}
@media screen and (min-width:768px) {
  .main-inner {
    display: flex;
    justify-content: space-between;
    max-width: 1000px;
    margin: 0 auto;
  }
}
.main-contents {
  position: relative;
  max-width: 660px;
}

.top-main-section {
  padding-bottom: 62px;
}

@media screen and (min-width:768px) {
  .side {
    width: 300px;
  }
}

.side > article + article {
  margin-top: 30px;
}

.side-inner {
  margin-top: 20px;
  padding: 20px;
}

/* ------------------------------------------------------------------------------
     画像のキャプションの会員限定gif
-------------------------------------------------------------------------------*/
.kaiin_gif {
  padding-top: 0;
  vertical-align: initial;
}

/* ------------------------------------------------------------------------------
     この先は会員限定です部分のサムネイルのコメント行数調整
-------------------------------------------------------------------------------*/
.post-user-only-img-item > .post-user-only-img-item-comment {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  text-align: left;
}

/* ------------------------------------------------------------------------------
     画像キャプションの格付け表示
-------------------------------------------------------------------------------*/
.contents-item-photo-right td a img {
  padding-top: 0;
  vertical-align: text-top;
}

/* ------------------------------------------------------------------------------
     画像キャプションの会員限定表示
-------------------------------------------------------------------------------*/
.contents-item-photo-right td img {
  padding-top: 0;
}

/* ------------------------------------------------------------------------------
     リード文の<p>タグも1文字下げる
-------------------------------------------------------------------------------*/
section.post-wrap > p:not(.subtitle) {
    text-indent: 1em;
}

/* ------------------------------------------------------------------------------
     記者からの追加情報の会員限定表示
-------------------------------------------------------------------------------*/
.add-info-text .block-comment img {
  padding-top: 0;
  vertical-align: initial;
}
