@charset "UTF-8";

/*
 このCSSに定義するセレクタは、接頭辞「ad-」をつける
 */


/* 先生ページヘのリンク 一時的に非リンクに */

.ad-teacher-link {
    cursor: default;
    pointer-events: none;
}

.ad-teacher-link:after {
    content: none;
}

.ad-noarticle {
    padding: 100px 0;
    text-align: center;
}

.youtube {
    padding-top: 56.25%;
    position: relative;
    width: 100%;
}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}


/* common
--------------------------------------------------*/

.benesse-header,
.benesse-footer {
    background-color: #fff;
    color: #000;
    font: 12px/1.231 "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
}

.benesse-header a,
.benesse-footer a {
    color: #0070cb;
    text-decoration: underline;
}

.benesse-header__inner,
.benesse-footer__inner {
    margin-right: auto;
    margin-left: auto;
    max-width: 1060px;
    /* 950px - 12px * 2 */
    padding: 12px;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    *zoom: 1;
    /* IE6,7 */
}


/* Clearfix */

.benesse-header__inner:before,
.benesse-header__inner:after,
.benesse-footer__inner:before,
.benesse-footer__inner:after {
    content: "";
    display: block;
    overflow: hidden;
}

.benesse-header__inner:after,
.benesse-footer__inner:after {
    clear: both;
}

.benesse-header__link,
.benesse-footer__link {
    margin: 0 0 0 -12px;
    padding: 0;
    list-style-type: none;
}

.benesse-header__link li,
.benesse-footer__link li {
    display: inline;
    margin-left: 12px;
}

.benesse-header__link a,
.benesse-footer__link a {
    display: inline-block;
    padding: 4px 0 4px 10px;
    background: url(/share/img/pc/common/icon-arrow@2x.png) left center / 6px 6px no-repeat;
    background: url(/pet.benesse.ne.jp/headfoot/img/icon-arrow.png) left center no-repeat \9;
    /* IE7 */
}


/* benesse-header
--------------------------------------------------*/

.benesse-header {
    padding-bottom: 0;
}

.benesse-header__inner {
    padding-bottom: 0;
}

.benesse-header__logo {
    float: left;
    display: inline;
    /* IE6 */
    margin: -12px 0 0 -12px;
}

.benesse-header__logo a {
    display: inline-block;
}

.benesse-header__logo img {
    display: block;
    width: 130px;
    height: 43px;
    border: none;
}

.benesse-header__link {
    float: right;
    margin-top: -1px;
    margin-bottom: 8px;
    margin-left: 0;
}

@media screen and (max-width: 480px) {
    .benesse-header__link li {
        display: block;
        text-align: right;
    }
}


/* benesse-footer
--------------------------------------------------*/

.benesse-footer {}

.benesse-footer__link {
    float: left;
    display: inline;
    /* IE6 */
}

.benesse-footer__copyright {
    float: right;
    margin: 0 0 0 12px;
    padding: 4px 0;
    color: #666;
    font-size: 11px;
    text-align: right;
}

@media screen and (max-width: 480px) {
    .benesse-footer__copyright {
        clear: left;
        float: none;
        margin-left: 0;
        text-align: left;
    }
}

.side_magazine_area {
    padding: 20px 10px 20px 20px;
    padding: 2rem 1rem 2rem 2rem;
    background: #f1f1ee;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    border-radius: .3rem;
}

.side_magazine_area>* {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.side_magazine_area .side_magazine_ttl {
    font-weight: 700;
    margin-bottom: 10px;
    margin-bottom: 1rem;
}

.side_magazine_area .side_magazine_img {
    width: 150px;
    min-width: 150px;
    max-width: 150px;
    position: relative;
}


/*.side_magazine_area .side_magazine_img:before {
    position: absolute;
    right: -10px;
    right: -1rem;
    top: -30px;
    top: -3rem;
    content: url(/_share/img/pc/common/icon_side_new.png);
}*/

.side_sns_area {
    border-top: solid 0.1rem rgba(0, 0, 0, 0.5);
    border-bottom: solid 0.1rem rgba(0, 0, 0, 0.5);
    margin: 30px 0;
    padding: 3rem;
}

.sidenav_ttl_ver2 {
    font-weight: 700;
    text-align: center;
    margin-bottom: 10px;
    margin-bottom: 1rem;
}

.flex_row,
.theme_list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -20px;
    margin-right: -2rem;
}

.flex_row>*,
.theme_list>* {
    padding-right: 20px;
    padding-right: 2rem;
    min-width: 10px;
    min-width: 1rem;
    min-height: 10px;
    min-height: 1rem;
}

.header_logo a:first-child {
    margin-right: 33px;
}

.pickup_ttl {
    background: url(/share/img/pc/common/icon_pickup.png) no-repeat left center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 22px;
    line-height: 2.2rem;
    margin-bottom: 11px;
    padding-left: 33px;
}

.btn_list.list_type_tag.pickup_tag {
    padding-left: 0;
}

