@charset "utf-8";

/*---------------
記事本文リンク
---------------*/
#column-main p a {
    color: #3086b2;
    text-decoration: underline;
}

/*---------------
記事画像を中央寄せ
---------------*/
.thumbs {
    text-align: center;
}

/*---------------
テキスト調整
---------------*/
#column-main h2.mt40 {
    padding: 0.2em 0;
    border-bottom: solid 3px #e1e8ed;
    background: #fff;
    font-size: 20px;
    font-weight: bold;
}

#column-main h3.mt30 {
    position: relative;
    font-size: 18px;
    padding-left: 20px;
    margin-top: 35px !important;
}
#column-main h3.mt30:before {
    background: #e1e8ed;
    content: '';/*何も入れない*/
    display: inline-block;/*忘れずに！*/
    width: 16px;/*画像の幅*/
    height: 16px;/*画像の高さ*/
    left: 0;
    position: absolute;
    top: 6px;
    left: 0;
}
#column-main div.fs14 {
    margin-top: 15px !important;
}
#column-main div.fs14 p {
    font-size: 16px;
    line-height: 2;
    margin-bottom: 20px;
}
#column-main div.fs14 p strong {
    background:rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ffffbc 0%) repeat scroll 0 0;
}


/*---------------
article
---------------*/
.article_title {
    font-size: 18px;
    font-weight: bold;
}
.thumbsbox .photo {
    width: 180px !important;
    word-wrap : break-word;
    overflow-wrap : break-word;
    font-size: 10px;
}
.thumbsbox .leadtext {
    font-size: 15px;
}


/*---------------
snstool
---------------*/
#snstool ul li {
    background: #fff;
    margin: 0;
    padding: 0;
    margin-right: 10px;
    float: left;
}
#snstool ul li:last-child {
    margin-right: 0;
}


/*---------------
toc（table of contents）
---------------*/
#toc {
    border: 1px solid #e5e5e5;
    padding: 10px 20px;
}
#toc ul.mt15 {
    margin-top: 10px;
}
#toc ul li {
    margin: 0;
    padding: 0;
    margin-bottom: 8px;
    background: #fff;
    font-size: 12px;
    padding-left: 10px !important;
    text-indent: -1.4em !important;
}
#toc ul li span.small_dot {
    font-size:20px !important;
}
#toc p {
    font-size: 14px;
}

/*---------------
blockquote
---------------*/
.blockquote_box {
    padding: 20px;
    background: #f3f3f3 url(/assets/pc/common/img/blockquote_icon.png) no-repeat 2% 9%;
    background-size: 39px 33px;
    font-size: 15px;
}

/*---------------
sns埋め込み箇所
---------------*/
.twitter-tweet, .instagram-media, .facebook, .youtube {
    margin: 30px auto !important;
}
.facebook, .youtube {
    text-align: center;
}
.facebook iframe {

    border-radius: 5px;
}
._4-u2 {
    border-bottom: 1px solid #dddfe1 !important;

    border-radius: 3px;
}


/*---------------
関連リンク
---------------*/
.relationlink {
    background: #f3f3f3;
    padding: 20px;
    line-height: 2
}

/*---------------
参考文献
---------------*/
.reference {
    background: #f3f3f3;
    padding: 20px;
}

/*---------------
商品サムネイル
---------------*/
.itemthumbs {
    border: 1px solid #b3b3b3;
    padding: 20px;
}
.itemthumbs .photo {
    width: 250px !important;
    float: left;
}
.itemthumbs .photo img {
    width: auto;
    height: auto;
    max-width: 100%;
}
.itemthumbs .text {
    width: 335px !important;
    float: left;
    font-size: 15px;
}
#column-main .itemthumbs .cv_btn01 {
    border-style: solid;
    border-width: 2px;
    border-radius: 5px;
    background-color: rgb(77, 77, 77);
    font-size: 20px;
    color: #fff;
    margin-top: 30px;
    text-align: center;
    padding: 10px 0;
}
#column-main .itemthumbs .cv_btn01 a {
    width: 100%;
    color: #fff;
    text-decoration: none;
    background: url(/assets/pc/common/img/searchicon03.png) no-repeat 95% center;
    display: inline-block
}
.itemthumbs .cv_btn01 a:hover {
    text-decoration: none !important
}
.itemthumbs .cv_btn01:hover {
    text-decoration: none !important;
    filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
}

