@charset "utf-8";

/*
Theme Name:liquid-magazine-child
Template:liquid-magazine
*/

/*===========================================
 20221110 add original
===========================================*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');

body {
    color: #595656;
    font-size: 16px;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1.5;
}

/* icomoon
--------------------------*/
@font-face {
  font-family: 'icomoon';
  src:  url('fonts/icomoon.eot?b31uur');
  src:  url('fonts/icomoon.eot?b31uur#iefix') format('embedded-opentype'),
    url('fonts/icomoon.ttf?b31uur') format('truetype'),
    url('fonts/icomoon.woff?b31uur') format('woff'),
    url('fonts/icomoon.svg?b31uur#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-rss:before {
  content: "\e908";
  color: #9f9f9f;
}
.icon-popular:before {
  content: "\e900";
  color: #d70a2e;
}
.icon-search:before {
  content: "\e901";
  color: #d7092f;
}
.icon-tag:before {
  content: "\e902";
  color: #9f9f9f;
}
.icon-watch:before {
  content: "\e903";
}
.icon-category:before {
  content: "\e904";
  color: #d70a2e;
}
.icon-mail:before {
  content: "\e905";
  color: #fff;
}
.icon-new:before {
  content: "\e906";
  color: #d70a2e;
}
.icon-outwindow:before {
  content: "\e907";
  color: #9f9f9f;
}

/* common
--------------------------*/
a, a:visited {
    color: #595656;
}
a:hover {
    color: #D7092F;
    text-decoration: none;
}
ul,ol {
    list-style: none;
    margin: 0;
    padding: 0;
}


*:focus {
    border: none;
    outline: none;
}

@media (max-width: 767.98px) {
    .mainarea {
        margin-bottom: 3rem;
    }
}


.ttl {
    font-size: 30px;
    border-bottom: 1px solid #D7092F;
}
.ttl span {
    border: none;
    padding: 0 0 0.3em;
}
.ttl span .icon {
    font-size: 48px;
}
@media (max-width: 767.98px) {
    .ttl {
        font-size: 18px;
    }
    .ttl span .icon {
        font-size: 22px;
    }
}
#main .list {
    margin-bottom: 1rem;
}
.list .post_links {
    border: none;
    border-top: 4px solid #D7092F;
    margin-bottom: 0.5rem;
}
.list .post_links .post_thumb {
    background-size: cover;
}
.list_big .post_links .post_thumb span {
    height: 197px;
}
.list_big .post_ttl {
    line-height: 1.4em;
    height: 4.2em;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    margin-bottom: 0.7rem;
    word-break: break-word;
}
.list .post_links .list-text {
    background: #F3F5F6; 
    padding: 0.7em 0.5em;
}
.list .post_links .list-text .post_ttl {
    /*font-size: 20px;*/
}
.list .post_links .list-category {
    padding: 0.5rem 0;
}
.list-category a {
    display: inline-block;
    margin-bottom: 5px;
}
.post_time {
    color: #595656;
    margin-bottom: .5rem;
}
.post_time, .post_cat {
    font-size: 13px;
}
.post_time .icon {
    color: #000;
    font-size: 16px;
    margin-right: 5px;
    display: inline-block;
    margin-bottom: 2px;
    vertical-align: bottom;
}
.post_cat .icon{
    color: #9F9F9F;
    font-size: 14px;
    margin-right: 5px;
}
@media (max-width: 767.98px) {
    .list .post_links .list-text .post_ttl {
        font-size: 16px;
    }
    .post_time .icon {
        margin-bottom: -1px;
    }
}

/* header
--------------------------*/
.btn-primary:hover {
    background: none;
    border-color: none;
}
.searchform .form-control.search-text {
    border-bottom: 1px solid #707070;
}
.form-control {
    border: none;
    border-radius: 0;
    transition: none;
}
.form-control:focus {
    color: #495057;
    background-color: #fff;
    border: none;
    outline: 0;
    box-shadow: none;
}
.header-wrraper {
    position: relative;
    box-shadow: 0px 11px 12px -18px rgba(0,0,0,0.6);
}
.navbar-nav a {
    color: #707070;
}