.btn_list.list_type_tag.pickup_tag::before {
    display: none;
}

.pickup_tag a {
    background: #02a4bf;
    border: 1px solid #02a4bf;
    color: white;
    font-size: 16px;
    font-size: 1.6rem;
}

.cf {
    *zoom: 1
}

.cf::after {
    content: "";
    display: table;
    clear: both
}

.app_download_ttl .img {
    float: left;
    margin-right: 10px;
}

.app_download_ttl .txt {
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 33px;
    overflow: hidden;
    zoom: 1;
}

.article_list_secondary.article_new_primary li:nth-child(n+7) .article_img {
    width: 12rem;
    min-width: 12rem;
    max-width: 12rem;
}

.article_list_secondary.article_new_secondary .article_img,
.article_list_secondary .article_img {
    width: 12rem;
    min-width: 12rem;
    max-width: 12rem;
}

.article_list_secondary .article_img img {
    width: 120px;
    height: 120px;
}

.article_new_primary li:nth-child(-n+6) .article_img {
    width: auto;
    min-width: 0;
    max-width: 100%;
}

.btn_next:after {
    transform: translateY(-50%) rotate(0);
}

.snav.notitle {
    border-top: 1px solid #e1e1e1;
}

li:empty {
    display: none;
}

.article_new_primary li p {
    padding-right: 20px;
}

.article_new_primary li:nth-child(-n+6) p {
    padding-right: 0;
}

.notfound_wrap {
    margin-top: 30px;
}

.notfound {
    padding-top: 100px;
}

.notfound h2 {
    margin-bottom: 30px;
    text-align: center;
}

.description_item a {
    text-decoration: underline;
}


/* 2018-01 add */

.ad-txt_link {
    position: relative;
    text-decoration: underline;
    /*padding-right: 15px;*/
}

.ad-txt_link:after {
    display: inline-block;
    /*position: absolute;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);*/
    content: "";
    width: 15px;
    height: 10px;
    background: url(/share/img/pc/common/icon_arrow.png);
    background-position: 100% 50%;
    background-repeat: no-repeat;
    background-size: contain;
}