/*---------------
ライターサムネイル
---------------*/
.writer-list {
    border: 1px solid #b3b3b3;
    padding: 20px;
}

.writer-list a:hover {
    text-decoration: underline !important;
}
.writer-list .photo {
    width: 150px !important;
    float: left;
    margin-right: 20px;
}
.writer-list .photo img {
    width: 150px !important;
}
.writer-list .text {
    width: 440px !important;
    float: left;
}
.writer-list .leadtext {
    font-size: 14px !important;
}
.writer-list h3 {
    font-size: 16px;
    font-weight: bold;
    margin-top: 0px !important
}
.writer-list .sns li {
    padding: 0 !important;
    background: #fff !important;
    float: left;
    margin-top: 20px;
    margin-right: 10px;
    border-radius: 5px;
}


/*---------------
記事ページ共通htmlモジュール
---------------*/
.common_module {
    border: 1px solid #b3b3b3;
    padding: 20px;
}
.common_module h3 {
    margin: 0 !important;
}
.common_module .photo {
    width: 200px !important;
}
.common_module .text {
    width: 390px !important;
}
.common_module .leadtext {
    font-size: 14px !important;
}


/*---------------
ページ切り替え
---------------*/
#page_switcher ul li {
    border: none !important;
}
#page_switcher ul li:nth-child(1) {
    margin: 0;
    padding: 0;
    background: #fff;
    width: 300px;
    float: left;
    margin-right: 30px;
}
#page_switcher ul li:nth-child(2) {
    margin: 0;
    padding: 0;
    background: #fff;
    width: 300px;
    float: right;
}
#page_switcher span.left {
    width: 10px;
    display: block;
    float: left;
    font-size: 2em;
    margin-right: 10px;
}
#page_switcher span.right {
    width: 10px;
    display: block;
    float: right;
    font-size: 2em;
    margin-left: 10px;
}


/*---------------
広告エリア
---------------*/
#adarea li {
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
}
#adarea li:nth-child(1){
    float: left;
}
#adarea li:nth-child(2){
    float: right;
}


/*---------------
あなたにおすすめの記事
---------------*/
#recommend-article .inner {
    width: 148px;
    float: left;
    margin-right: 21px;
    margin-bottom: 21px;
}
#recommend-article .inner:last-child {
    margin-right: 0;
}
#recommend-article .inner ul li {
    margin-top: 10px;
}

#adarea li {
    border: none !important
}

/*---------------
追加コンテンツ（楽天カード）
---------------*/
#rcard .ttl {
    font-size: 16px;
    font-weight: bold;
    border-bottom: 4px solid #e5e5e5;
    padding-bottom: 5px;
    margin-bottom: 20px;
}
#rcard .left {
    width: 230px;
    margin-right: 20px;
    float: left;
}
#rcard #brand {
    border: solid 1px #e5e5e5;
    margin-top: 10px;
}
#rcard #brand .ttl {
    font-size: 14px;
    border: none;
    background: #f5f5f5;
    text-align: center;
    padding: 5px 0;
    margin-bottom: 0;
}
#rcard #brand ul {
    padding: 15px 15px 10px;
}
#rcard #brand ul li {
    width: 33%;
    float: left;
    margin-bottom: 5px;
}

#rcard #brand ul li img {
    width: 100%;
}