.navbar .current-menu-item, .navbar .current-menu-parent, .navbar .current_page_item {
    font-weight: normal;
}




@media (min-width: 768px) {/*PC*/

    .logo img {
        height: 55px!important;
    }
    .headline {
        box-shadow: none;
    }
    .header-wrapper {
        position: relative;
    }
    .logo-wrapper {
        text-align: center;
        margin-bottom: 10px;
    }
    .header-text {
        margin-top: 10px; 
    }
    .logo-wrapper .header-text a {
        text-decoration: none; 
        color: #000 ;
        font-size: 16px;
    }
    .logo-wrapper .header-text a:hover {
        text-decoration: underline ; 
        color: #000000 ; 
    }
    .headline {
        padding: 1.4rem 0 0;
    }
    .searchform_nav {
        display: block;
        position: absolute;
        right:  17px;
        top: 44px;
    }
    .searchform_nav .form-group {
        width: 265px;   
    }
     /* .searchform .search-text {
        padding-left: 60px;
    }    */
    .navbar {
        padding: .5rem 0 0;
    }
    .navbar-expand-md .navbar-nav {
        justify-content: center;
        width: 100%;
    }
    .navbar li {
        padding: 0.5rem 1rem;
    }
    .navbar-nav a {
        display: inline-block;
        font-size: 15px;
        position: relative;
        transition: 0.3s;
        padding:0 0 0.3rem;
    }
    .navbar-nav a:hover {
        opacity: 0.7;
    }
    .navbar-nav .current-menu-item a {
        font-weight: normal;
    }
    .navbar-nav .current-menu-item a:after/*, .navbar-nav .current-post-parent a:after*/ {
        content:'';
        display: block;
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 2px;
        background: #D7092F;
    }
    .searchform .btn {
        left: auto;
        right:  0px;
        transition:  0.3s;
        background: #fff;
        -webkit-tap-highlight-color:rgba(0,0,0,0);
        outline: none;

    }
    .searchform .btn:focus {
      outline: none;
    }
    .searchform .btn .icon {
        transition: 0.3s;
    }
    .searchform .btn:hover .icon:before {
        color: #E2526C;
    }
    .searchform .btn .icon {
        font-size: 30px;
    }
}


@media (max-width: 992px) and (min-width: 768px){
    /* .searchform .search-text {
        padding-left: 50px;
    }  */
    .searchform_nav .form-group {
        width: 200px;   
    }
     .searchform .btn .icon {
        font-size: 22px;
    }
}

@media (max-width: 767.98px) {
    .navbar {
        padding:  0;
    }
    .navbar-light .navbar-toggler {
        border:  none;
    }
    .navbar .navbar-search {
        outline:  none;
    }
    .searchform .btn {
        top: 0;
    }
    .head-open .navbar li {
        padding:  0 1rem;
    }
}

/* breadcrumb
--------------------------*/
.breadcrumb {
    box-sizing: border-box;
    display: flex;
    flex-wrap: wrap;
    padding: 10px 0;
    background: none;
    /* box-shadow: none; */
    border: none;
    border-bottom: none !important;
    max-width: 100%; 
    /* margin-top: 0 !important; */
    /* margin: 0 auto; */
}
.breadcrumb .separator {
    color: #ff0000; 
    padding: 0 5px; 
}
.breadcrumb-item {
    margin-right: 5px;
}
.breadcrumb-item a {
    color: #000000;
}
.breadcrumb-item a:hover {
    text-decoration: underline !important; 
    color: #000000 ;
}
.breadcrumb-item.active a {
    color: #6b6b6b;
}