.ad-ttl_side {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.article_list_secondary.row2 {
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.article_list_secondary.row2 li {
    width: 48%;
}

.article_list_secondary.row2 li:nth-child(2n+1) {
    margin-right: 4%;
}

.article_list_secondary.row2 .article_img {
    width: 90px;
    min-width: 90px;
    max-width: 90px;
}

.article_list_secondary.row2 .article_img img {
    width: 90px;
    height: 90px;
}

.l-modal {
    display: none;
    position: absolute;
    top: 40px;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    box-shadow: 0 0 5px 0 rgba(0, 0, 0, .4);
    z-index: 500;
}

.l-modal .inner {
    padding: 30px;
}

.l-modal .search_area {
    width: 100%;
    margin: 0 0 20px;
}

.modal_header {
    padding: 10px 20px;
    padding: 1rem 2rem;
    background: #ccc;
    text-align: right;
}

.modal_header .js-btn_close {
    display: block;
    width: 30px;
    height: 30px;
    background: url(/share/img/sp/common/btn_close.png) center center no-repeat;
    background-size: contain;
    margin-left: auto;
}

.pickup_ttl .icon_tag {
    font-size: inherit;
}

.btn_list.ad_large_tag {
    padding-left: 30px;
}

.btn_list.ad_large_tag a {
    font-size: 17px;
    font-size: 1.7rem;
}

.btn_list.ad_large_tag:before {
    width: 20px;
    height: 20px;
}


/* 2018-01-25 add */

.ad_article_detail h2:not([class*='ttl']) {
    background: #f2f2f5;
    padding: 5px 10px;
    padding: .5rem 1rem;
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 20px;
    margin-bottom: 2rem;
}

.ad_article_detail h3:not([class*='ttl']) {
    font-size: 18px;
    font-size: 1.8rem;
    border-left: solid 10px #e1e1e1;
    border-left: solid 1rem #e1e1e1;
    border-bottom: solid 1px #e1e1e1;
    border-bottom: solid .1rem #e1e1e1;
    padding: 5px 10px;
    padding: .5rem 1rem;
    margin-bottom: 20px;
    margin-bottom: 2rem;
}

.ad_article_detail h4:not([class*='ttl']) {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 10px;
    margin-bottom: 1rem;
}

.ad_article_detail ul li {
    margin-left: 1.6em;
    text-indent: -1.6em;
}

.article_detail_description ul li:before {
    content: '・';
    width: 1.2em;
    display: inline-block;
    text-align: center;
    font-weight: bold;
    margin-right: .4em;
    text-indent: 0;
}

.ad_article_detail ol {
    counter-reset: number;
    list-style: none;
}

.ad_article_detail ol li {
    margin-left: 1.6em;
    text-indent: -1.6em;
}

.article_detail_description ol li:before {
    counter-increment: number;
    content: counter(number);
    width: 1.2em;
    display: inline-block;
    text-align: center;
    white-space: nowrap;
    margin-right: .4em;
    text-indent: 0;
}

.ad_article_detail dl dt {
    font-weight: bold;
    margin-top: .5em;
}

.ad_article_detail blockquote {
    background: #f2f2f5;
    padding: 50px 20px;
    border-radius: 6px;
    position: relative;
}

.ad_article_detail blockquote:before {
    display: inline-block;
    position: absolute;
    top: 8px;
    left: 15px;
    vertical-align: middle;
    content: "\f10d";
    font-family: FontAwesome;
    color: rgba(0, 0, 0, .07);
    font-size: 38px;
    line-height: 1;
}

.ad_article_detail blockquote:after {
    display: inline-block;
    position: absolute;
    bottom: 8px;
    right: 15px;
    vertical-align: middle;
    content: "\f10e";
    font-family: FontAwesome;
    color: rgba(0, 0, 0, .07);
    font-size: 38px;
    line-height: 1;
}

.ad_article_detail table {
    border: 1px solid #ccc;
}

.ad_article_detail table th {
    font-weight: bold;
    padding: 1em;
    border: 1px solid #ccc;
    vertical-align: top;
    background: #f2f2f5;
}

.ad_article_detail table td {
    padding: 1em;
    border: 1px solid #ccc;
    vertical-align: top;
}


/* 2018-03 ad probo search */

.ad_search {
    display: flex;
    display: -webkit-flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    width: 100%;
}

.ad_search input {
    background-color: transparent;
}

.ad_search input[type=text] {
    display: block;
    width: calc(100% - 30px);
}

.ad_search input[type=submit] {
    display: block;
    text-indent: 100%;
    background-image: url(/share/img/pc/common/icon_search.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 20px;
    height: 20px;
}


/* 2018-06 ad button */

.article_detail_item .ad_link_button {
    display: block;
    margin: 20px auto;
    background: #333;
    color: #fff;
    text-align: center;
    padding: 5px 25px;
    width: 450px;
    font-weight: bold;
    text-decoration: none !important;
    border-radius: 100px;
    position: relative;
}

.article_detail_item .ad_link_button:hover {
    background: #444;
}

.article_detail_item .ad_link_button:after {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    position: absolute;
    top: 50%;
    right: 15px;
    -webkit-transform: translateY(-50%) rotate(45deg);
}

.article_detail_item .ad_link_green_button {
    display: block;
    margin: 20px auto;
    background: #3d95d4;
    color: #fff;
    text-align: center;
    padding: 5px 25px;
    width: 450px;
    font-weight: bold;
    text-decoration: none !important;
    border-radius: 100px;
    position: relative;
}

.article_detail_item .ad_link_green_button:hover {
    background: #4ca1de;
}

.article_detail_item .ad_link_green_button:after {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    position: absolute;
    top: 50%;
    right: 15px;
    -webkit-transform: translateY(-50%) rotate(45deg);
}


/* 2018 07 ナビ改定 */

.header_wrap .search_area {
    width: 46px;
    height: 46px;
    padding: 0;
}

.js-btn_search {
    background: url(/share/img/sp/common/20180131/icon_search2.svg) 50% 50% no-repeat;
    background-size: 30px 30px;
    width: 100% !important;
    height: 100% !important;
}

.theme_list>* {
    padding-right: 20px;
    padding-right: 2rem;
    min-width: 10px;
    min-width: 1rem;
    min-height: 10px;
    min-height: 1rem;
    width: 50%;
}

.theme_list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -20px;
    margin-right: -2rem;
}

.theme_list li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
}

.theme_list .theme_item {
    display: block;
    padding-top: 20px;
    padding-top: 2rem;
    padding-bottom: 20px;
    padding-bottom: 2rem;
    border-bottom: solid 2px #dddcd7;
    border-bottom: solid .2rem #dddcd7;
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}


/* 目次 */

.ad_index_list {
    padding: 24px 30px;
    background-color: rgba(248, 227, 0, 0.4);
}

.ad_index_list dd {
    margin: 5px 0;
}

.ad_index_list dd a {
    position: relative;
    padding: 0 0 0 20px;
    display: inline-block;
}

.ad_index_list dd a:before {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #ef8205;
    position: absolute;
    top: 1.2rem;
    left: 0;
}

.ad_index_list dd.middle_summary_item {
    margin: 0 0 0 25px;
}


/* 目次パーツ(CMSの目次チェックがある記事のみ適用する) */

.summary {
    margin: 30px 0;
}

.qa_detail .ad_article_detail .ttl_secondary_ver1 {
    background: #f2f2f5 url(/share/img/pc/qa/txt_q.png) no-repeat 21px center;
    padding-left: 67px;
    position: relative;
}

.qa_detail .ad_article_detail .ttl_secondary_ver1::after {
    background: url(/share/img/pc/qa/txt_a.png) no-repeat left top;
    bottom: -51px;
    content: "";
    display: block;
    height: 26px;
    left: 21px;
    position: absolute;
    width: 22px;
}

.qa_detail .ad_article_detail .article_detail_description {
    padding-left: 67px;
}


/*20171226 murakami*/

.txtDecoUl {
    text-decoration: underline;
}

.txtAlignR {
    text-align: right
}

.bread_area li {
    white-space: normal;
}

.random_banner {
    margin-top: 15px;
    text-align: center;
}


/* 2018-06 ad catlist */

.ad_dogcat_ranking_list a {
    -webkit-align-items: center;
    align-items: center;
}

.ad_dogcat_ranking_list a.dogcat_ranking_link {
    text-decoration: underline;
}

.ad_dogcat_ranking_list li:nth-of-type(4)~li {
    display: none;
}

.ad_icon_rank1 {
    background: url(/share/img/pc/catlist/icon-crown_gold.svg) 0 50% no-repeat transparent;
    background-size: 38px 38px;
    padding-left: 45px;
}

.ad_icon_rank2 {
    background: url(/share/img/pc/catlist/icon-crown_silver.svg) 0 50% no-repeat transparent;
    background-size: 38px 38px;
    padding-left: 45px;
}

.ad_icon_rank3 {
    background: url(/share/img/pc/catlist/icon-crown_bronze.svg) 0 50% no-repeat transparent;
    background-size: 38px 38px;
    padding-left: 45px;
}

.ad_icon_rank_other {
    background: url(/share/img/pc/catlist/icon-crown_other.svg) 0 50% no-repeat transparent;
    background-size: 38px 38px;
    padding-left: 45px;
}

.ad_icon_dogcat_links {
    display: -webkit-flex;
    display: flex;
    margin-right: -5px;
}

.ad_icon_dogcat_links li {
    padding-right: 5px;
}

.ad_icon_dogcat_links a {
    display: block;
    border: 2px solid #000;
    text-align: center;
    padding: 70px 10px 5px;
    border-radius: 4px;
    position: relative;
}

.ad_icon_dogcat_links a:after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    background: url(/share/img/pc/common/icon_arrow.png) 0 0 no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 10px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}