#rcard .right {
    width: 400px;
    float: left;
}
#rcard .right table {
    width: 405px;
    border: solid 1px #e5e5e5;
    border-collapse: collapse;
}
#rcard .right table th {
    width: 30%;
}
#rcard .right table td {
    width: 70%;
    font-size: 14px;
    padding:10px 15px;
}
#rcard .right table td,
#rcard .right table th {border: solid 1px #e5e5e5}
#rcard .right th {
    background: #edf5fa;
    font-size: 14px;
    padding: 10px 15px;
    text-align: left;
}
#rcard .cv_btn02 {
    width: 345px;
    margin: 0 auto;
    border-style: solid;
    border-width: 2px;
    border-radius: 5px;
    background-color: rgb(90, 173, 216);
    font-size: 20px;
    color: #fff;
    margin-top: 30px;
    text-align: center;
    padding: 10px 0;
    text-decoration: none !important;
}
#rcard .cv_btn02 a {
    width: 100%;
    color: #fff;
    background: url(/assets/pc/common/img/arrow02.png) no-repeat 95% center;
    display: inline-block;
    text-decoration: none !important;
}
#rcard .cv_btn02 a:hover {
    text-decoration: none !important
}
#rcard .cv_btn02:hover {
    text-decoration: none !important;
    filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
}
#rcard .cv_btn03 {
    width: 345px;
    margin: 0 auto;
    border-style: solid;
    border-width: 2px;
    border-radius: 5px;
    background-color: rgb(192, 0, 0);
    font-size: 20px;
    color: #fff;
    margin-top: 10px;
    text-align: center;
    padding: 10px 0;
    text-decoration: none !important;
}
#rcard .cv_btn03 a {
    width: 100%;
    color: #fff;
    background: url(/assets/pc/common/img/arrow02.png) no-repeat 95% center;
    display: inline-block;
    text-decoration: none !important;
}
#rcard .cv_btn03 a:hover {
    text-decoration: none !important
}
#rcard .cv_btn03:hover {
    text-decoration: none !important;
    filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
}

#point {
    background: #ffffda;
    border:1px solid #e5e5e5;
    clear: both;
    margin-top: 20px;
    padding: 15px;
}
#point .ttl {
    font-size: 16px;
    font-weight: bold;
    border: none !important;
    margin-bottom: 0;
}

.thumbnail {
    border:1px solid #e5e5e5;
    padding: 20px;
}

.thumbnail a:hover {
    text-decoration: underline !important;
}
.thumbnail .photo {
    width: 180px !important;
    float: left;
    margin-right: 20px;
}
.thumbnail .text {
    width: 410px !important;
    float: left;
}
.thumbnail .leadtext {
    font-size: 12px !important;
}
.thumbnail h3 {
    font-size: 16px;
    font-weight: bold;
    margin-top: 0px !important
}
.thumbnail img {
    width: 180px;
    height: 125px;
    object-fit:cover;
    font-family: 'object-fit: cover;'
}
.thumbnail:hover {
    filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
    cursor: pointer
}


.rcardbox {
    border:1px solid #e5e5e5;
    padding: 20px;
}

.rcardbox a:hover {
    text-decoration: underline !important;
}
.rcardbox .photo {
    width: 230px !important;
    float: left;
    margin-right: 20px;
}
.rcardbox .text {
    width: 350px !important;
    float: left;
    text-align: center;
    font-size: 15px;
    font-weight: bold;
    padding-top: 16px;
}
.rcardbox .leadtext {
    font-size: 12px !important;
}


/*マーカーアニメーション*/

.marker-animation.active{
    background-position: -100% .7em;
}

.marker-animation {
    background-image: -webkit-linear-gradient(left, transparent 50%, rgb(255,212,0) 50%);
    background-image: -moz-linear-gradient(left, transparent 50%, rgb(255,212,0) 50%);
    background-image: -ms-linear-gradient(left, transparent 50%, rgb(255,212,0) 50%);
    background-image: -o-linear-gradient(left, transparent 50%, rgb(255,212,0) 50%);
    background-image: linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
    background-repeat: repeat-x;
    background-size: 200% .8em;
    background-position: 0 .5em;
    transition: all 2s ease;
    font-weight: bold;
}

/*記事下共通パーツ*/

#article_common .cv_btn03 {
    width: 345px;
    margin: 0 auto;
    border-style: solid;
    border-width: 2px;
    border-radius: 5px;
    background-color: rgb(192, 0, 0);
    font-size: 20px;
    color: #fff;
    margin-top: 10px;
    text-align: center;
    padding: 10px 0;
    text-decoration: none !important;
}
#article_common .cv_btn03 a {
    width: 100%;
    color: #fff;
    display: inline-block;
    text-decoration: none !important;
}
#article_common .cv_btn03 a:hover {
    text-decoration: none !important
}
#article_common .cv_btn03:hover {
    text-decoration: none !important;
    filter:alpha(opacity=70);
    -moz-opacity: 0.7;
    opacity: 0.7;
}