/* footer
--------------------------*/
footer {
    background: #000;
    margin-top: 6rem;
    padding-top: 1.5rem;
    padding-bottom: 0;
}
footer, footer a {
    color: #9F9F9F;
}
footer a:visited {
    color: #9F9F9F;
}
footer a:hover {
    color: #fff;
}
footer a img {
    transition: 0.3s;
}
footer a:hover img {
    opacity:  0.7;
}
.footer-logo {
    margin-bottom: 1rem;
    text-align: center;
}
.footer-logo span {
    font-size: 18px;
    font-weight: bold;
    position: relative;
}
.footer-logo span:before {
    content: '';
    display: block;
    width: 43px;
    height:  26px;
    background: url('images/icn_footerlogo.png') no-repeat left top /cover;
    position: absolute;
    left: -48px;
    top: 0;
}
@media (min-width: 768px) {/*PC*/
    .footer-menu {
        display: flex;
        flex-wrap: wrap;
        max-width: 720px; /*655px;*/
        margin: 0 auto;
    }
    .footer-menu li {
        width: 47%;
    }
    .footer-menu li:nth-child(2n) {
        margin-left: 6%
    }
}
.footer-menu {
    margin-bottom: 1.6rem;
}
.footer-menu li {
    margin-bottom: 0.5rem;
}
.footer-menu li .icon {
    margin-left: 0.2rem;
    font-size: 13px;
}

@media (min-width: 768px) {/*PC*/
    .footer-utility {
        display: flex;
        justify-content: space-between;
    }
    .footer-utility-list {
        display: flex;
        flex-wrap:  wrap;
    }
    .footer-utility-list li {
        margin-left: 2rem;
    }
}

.footer-utility {
    border-bottom:  1px solid #707070;
    padding-bottom: 0.4rem;
}
.footer-utility-list li {
    font-size: 15px;    
}
.footer-utility-list li .icon {
    margin-left: 0.3rem;
    font-size: 13px;
}

.footer-utility-list li .icon.icon-rss {
    font-size: 16px;
    margin-left: 0;
    margin-right: 0.3rem;
}

.footer-utility_sns {
    display: flex;
}
.footer-utility_sns li {
    margin-left: 0.7rem;
}
.footer-utility_sns li img {
    vertical-align: top;
}
.footer-utility-list li:first-child, .footer-utility_sns li:first-child {
    margin-left: 0;
}
.copy {
    padding: 1rem 2rem;
}
.copy-text {
    color: #9F9F9F;
    font-size: 12px;
    margin:  0;
}
.pagetop a {
    height:  3.7rem;
    width: 3.7rem;
    line-height: 1;
    transition: 0.3s;
}
.pagetop a:hover {
    opacity: 0.7;
}

.pagetop.foot {
    position: relative;
}
.pagetop.foot a {
    position: absolute;
    bottom: -60px;
}

@media (max-width: 767.98px) {
    .footer-menu li {
        text-align: center;
        font-size: 12px;
    }
    .footer-utility {
        padding-bottom: 1.8rem;
    }
    .footer-utility-list {
        margin-bottom: 1.6rem;
    }
    .footer-utility-list li {
        text-align: center;
        font-size: 12px;
        margin-bottom: 0.4rem
    }
    .footer-utility_sns {
        justify-content: center;
    }
    .pagetop a {
        height:  2.4rem;
        width: 2.4rem;
        line-height: 1;
    }
}

/* sidebar
--------------------------*/
.sidebar-inner {
    background: none;
    padding: 0;
}

.sidebar .widget {
    background: #F3F5F6;
    padding:  0 0.5rem;
    margin-bottom: 0;
}

.sidebar .widget_block {
    border-top: 6px solid #D7092F;
    margin-bottom: 0.5rem;
}
.sidebar .widget h2 {
    border-bottom: none;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 0.5em;
}
.widget ul li {
    border-bottom: none;
}
.sidebar .widget ul li a {
    padding: 0;
}