/*.ad_icon_dog_xsmall {
    background: url(/share/img/pc/doglist/ill-dog_xsmall.png) 50% 10px no-repeat;
    background-size: 90px;
}
.ad_icon_dog_small {
    background: url(/share/img/pc/doglist/ill-dog_small.png) 50% 10px no-repeat;
    background-size: 90px;
}
.ad_icon_dog_middle {
    background: url(/share/img/pc/doglist/ill-dog_middle.png) 50% 10px no-repeat;
    background-size: 90px;
}
.ad_icon_dog_large {
    background: url(/share/img/pc/doglist/ill-dog_large.png) 50% 10px no-repeat;
    background-size: 90px;
}
*/

.ad_search_photo_list {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -12px;
}

.ad_search_photo_list li {
    width: 16.66%;
    padding: 0 12px 12px 0;
}

.ad_search_photo_list li:nth-of-type(12)~li {
    display: none;
}

.ad_search_photo_list a {
    display: block;
    height: 100%;
}

.ad_search_photo_list img {
    width: 100%;
    height: 112px;
    object-fit: cover;
}

.ad_search_photo_list figcaption {
    font-size: 12px;
    font-size: 1.2rem;
    margin-top: 5px;
}

.ad_today_dogcat {
    display: -webkit-flex;
    display: flex;
}

.ad_today_dogcat .article_img img {
    height: 250px;
    object-fit: cover;
    width: 100%;
}

.ad_today_dogcat .article_img img {
    height: 250px;
    width: 360px;
}

.ad_off_link {
    color: #ccc;
    pointer-events: none
}

.ad_off_link:after {
    content: none !important;
}

.ad_dummy_bnr {
    position: relative;
    display: block;
}

.ad_dummy_bnr:after {
    content: "ECサイトへのバナー";
    color: #fff;
    font-weight: bold;
    background: rgba(0, 0, 0, .7);
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    position: absolute;
    top: 0;
    left: 0;
    padding-top: 40%;
    box-sizing: border-box;
}


}
.ad_dogcatlist a[href^="#"] {
    color: #ccc;
    pointer-events: none
}
.ad_dogcatlist a[href^="#"]:after {
    content: none !important;
}
.catlist .btn_more.on::after {
    transform: translateY(-70%) rotate(-90deg);
}

/* 2018-08 ABJマーク */
.abj {
    border: #CCC solid 1px;
    margin: 20px 0 0;
    width: 100%;
    font-size: 13px;
    overflow: auto;
}
.abj img {
    width: 120px;
    padding: 5px;
}
.abj .abjinfo {
    float: right;
    width: calc(100% - 120px);
}
.abj .abjinfo div {
    font-size: 13px;
    margin: 5px;
}
.abj .abjinfo a {
    text-decoration: underline;
    color: blue;
}

