@charset "utf-8";

/*==============================================================================
 * 記事詳細
 *----------------------------------------------------------------------------*/
/* ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■  default (スマホ用スタイル)                                         ■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ */

/*==============================================================================
 * 記事本文
 *----------------------------------------------------------------------------*/

a {text-decoration: none; color: #333;}

/* 文字サイズ */
.detail_page {font-size: 16px;}
.detail_page h1 {font-size: 1.45em;}
.article_detail h1 {font-size: 1.3em;}
.article_detail h2 {font-size: 1.1em;}
.article_detail h3 {font-size: 1em;}

.next_page_link {
    margin-top: 20px;
}
.next_page_link a {
    font-weight: bold;
}

.detail_page {
    padding: 10px;
}
.page_title {
    padding: 0 0 10px;
    margin-bottom: 10px;
    border-style: solid;
    border-color: transparent transparent #444;
    border-width: 0px 0 2px;
    word-wrap: break-word;
}
.page_title .article_date {
    margin: 3px 0;
    color: #777;
    font-size: 0.9em;
}
.page_title .tag {
    font-size: 1em;
}
.page_title .tag a {
    color: #333;
    font-size: 12px;
}
.detail_page h1 {
    font-weight: bold;
    line-height: 1.4em;
}
.article_detail {
    line-height: 1.4em;
}
.article_detail h1,
.article_detail h2,
.article_detail h3 {
    display: table-cell;
    vertical-align: top;
    padding: 0;
    word-wrap: break-word ;
}
.article_detail h1 {
    position: relative;
    padding-left: 20px;
}
.article_detail h1:before {
    content: '';
    position: absolute;
    width: 10px;
    top: 0px;
    left: 0px;
    bottom: 3px;
    background: #444;
}
.article_detail h2 {
    padding-left: 25px;
    font-weight: bold;
    position: relative;
}
.article_detail h2:before {
    content: '';
    width: 7px;
    height: 1em;
    background: #555;
    display: inline-block;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 5;
}
.article_detail h2:after {
    content: '';
    width: 7px;
    height: 1em;
    background: #ddd;
    display: inline-block;
    position: absolute;
    left: 7px;
    top: 0px;
}

.article_detail h3 {
    font-weight: bold;
    color: #555;
}

.single-image.right,
.double-image.right,
.single-image.left,
.double-image.left {
    width: 50%;
    position: relative;
}
.article_detail .top {
    width: 100%;
    position: relative;
    margin-bottom: 20px;
}
.article_detail .single-image.top img.protectImg {
    max-width: 100%;
    margin-right: 10px;
}
.article_detail .double-image.top {
    position: relative;
}
.article_detail .double-image.top div.image-container {
    float:left;
    max-width:50%;
}
.article_detail .double-image.top img.protectImg {
    max-width: calc(100% - 5px);
}
.article_detail .double-image.top img.protectImg:last-child {
    margin-left: 10px;
}
.single-image.right img.protectImg,
.double-image.right img.protectImg,
.single-image.left img.protectImg,
.double-image.left img.protectImg {
    float: left;
    max-width: 100%;
    margin-bottom: 5px;
}
.single-image.right,
.double-image.right {
    float: right;
    margin-left: 20px;
}
.single-image.left,
.double-image.left {
    float: left;
    margin-right: 20px;
}
.single-image.right .image-container .image-alt,
.double-image.right .image-container .image-alt,
.single-image.left .image-container .image-alt,
.double-image.left .image-container .image-alt {
    clear: both;
}
.image-alt {
    font-size: 12px;
}
.sns_btns {
    margin-bottom: 20px;
}
.detail_pager {
    margin: 20px 0;
}
.detail_pager span {
    width: 40px;
    height: 40px;
    text-align: center;
    line-height: 42px;
    color: #fff;
    font-weight: bold;
    background: #999;
    display: inline-block;
}
.detail_pager span a {
    color: #fff;
    font-weight: bold;
    width: 100%;
    height: 100%;
    display: block;
}
.detail_pager span.current {
    background: #666;
}
.article_detail ol {
    list-style: decimal;
    padding-left: 40px;
}
.article_detail ul {
    list-style: disc;
    padding-left: 40px;
}
.article_detail em {
    font-family: "ＭＳ ゴシック",sans-serif;
    font-style: italic;
}
.private_page {
    text-align: center;
    font-size: 1.4em;
    color: #aaa;
    padding-top: 140px;
    margin-bottom: 30px;
    background: url('../img/bg_private.png') no-repeat center center;
    background-size: 70px;
}
.private_page + .a_center {
    padding: 0 10px 20px;
}
.enou_detail .page_title {
    border: none;
    padding: 0;
}
.enou_detail .page_title h1 {
    font-size: 16px;
}
.enou_detail_table {
    margin-bottom: 20px;
    width: 100%;
}
.enou_detail_table a {
    color: #555;
    font-weight: bold;
    text-decoration: underline;
}
.enou_detail_table th {
    width: 100px;
    font-weight: normal;
    text-align: left;
    background: #eee;
}
.enou_detail_table th.first_th {
    border-top: 3px solid #333;
}
.enou_detail_table td.first_td {
    border-top: 3px solid #333;
}
.enou_detail_table td,
.enou_detail_table th {
    border: 1px solid #ddd;
    border-width: 1px 0;
    padding: 5px 10px;
    font-size: 14px;
}
.no_list {
    border-top: 1px solid #DDD;
    padding: 15px 10px;
    font-size: 14px;
}


/* snsボタン */
.socialbtn {
    overflow: hidden;
}
.socialbtn li {
    float: left;
    margin-right: 15px;
    list-style-type:none;
    margin-bottom: 5px;
    height: 25px;
}
.sns_google,
.sns_fb {
    margin-right: 3px !important;
}
.socialbtn iframe {
margin: 0 !important;
}
#___plusone_0 {
width:70px !important;
}
li.sns_fb {
    width: 95px;
}

/* Youtube対応 */
.movie-wrap {
     position: relative;
     padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
     height: 0;
     overflow: hidden;
}

.movie-wrap iframe {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
}



/* ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■  画面幅640px以上のスタイル                                          ■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ */
@media screen and (min-width:640px) {
    /* 文字サイズ */
    .detail_page {font-size: 16px;}
    .detail_page h1 {font-size: 1.75em;}
    .article_detail h1 {font-size: 1.5em;}
    .article_detail h2 {font-size: 1.125em;}
    .article_detail h3 {font-size: 1em;}

    .page_title {
        padding: 20px 0 10px;
        margin-bottom: 10px;
        border-style: solid;
        border-color: #444 transparent #ddd;
        border-width: 3px 0 1px;
        word-wrap: break-word;
    }
}











/* ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■  画面幅950px以上のスタイル                                          ■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ */
@media screen and (min-width:950px) {
    .detail_page {
        padding: 0px;
    }
}