.sidebar .widget.popular-posts {
    padding-bottom: 1rem;
}
.sidebar .widget.popular-posts .popularpost-ttl {
    text-align: left;
    border-bottom: 1px solid #d70a2e;
    padding: 0.5rem 0 0.2rem;
    margin-bottom: 0.4rem;
}
.sidebar .widget.popular-posts .popularpost-ttl span:before {
    font-family: 'icomoon' !important;
      speak: never;
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      line-height: 1;

      /* Better Font Rendering =========== */
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    content: "\e900";
    color: #d70a2e;
    font-size: 30px;
    margin-right: 0.5rem;
    vertical-align: sub;
}

.popular-posts .wpp-list li {
    margin-bottom: 0.5rem;
    padding-bottom: 0.2rem;
    border-bottom:  1px dashed #9F9F9F;
    padding: 0.5rem 0;
}
.popular-posts .wpp-list li img {
    height: 50px;
    width: 90px;
    object-fit: cover;
}
.popular-posts .wpp-list li a {
    padding: 0.5rem 0;
}
.popular-posts .wpp-list li a:first-of-type {
    width: 90px;
}
.popular-posts .wpp-list li .wpp-post-title {
    text-decoration: underline;
    overflow: hidden;
    line-height: 1.4em;
    /*height: 2.8em;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    overflow: hidden;
    box-orient: vertical;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    display: -webkit-box;*/
}
.sidebar-contact h2 span {
    display: inline-block;
}
.sidebar-contact ul {
    padding-bottom: 0.5rem;
}
.sidebar-contact ul li {
    margin-bottom: 1.2rem;
    text-align: center;
}
.sidebar-contact ul li img {
    width: 100%;
    max-width: 286px;
}

@media (min-width: 768px) {/*PC*/
    .popular-posts .wpp-list li a, .popular-posts .wpp-list li a img {
        transition: 0.3s;
    }
    .popular-posts .wpp-list li a:hover {
        background: none;
    }
    .popular-posts .wpp-list li a:hover img {
        opacity: 0.7;
    }
    .sidebar-contact ul li a {
        border-radius: 10px;
        display: inline-block;
    }
    .sidebar-contact ul li:nth-child(1) a{
        background-image: url(images/btn_contact01_hv.png);
        background-size: cover;
    }
    .sidebar-contact ul li:nth-child(2) a{
        background-image: url(images/btn_contact02_hv.png);
        background-size: cover;
    }

    .sidebar-contact ul li a:hover {
        opacity: 1;
    }
    .sidebar-contact ul li a:hover img {
        opacity: 0;
    }
}

@media (max-width: 992px) and (min-width: 768px){
     .popular-posts .wpp-list li .wpp-post-title {
        font-size: 12px
     }
}

@media (max-width: 767.98px) {
   .popular-posts .popularpost-ttl {
        font-size: 16px;
    }
    .popular-posts .wpp-list li .wpp-post-title{
        font-size: 13px;
    }
}
.post_body h1 > span, .post_body h2 > span, .widget h1 > span, .widget h2 > span {
    border-bottom: none;
}

/* index
--------------------------*/
.hero {
    background: url("images/bg_hero.png") no-repeat center bottom /cover;
    height: 300px;
}

.index-hero {
    padding-left: 9px;
    padding-top: 30px;
}
.index-hero-ttl {
    color: #fff;
    font-size: 55px;
    font-weight: bold;
    margin-bottom: 16px;
}
.index-hero-txt {
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.6;
}
@media (max-width: 767.98px) {
    .hero {
        height: 200px;
    }
    .index-hero {
        padding-top: 30px;
    }
    .index-hero-ttl {
        font-size: 23px;
        text-shadow: 0px 0px 3px rgba(0,0,0,0.8);
    }
    .index-hero-txt {
        font-size: 16px;
        line-height: 1.7;
        text-shadow: 0px 0px 3px rgba(0,0,0,0.8);
    }
}

@media (min-width: 768px) {/*PC*/
    .mainpost {
        margin-top: 5.2rem;
    }
}