/* 2019-08 ad_result_search_area */
.ad_result_search_area {
    padding: 44px 30px;
    margin: 0;
    width: 100%;
    background: #eee;
}
.ad_result_search_area #q_result {
    -webkit-appearance: none;
    font-family: "NotoSansCJKjp";
    font-weight: 300;
    font-size: 16px;
    line-height: 16px;
    border-radius: 4px 0 0 4px;
    padding: 9px 0 13px 2%;
    width: 90%;
    background: #FFF;
}
.ad_result_search_area input:last-child {
    font-family: "NotoSansCJKjp";
    font-weight: 300;
    font-size: 0;
    line-height: 0;
    letter-spacing: 10px;
    display: block;
    background: #fff500 url(/share/renewal_design/img/cmn_icn_search.png) center no-repeat;
    background-size: 19.5px auto;
    border-radius: 0 4px 4px 0;
    width: 10%;
    height: 46px;
}

/* 2019-07 .ad_tag_description */
.ad_tag_description p a {
    color: #008eba;
    border-bottom: #008eba;
}

/* 2019-10 logly ranking */
.rankingList {
    counter-reset: ranking-num;
}
.rankingList_rankNum {
    position: relative;
}
.rankingList_rankNum::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 35px 35px 0 0;
    border-color: #fff500 transparent transparent transparent;
    position: absolute;
    top: 0;
    left: 0;
}
.rankingList_rankNum::after {
    counter-increment: ranking-num;
    content: counter(ranking-num);
    color: #000000;
    font-family: "NotoSansCJKjp";
    font-size: 11px;
    font-weight: bold;
    position: absolute;
    top: 1px;
    left: 7px;
}
.ranking_nav {
    margin-top: 3rem;
}
.sidePostWrap_list {
    /* padding-top: 3%; */
    
    font-size: 0;
}
.sidePostWrap_item {
    border-top: 1px solid #e1e1e1;
}
.sidePostWrap_item:last-child {
    border-bottom: 1px solid #e1e1e1;
}
.sidePostWrap_link {
    display: block;
    padding: 2% 0;
    overflow: hidden;
}
.sidePostWrap_thumb {
    float: left;
    width: 60px;
    height: 60px;
    display: block;
    -o-object-fit: cover;
    object-fit: cover;
}
.sidePostWrap_textArea {
    float: left;
    width: 230px;
    margin-left: 10px;
}
.sidePostWrap_tit {
    padding-top: 2px;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}
.sidePostWrap_desc {
    display: block;
    color: #999;
    font-size: 12px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
}
.ranking_more_btn {
    margin-top: 10px;
}