/* archive
--------------------------*/
.detail {
    padding-top: 5rem;
}
@media (max-width: 575.98px) {
    .detail {
        padding-top: 2rem;
    }
}
.archive .ttl_h1 {
    border-bottom: 0;
    letter-spacing: -1.7px;
    margin-bottom: 0.8rem;
    position: relative;
    padding-left: 55px;
}
.archive .ttl_h1 .icon {
    font-size: 45px;
    position: absolute;
    left: 0;
    top: 0;
}
.cat_info {
    margin-bottom: 2rem;
}

@media (max-width: 767.98px) {
    .archive .ttl_h1 {
        font-size: 20px;
        padding-left: 30px;
        letter-spacing: 0;
    }
    .archive .ttl_h1 .icon {
        font-size: 24px;
    }
}

/* author
--------------------------*/
.ttl_h1.m-author {
    border-top: 1px solid #707070;
    border-bottom: 1px solid #707070;
    font-size: 20px;
    padding: 0.5rem 0 0.5em 23px;
    letter-spacing: 0;
    margin-bottom: 3.2rem;
    position: relative;
}
.ttl_h1.m-author:before {
    content: '';
    display: block;
    height: calc(100% - 12px);
    width: 11px;
    background: #D7092F;
    position: absolute;
    left: 0;
    top: 6px;
}
.archive .authorbox .fn {
    font-weight: bold;
    font-size: 20px;
    margin-top: 0.6rem;
}


/* search
--------------------------*/
.ttl_h1.m-search {
    border-top: 1px solid #707070;
    border-bottom: 1px solid #707070;
    font-size: 20px;
    padding: 0.5rem 0 0.5em 23px;
    letter-spacing: 0;
    margin-bottom: 2.2rem;
    position: relative;
}
.ttl_h1.m-search:before {
    content: '';
    display: block;
    height: calc(100% - 12px);
    width: 11px;
    background: #D7092F;
    position: absolute;
    left: 0;
    top: 6px;
}
.ttl_h2.m-search {
    font-size: 30px;
    font-weight: bold;
    margin: 0 0 2rem;
}

/* single
--------------------------*/
.ttl_h1.entry-title {
    font-size: 30px;
    line-height: 1.6;
    margin-bottom: 1.6rem;
}
@media (max-width: 767.98px) {
    .ttl_h1.entry-title {
        font-size: 20px;
        margin-bottom: 0.6rem;
    }
}
.list-category.entry-cat {
    margin-bottom: 1rem;
}

.attachment-post-thumbnail, .ttl_h1 + img {
    margin-bottom: 3rem;
    max-height: 386px;
    width: 100%;
    object-fit: cover;
}

.authorbox {
    background: #F3F5F6;
    border: none;
    border-top: 1px solid #D7092F;
    margin: 1.7rem 0 3.4rem;
    padding: 1.2em;
}
.authorbox .avatar {
    border: none;
    width: 118px;
    height: 118px;
}
.authorttl {
    border: none;
    font-size: 14px;
    font-weight: normal;
    margin: 0 0 0.2rem;
}
.authorbox .clearfix {
    padding-left: 150px;
}
@media (max-width: 767.98px) {
    .authorbox .clearfix {
        padding-left: 0;
        text-align: center;
    }
}
.authorbox .prof {
    margin-top: 0.8rem;
    padding-top: 0.7rem;
    border-top: 1px solid #9F9F9F;
    line-height: 1.8;
}

@media (max-width: 767.98px) {
    .authorbox .float-left {
        float: none!important;
        text-align: center;
    }
    .authorbox .prof {
        text-align: left;
    }
}

.share {
    margin-bottom: 2.8rem;
    text-align: center;
}
.share a {
    width: 32px;
    height: 32px;
    padding: 0;
    margin-right: 0.6rem;
}
.share a img {
    height: 100%;
    width: 100%;
}