/* 2019-10 add movie parts */
.movie_article {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    height: 0;
    overflow: hidden;
    margin-top: 44px;
}
.movie_player {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

/* 2019-11 rensai corner */
.rensai_more_btn {
    margin-top: 10px;
}
.sideSeriesWrap {
    margin-top: 3rem;
}
.sideSeriesWrap_list {
    padding-top: 10px;
}
.sideSeriesWrap_item:not(:first-child) {
    padding-top: 15px;
}
.sideSeriesWrap_link {
    display: block;
}
.sideSeriesWrap_thumb {
    display: block;
    width: 300px;
    height: 100px;
    object-fit: contain;
}
.sideSeriesWrap_tit {
    padding-top: 4px;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: -.8px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

/* rensai pagination */
.SeriesPagerWrap {
    display: table;
    width: 100%;
    border-top: 1px solid #efefef;
    border-bottom: 1px solid #efefef;
    padding: 10px 0;
    font-family: "NotoSansCJKjp";
    font-weight: 300;
    font-size: 14px;
    line-height: 14px;
    position: relative;
    margin-top: 26px;
}
.ovH {
    overflow: hidden;
}
.SeriesPagerWrap_box {
    display: table-cell;
    width: 40%;
    text-align: center;
    position: relative;
}
.SeriesPager_arrow_left::before,
.SeriesPager_arrow_right::after {
    content: '';
    width: 12px;
    height: 12px;
    border: 0px;
    border-top: solid 2px #000000;
    border-right: solid 2px #000000;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    position: absolute;
    top: 50%;
    margin-top: -4px;
}
.SeriesPager_arrow_left::before {
    transform: rotate(-135deg);
    left: 3px;
}
.SeriesPager_arrow_right::after {
    transform: rotate(45deg);
    right: 3px;
}
.disptbc {
    width: 100%;
    vertical-align: middle;
}
.prevTtl,
.nextTtl,
.firstTtl {
    padding-bottom: 10px;
}
.prevTtl,
.nextTtl,
.firstTtl,
.SeriesPager_list {
    font-family: "NotoSansCJKjp"!important;
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
}
.SeriesPager_article_ttl {
    font-family: "NotoSansCJKjp"!important;
    font-weight: 300;
    font-size: 13px;
    line-height: 18px;
    padding: 0 8px;
    height: 35px;
}
.txt_2line_ellipsis {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: initial;
}
.fig_Padding_Top {
    padding-top: 18px;
}
.txt_4line_ellipsis {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: initial;
    font-size: 13px!important;
}
.supervisor_description_item .txt_4line_ellipsis {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: initial;
}
.supervisor_description_item a {
    font-size: 13px;
}
.SeriesPager_list {
    display: table-cell;
    width: 20%;
    text-align: center;
    border-left: 1px solid #efefef;
    border-right: 1px solid #efefef;
    vertical-align: middle;
}
.SeriesPagerWrap a {
    text-decoration: none!important;
}
.pL3per {
    padding-left: 3%
}
.pR3per {
    padding-right: 3%
}

/* 2019-11 renewal carousel design */
.js-slider_main {
    width: 100%;
}
.js-slider_main .slick-next {
    right: -1px;
    width: 118px;
}
.js-slider_main .slick-prev {
    left: -1px;
    width: 118px;
}
.slider_item {
    margin: 0 0.2rem;
}
.js-slider_main .slider_item img,
.js-slider_main .slick-next,
.js-slider_main .slick-prev {
    height: 400px;
}

/* 2019-11 renewal_dogcatlist_page */
.dogcat_supervisor {
    font-family: "NotoSansCJKjp";
    font-weight: 500;
    font-size: 18px;
    line-height: 18px;
    letter-spacing: 0;
    text-align: right;
}
.dogcat_supervisor a,
.dogcat_supervisor_description a {
    color: #008eba;
    text-decoration: underline;
}
.dogcat_supervisor_profile {
    display: flex;
    width: 100%;
}
.dogcat_supervisor_description {
    width: 582px;
}
.dogcat_supervisor_description div {
    font-family: "NotoSansCJKjp";
    font-weight: 500;
    font-size: 16px;
    line-height: 18px;
    letter-spacing: 0;
    display: inline;
}
.dogcat_supervisor_image {
    width: 138px;
    text-align: center;
}
.dogcat_supervisor_image img {
    width: auto;
    height: 120px;
}

/* 2019-12 child_tags */
.icon_child_tag {
    font-family: "NotoSansCJKjp" !important;
    font-weight: 300 !important;
    font-size: 12px !important;
    line-height: 12px !important;
    background: #FFF !important;
    padding: 7px 10px 10px 10px !important;
    margin: 0 5px 10px 0 !important;
    border: solid 1px #e1e1e1 !important;
    color: #000000 !important;
}
.btn_child_tags_open,
.btn_child_tags_close {
    width: 25px;
    height: 25px;
    border: 0px;
    border-bottom: solid 4px #FFFFFF;
    border-right: solid 4px #FFFFFF;
    cursor: pointer;
    position: relative;
    right: 3px;
}
.btn_child_tags_open {
    transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    top: 20px;
}
.btn_child_tags_close {
    transform: rotate(225deg);
    -ms-transform: rotate(225deg);
    -webkit-transform: rotate(225deg);
    top: 30px;
}
.child_tags_box {
    overflow: hidden;
    width: 95%;
}
.child_tags_area {
    display: flex;
    justify-content: space-between;
}
.pickup_ttl_child_tag {
    font-family: "NotoSansCJKjp"!important;
    font-weight: 600!important;
    font-size: 12px!important;
    line-height: 34px!important;
    letter-spacing: 2px!important;
    background: url(/share/renewal_design/img/art_icn_tag.png) no-repeat!important;
    background-size: 31px auto!important;
    margin: 0px 0 15px 0!important;
    padding-left: 40px!important;
    background-position: 0px 3px!important;
}
.pickup_ttl_child_tag .icon_tag {
    font-family: "NotoSansCJKjp"!important;
    font-weight: 300!important;
    font-size: 12px!important;
    line-height: 12px!important;
    background: #fff500!important;
    padding: 7px 10px 10px 10px!important;
    margin: 0 5px!important;
}

/* 2019-12 link_related parts */
.link_related_main {
    border: 1px solid #d9d9d9;
    margin-top: 44px;
    width: 100%;
    display: flex;
}
.link_related_thumb_wrapper {
    padding: 10px 7px 10px 10px;
    flex-basis: 97px;
    flex-shrink: 0;
}
.link_related_thumb {
    width: 80px;
    height: 80px;
    object-fit: cover;
}
.link_related_item {
    font-size: 12px;
    color: #999999;
}
.link_related_title {
    font-size: 16px;
    font-weight: 600;
}
.link_related_desc {
    font-size: 13px;
    color: #999999;
    line-height: normal;
}
.link_related_item,
.link_related_desc {
    font-weight: 300;
}
.link_related_media {
    vertical-align: top;
    padding: 10px 10px 10px 0;
    flex-basis: auto;
    font-family: "NotoSansCJKjp";
}
.txt_1line_ellipsis {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: initial;
}

/* 2020-01 dangerous_foods_tag_page */
.dangerous_foods_tag_anchor_list {
    margin: 0 140px;
}
.dangerous_foods_tag_anchor_list_item {
    margin-bottom: 15px;
    border-bottom: solid 1px #000000;
}
.dangerous_foods_tag_anchor_list a {
    display: flex;
    font-size: 18px;
    font-weight: 600;
    position: relative;
    text-decoration: none;
}
.dangerous_foods_tag_anchor_list a .feed_capsion {
    width: 15%;
}
.dangerous_foods_tag_anchor_list a::after {
    background: url("/share/renewal_design/img/catlist/icon_arrow.svg") no-repeat left top/contain;
    content: "";
    display: block !important;
    height: 8px;
    position: absolute;
    right: 5px;
    top: 50%;
    width: 12px;
}
.dangerous_foods_list {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    margin-top: 30px;
    border: solid 2px black;
}
.dangerous_foods_list td,
.dangerous_foods_list th {
    font-size: 14px;
    padding: 10px 5px;
    overflow: hidden;
    word-break: normal;
    border: solid 1px black;
}
.dangerous_foods_list .genre,
.dangerous_foods_list .item {
    font-size: 18px;
}
.dangerous_foods_list a {
    text-decoration: underline;
}
.dangerous_foods_list a[href^="#"] {
    text-decoration: none;
}
.dangerous_foods_alphabetical_order_list {
    margin: 0 35px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}
.dangerous_foods_alphabetical_order_list li:nth-child(odd) {
    padding-right: 10px;
}
.dangerous_foods_alphabetical_order_list li:nth-child(even) {
    padding-left: 10px;
}
.dangerous_foods_alphabetical_order_list a {
    display: flex;
    padding: 15px 0 5px;
    margin-bottom: 10px;
    font-size: 18px!important;
    line-height: 14px!important;
    border-bottom: solid 1px #000000;
}
.dangerous_foods_alphabetical_order_list .food_safety {
    font-size: 16px;
    margin: 0 auto;
}
.dangerous_foods_alphabetical_order_list .food_name {
    width: 80%;
}
.dangerous_foods_list img {
    height: 40px;
    width: 40px;
    vertical-align: middle;
    margin-right: 20px;
    object-fit: cover;
}
.dangerous_foods_supervisor {
    width: 200px;
    margin: 10px 0;
}
.dangerous_foods_list a[href^="#"],
.dangerous_foods_alphabetical_order_list a[href^="#"] {
    pointer-events: none;
}
.dangerous_foods_alphabetical_order_list a[href^="#"]:after {
    content: none;
}
.dangerous_foods_alphabetical_order_list_row1_width {
    width: 45%;
}

/*  */
#not_to_feed {
    display: flex;
    padding: 47px 180px 0!important;
}
#should_not_feed_too_much {
    display: flex;
    padding: 47px 165px 0!important;
}
#ok_to_feed {
    display: flex;
    padding: 47px 180px 0!important;
}
#not_to_feed .ttl_capsion,
#should_not_feed_too_much .ttl_capsion,
#ok_to_feed .ttl_capsion {
    width: 20%;
    text-align: left;
}
#not_to_feed .ttl_main,
#should_not_feed_too_much .ttl_main,
#ok_to_feed .ttl_main {
    width: 80%;
    text-align: right;
}

/* 開閉エリア */
.toggle {
    display: none;
}
.option {
    margin: 0 140px 10px;
}
.title,
.content {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
}
.title {
    display: block;
    width: 100%;
    font-size: 14px;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.title::after {
    content: "+";
    display: block !important;
    height: 4px;
    position: absolute;
    right: 10px;
    top: 10%;
    width: 8px;
}
.content {
    max-height: 0;
    overflow: hidden;
}
.content p {
    padding: 5px 10px;
    font-size: 14px !important;
    line-height: 1.5;
}
.toggle:checked+.title+.content {
    max-height: 500px;
    transition: all 1.5s;
}

/* Gallery */
.gallery {
    background-color: #f5f5f5;
}
.gallery a {
    text-decoration: none!important;
}
.gallery .back a {
    position: relative;
    display: block;
    text-align: center;
}
.gallery .movie_player {
    width: 100%;
}
.instagram-media {
    min-width: 100% !important;
}
.js-slider_gallery-for {
    margin-bottom: 8px;
}
.js-slider_gallery-for .slider_item {
    width: 576px;
    margin: auto;
}
.js-slider_gallery-for .slider_item img {
    width: 100%;
    height: auto;
}
.js-slider_gallery-nav .slider_item img {
    height: 202px;
    width: 100%;
    object-fit: cover;
}
.js-slider_gallery-nav .glr_instagram,
.js-slider_gallery-nav .glr_twitter,
.js-slider_gallery-nav .glr_movie {
    position: relative;
    overflow: hidden;
    height: 202px;
}
.js-slider_gallery-nav .glr_instagram .objfit,
.js-slider_gallery-nav .glr_twitter .objfit,
.js-slider_gallery-nav .glr_movie .objfit {
    -o-object-fit: cover;
       object-fit: cover;
    position: absolute;
}
.js-slider_gallery-nav .glr_instagram .objfit {
    top: -55px;
    left: 0;
}
.js-slider_gallery-nav .glr_instagram iframe {
    min-width: 100% !important;
}
.js-slider_gallery-nav .glr_twitter .objfit {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.js-slider_gallery-nav .glr_twitter .objfit > div {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    height: 202px !important;
}
.js-slider_gallery-nav .glr_twitter iframe {
    width: auto !important;
}
.js-slider_gallery-nav .glr_movie .objfit {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.js-slider_gallery-nav .glr_movie iframe {
    width: auto;
    height: 202px;
}
.js-slider_gallery-for .slick-next:before,
.js-slider_gallery-for .slick-prev:before,
.js-slider_gallery-nav .slick-next:before,
.js-slider_gallery-nav .slick-prev:before {
    color: #ccc;
    font-size: 5rem;
}
.js-slider_gallery-for .slick-slide .slider_img,
.js-slider_gallery-for .slick-slide figcaption,
.js-slider_gallery-for .slick-current .slider_img,
.js-slider_gallery-for .slick-current figcaption {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
    opacity: 1;
}
.js-slider_gallery-nav figcaption,
.js-slider_gallery-for .slick-slide .slider_img,
.js-slider_gallery-for .slick-slide figcaption {
    opacity: 0;
}
.js-slider_gallery-for .slick-current .slider_img,
.js-slider_gallery-for .slick-current figcaption {
    opacity: 1;
    text-align: center;
}
.gallery .slider_item figcaption a {
    color: #aaa!important;
    font-size: .8em!important;
}
.js-slider_gallery-nav .slick-prev,
.js-slider_gallery-nav .slick-next {
    top: calc(202px/2);
}
.new_btn_more {
    background: #fff;
    color: black;
    width: 60%;
    margin: 0 auto;
    font-family: "NotoSansCJKjp";
    font-weight: 300;
    font-size: 16px;
    line-height: 16px;
    letter-spacing: 1px;
    border: 4px solid #e6e6e6;
    border-radius: 0;
    padding: 13px 0 18px 0;
}

/* 無断転載 */
.caution {
    font-size: 14px;
    text-align: center;
    margin-top: 10px;
}

/*------------------------------
記事詳細
------------------------------*/
.article_detail_item .comment_area {
    white-space: pre-line;
}

/*------------------------------
タグページ
------------------------------*/
.flex {
    display: flex;
}
.w20per {
    width: 20%;
}
.mw20per {
    min-width: 20%;
}
.w90per {
    width: 90%;
}
.mw90per {
    min-width: 90%;
}
.ml2rem {
    margin-right: 2rem;
}
.mb2rem {
    margin-bottom: 2rem;
}
.br50per {
    border-radius: 50%;
}
.max_width60per {
    max-width: 85%;
}
.supervisor p {
    font-family: "NotoSansCJKjp"!important;
    font-weight: 300!important;
    font-size: 16px!important;
    line-height: 32px!important;
}
.supervisor .supervisor_name {
    clear: both!important;
    font-family: "NotoSansCJKjp"!important;
    font-weight: 480!important;
    font-size: 20px!important;
    line-height: 40px!important;
    letter-spacing: 0!important;
    background: none!important;
    margin: 0!important;
    text-align: left!important;
    border: none!important;
    padding: 0 0 0 0!important;
}
.supervisor .supervisor_title {
    text-align: center;
}
.supervisor_list .supervisor_list_description {
    font-size: 1.3rem;
    color: #999;
}
.ta_center {
    text-align: center;
}
.mb_none_imp {
    margin-bottom: 0!important;
}
.ofw-anywhere {
    overflow-wrap: anywhere;
}
.guide_link_area {
    width: 90%;
    margin: 48px auto auto auto;
}
.guide_link_area .guide_link_area_text {
    text-align: center;
    font-weight: bold;
}
.guide_link_area .guide_link_area_link .ad_link_button_guide {
    display: block;
    margin: 12px 15px;
    /*text-align: center;*/
    
    padding: 5px 70px;
    font-weight: bold;
    text-decoration: none !important;
    border-radius: 100px;
    position: relative;
    background-color: #cbe758;
}
.guide_link_area .guide_link_area_link a.ad_link_button_guide:before {
    position: absolute;
    /*top: 50%;*/
    
    top: 35%;
    /* 50%だと位置がずれるため調整している */
    
    left: 45px;
    content: "";
    min-width: 1.5rem;
    width: 1.5rem;
    height: 1.5rem;
    background: url(/share/renewal_design/img/art_icn_stamp.png);
    /* TODO : 仮画像 */
    
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: contain;
}
.guide_link_area .guide_link_area_link a.ad_link_button_guide::after {
    position: absolute;
    /*top: 50%;*/
    
    top: 37%;
    /* 50%だと位置がずれるため37%に設定 */
    
    right: 60px;
    content: "";
    min-width: 1rem;
    width: 1rem;
    height: .8rem;
    background: url(/share/img/sp/common/icon_arrow.svg);
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: contain;
}
.updated_at {
    text-align: right;
}
.border_text {
    display: block;
    border: 1px solid #ccc;
    padding: 20px;
}