.recommend {
    background: #F3F5F6;
    padding: 0 1rem 0.4rem;
}
.recommend .ttl {
    position: relative;
    text-align: center;
    padding: 1.2rem 0 0;
    border-bottom: 0;
    margin: 0 0 0.7rem;
}
.recommend .ttl:before {
    content: '';
    display: block;
    width: 128px;
    height: 5px;
    background: #D7092F;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: 0 auto;
}
.recommend .list .post_links {
    border: 1px solid #D9D9D9;
    margin-bottom: 1.2rem;
    transition: 0.3s;
}
.recommend .list .post_links .list-text {
    border-left: 4px solid #D7092F;
    background: #fff;
    transition: 0.3s;
    padding: 0.9em 1em;
}
@media (min-width: 768px) {/*PC*/
    .recommend .list .post_links:hover .list-text {
        background: #f1f1f1;
    }
}
.recommend .list .post_links .list-text .post_ttl {
    line-height: 1.4;
}
.recommend .list .post_links .list-block {
    width: 100%;
}

.pagination {
    margin-top: 4.2rem;
}

.pagination li>a, .pagination li>span {
    border:none;
}
.pagination li>a {
    position: relative;
    padding: 0;
    margin: 0;
}
.pagination li>a:hover {
    background: none;
}
.pagination li>a.m-prev, .pagination li>a.m-next {
    color: #D7092F;
    transition: 0.3s;
}
.pagination li>a.m-prev {
    padding-left: 26px;
}
.pagination li>a.m-next {
    padding-right: 26px;
}
.pagination li>a.m-prev:before, .pagination li>a.m-next:before {
    content: '';
    display: block;
    background: url(images/icn_pagenation.png) no-repeat left top /cover;
    width: 21px;
    height: 21px;
    position: absolute;
    top: 50%;
}
.pagination li>a.m-prev:before {
    left: 0;    
    transform: translateY(-50%);
}
.pagination li>a.m-next:before {
    right: 0;
    transform: translateY(-50%) rotate(180deg);
}
.pagination li>a.m-prev:hover, .pagination li>a.m-next:hover {
    opacity: 0.6;
}


@media (max-width: 767.98px) {
    .pagination {
        margin-top: 1.8rem;
    }
}

/* page
--------------------------*/
.page .ttl_h1 {
    font-size: 30px;
    margin-bottom: 2.6rem;
}
@media (max-width: 767.98px) {
    .page .ttl_h1 {
        font-size: 24px;
    }
}
.post_meta {
    margin-bottom: 0;
}

/* parts
--------------------------*/
.post_body *:first-child {
    margin-top: 0;
}
.post_body h1 > span, .post_body h2 > span{
    padding: 0;
}

/*区切り赤ライン*/
.post_body hr, .widget hr {
    background: #D7092F;
    margin: 2rem 0;
}


.post_body * {
    word-break: break-word;
}

/*見出し*/

.post_body h2{
    border-bottom: 1px solid #707070;
    font-size: 24px;
    padding-bottom: 0.5rem;
    margin-top: 4rem;
    margin-bottom: 1.3rem;
}
.post_body h3 {
    font-size: 20px;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
}

.post_body h2 + h3 {
    margin-top: 1rem;
}

.post_body h4 {
    font-size: 18px;
}


@media (max-width: 767.98px) {
    .post_body h2{
        margin-top: 2rem;
        font-size: 20px;
    }
    .post_body h3 {
        margin-top: 2rem;
        font-size: 18px;
    }
}
/*本文*/
.post_body p {
    margin-bottom: 0.8rem;
    line-height: 1.9;
}
.post_body p + p {
    margin-top: 0!important;
}
.post_body .mbL {
    margin-bottom: 2rem!important;
 }   

/*ハイライト*/
.post_body .marker {
    font-weight: bold;
    background:linear-gradient(transparent 20%, #FFF500 20%);
}
/*別窓*/
.post_body .outlink {
    display: inline-block;
    padding-right: 1rem;
    position: relative;
}
.post_body .outlink:after {
    content: '';
    display: block;
    background: url(images/icn_outlink.svg) no-repeat left top /cover;
    width: 13px;
    height: 13px;
    position: absolute;
    right: 0;
    top: 10px;
}

/*図のキャプション*/
.post_body p.wp-caption-text {
    margin-top: 0.4rem;
}

/*二列*/
@media (min-width: 768px) {/*PC*/
    .post_body .colwrap {
        display: flex;
    }
    .post_body .colwrap .col {
        margin-right: 2%;
        width: 49%;
    }
    .post_body .colwrap .col + .col {
        margin-right: 0;
    }
}

/*ポイント*/
.post_body .point_unit {
    border-left: 6px solid #D9D9D9;
    padding-left: 1rem;
    margin-bottom: 2.6rem;
}
.post_body .point_ttl {
    color: #D7092F;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 0;
}
@media (max-width: 767.98px) {
    .post_body .point_ttl {
        font-size: 18px;
    }
}
.post_body .point_ttl + p {
    margin: 0;
}
.post_body .point_unit p {
   line-height: 1.8; 
}

/*箇条書き*/
.post_body ul {
    margin: 1rem 0 1rem 1.8rem;
}
.post_body ul li {
    line-height: 1.9;
    position: relative;
    padding-left: 15px;
}
.post_body ul li:before {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    background: #595656;
    border-radius: 10px;
    position: absolute;
    left: 0;
    top: 13px;
}

/*数字付きリスト*/
.post_body ol {
    margin: 1rem 0 1rem 1.8rem;
    counter-reset: item;
}
.post_body ol li {
    position: relative;
    padding-left: 2.5rem;
    line-height: 1.9;
}
.post_body ol li:before {
    counter-increment: item;
    content: counter(item)'.';
    position: absolute;
    left: 0.5rem;
    top: -2px;
    font-size: 18px;
}
.post_body ol li ol {
    margin: .6rem 0 1rem;
}

@media (max-width: 767.98px) {
    .post_body ol, .post_body ul {
        font-size: 15px;
    }
}


/*目次*/
.detail_index {
    margin: 5rem 0;
}
.detail_index_ttl {
    background: #EDEDED;
    font-size: 20px;
    font-weight: bold;
    padding: 0 .5rem;
}
.detail_index ol {
    margin: 0;
}
.detail_index ol li{
    margin-bottom: .5rem;
    padding-left: 2.5rem;
}
.detail_index ol li a {
    text-decoration: none;
}
.detail_index ol li:before {
   color: #D7092F;
   font-weight: bold;
}

/*画像とテキストのセット*/

.detail_imgbox {
    display: flex;
    margin-bottom: .5rem;
}
.detail_imgbox img {
    width: 150px;
    height: 150px;
    object-fit: cover;
    margin: 0 1.5rem 0 0;
}
.detail_imgbox p {
    margin-bottom: .5rem;
}
.detail_imgbox.m-right {
    flex-direction: row-reverse;
}
.detail_imgbox.m-right img {
    margin: 0 0 0 1.5rem;
}

@media (max-width: 767.98px) {
    .detail_imgbox {
        display: block;
        text-align: center;
    }
    .detail_imgbox p {
        text-align: left;
    }
    .detail_imgbox img, .detail_imgbox.m-right img {
        margin: 0 0 .5rem;
    }
}

/*table*/
.table-bordered {
    border-right: none;
    border-left: none;
}
.table-bordered td, .table-bordered th {
    border-color: #9F9F9F;
}
.table-bordered td:first-child, .table-bordered th:first-child {
    border-left: none;
}
.table-bordered td:last-child, .table-bordered th:last-child {
    border-right: none;
}

.post_body table {
    margin: 1rem 0;
}
.post_body table th, .post_body table td {
    padding: .2rem .6rem;
    text-align: center;
}
.post_body table th {
    background: #EDEDED;
}
.post_body .table_caption {
    font-size: 14px;
    margin-top: -0.5rem;
}

@media (max-width: 767.98px) {
    .post_body table th, .post_body table td {
        font-size: 12px
    }
}

/*囲み*/
.post_body .border01 {
    border: 2px solid #D9D9D9;
    border-radius: 10px;
    padding: 1.4rem;
}
.post_body .border02 {
    background: #F3F5F6;
    border: 2px solid #D9D9D9;
    border-radius: 10px;
    padding: 1.4rem;
}
/*特集囲み*/
.post_body .feature_box {
    border: 1px solid #D7092F;
    border-radius: 10px;
    position: relative;
    padding: 0.7rem 1rem 0.7rem 6.5rem;
}
.post_body .feature_box_icn {
    background: #D7092F;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    position: absolute;
    left: 0;
    top: 1rem;
    padding: 1.3rem 1.4rem;
    border-radius: 0 12px 12px 0;
}
.post_body .feature_box_ttl {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 0rem;
}
.post_body .feature_box_txt {
    line-height: 1.7;
    margin-bottom: 0;
} 

@media (max-width: 767.98px) {
    .post_body .feature_box_txt {
        font-size: 13px;
    }
}

/*吹きだし*/
.fukidashi_wrap {
    display: flex;
    flex-wrap: wrap;
}
.fukidashi_img {
    width: 92px;
}
.fukidashi_txt {
    flex: 1;
    margin-left: 1.6rem;
    background: #F3F5F6;
    border: 2px solid #D9D9D9;
    border-radius: 10px;
    padding: 1rem;
    position: relative;
    max-width: 426px;
}
.fukidashi_txt:before {
    content: '';
    display: block;
    background: url(images/icn_fukidashi.png) no-repeat left top /cover;
    width: 21px;
    height: 23px;
    position: absolute;
    left: -21px;
    top: 28px;
}
.fukidashi_txt:after { 
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 17px 10px 0;
    border-color: transparent #f3f5f6 transparent transparent;
    position: absolute;
    left: -15px;
    top: 30px;
    z-index: 2;
}
.post_body .fukidashi_txt p {
    margin-bottom: 0;
    line-height: 1.7;
}

.fukidashi_wrap.m-right {
    flex-direction: row-reverse;
}
.fukidashi_wrap.m-right .fukidashi_txt {
    margin-left: 0;
    margin-right: 1.6rem;
}
.fukidashi_wrap.m-right .fukidashi_txt:before {
    left: auto;
    right: -21px;
    transform: rotate(180deg);
}
.fukidashi_wrap.m-right .fukidashi_txt:after {
    left: auto;
    right: -15px;
    transform: rotate(180deg);
    top: 29px;
}

@media (max-width: 767.98px) {
    .post_body .fukidashi_txt p {
        font-size: 13px;
    }
}

/*引用*/
.post_body blockquote:before{
    content: '”';
    font-size: 30px;
}


/*その他汎用*/
.tal {
    text-align: left!important;
}
.tac {
    text-align: center!important;
}
.tar {
    text-align: right!important;
}

.mt0 {margin-top: 0px!important;}
.mt10 {margin-top: 10px!important;}
.mt20 {margin-top: 20px!important;}
.mt30 {margin-top: 30px!important;}
.mt40 {margin-top: 40px!important;}
.mt50 {margin-top: 50px!important;}
.mt60 {margin-top: 60px!important;}
.mt70 {margin-top: 70px!important;}
.mt80 {margin-top: 80px!important;}
.mt90 {margin-top: 90px!important;}
.mt100 {margin-top: 100px!important;}

.mb0 {margin-bottom: 0px!important;}
.mb10 {margin-bottom: 10px!important;}
.mb20 {margin-bottom: 20px!important;}
.mb30 {margin-bottom: 30px!important;}
.mb40 {margin-bottom: 40px!important;}
.mb50 {margin-bottom: 50px!important;}
.mb60 {margin-bottom: 60px!important;}
.mb70 {margin-bottom: 70px!important;}
.mb80 {margin-bottom: 80px!important;}
.mb90 {margin-bottom: 90px!important;}
.mb100 {margin-bottom: 100px!important;}


/*sidebar トップのみ上揃え*/
@media (min-width: 768px) {
    .home .sidebar {
        margin-top: 58px;
    }
}

/*header 固定*/
.js-header {/*header-wrraper*/
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #fff;
    z-index: 999;
}
