/* 
Theme Name: Kimpusha DCH - Hello Elementor Child
Theme URI: https://dch-kimpusha.com/
Description: 金風舎DCH テーマ for Elementor.
Author: 株式会社金風舎
Author URI: https://kimpusha.co.jp/
Template: hello-elementor
Version: 2.0.9
Text Domain: hello-elementor-child
*/

/*
 DCH Theme style default settings.
*/
body{
    background-color: #fcfcfc;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}
a{
    transition: 0.3s;
}
a:active, a:hover {
    color: #888;
}

.body-container,
.elementor-element.e-con-full.body-container{
    max-width: 540px;
    min-height: 100svh;
    padding: 0;
    background-color: #fff;
}
#content{
    padding: 0 10px;
}
h1.entry-title{
    font-size: 1.8rem;
}

/*
 DCH Theme style settings for PC.
*/

@media screen and (min-width: 540px) {
    .body-container,
    .elementor-element.e-con-full.body-container{
        box-shadow: 0px 0px 16px #cecece;
        margin: 0 auto;
    }
}

/* elementor custom */
@media (max-width: 767px) {
    .page-content .elementor-tabs .elementor-tabs-wrapper {
        display: flex;
        width: 100%;
    }

    .page-content .elementor-tabs .elementor-tab-mobile-title {
        display: none;
    }
    .elementor-tab-title.elementor-tab-desktop-title{
        border: 1px solid #7c7c7c;
    }
    .elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-desktop-title.elementor-active,
    .elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-title.elementor-active{
        background-color: #7c7c7c;
        color: #fff;
    }
    .elementor-tabs .elementor-tab-content, .elementor-tabs .elementor-tab-title {
        border-style: none solid none solid;
    }

}
.page-content .elementor-widget-tabs .elementor-tab-desktop-title{
    border-top: 1px solid #7c7c7c;
    border-right: 1px solid #7c7c7c;
    padding: 16px;
}
.page-content .elementor-widget-tabs .elementor-tab-desktop-title:first-child{
    border-left: 1px solid #7c7c7c;
}

.page-content .elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-title.elementor-active,
.page-content .elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-title.elementor-active{
    background-color: #7c7c7c;
    color: #fff;
    margin-bottom: -1px;
    font-size: 11px;
    border-color: #7c7c7c;
}
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-title,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-title{
    flex-grow: 1;
    text-align: center;
    line-height: 1.3;
}
.elementor-widget-tabs .elementor-tab-content{
    font-size: 13px;
}
.elementor-tabs h2,
.elementor-tabs h3,
.elementor-tabs h4{
    font-weight: 800;
    font-style: normal;
    font-size: 14px;
}
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-mobile-title,
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-desktop-title.elementor-active,
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-title:before,
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-title:after,
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tab-content,
.elementor-317 .elementor-element.elementor-element-dfb2347 .elementor-tabs-content-wrapper,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-mobile-title,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-desktop-title.elementor-active,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-title:before,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-title:after,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tab-content,
.elementor-462 .elementor-element.elementor-element-2f5af323 .elementor-tabs-content-wrapper{
    border-color: #7c7c7c;
}
.book-upper{
    padding: 0 10px;
}
.thumbnail p{
    font-size: 10px;
    text-align: center;
    color: #4b4b4b;
    font-weight: 400;
    margin-bottom: 10px;
    margin-top: 10px;
}
.thumbnail-wrap{
    position: relative;
    display: block;
}
.book .thumbnail-wrap::after{
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    aspect-ratio: 335 / 447;
    background-image: url(./assets/image/owned_cover.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}
.sns-share ul{
    display: flex;
    justify-content: flex-end;
    margin: 10px 0;
}
.sns-share li{
    list-style: none;
    width: 18px;
    margin: 0 0 0 5px;
}
.sns-share img{
    width: 18px;
    height: auto;
}
.sns-share button{
    margin: 0;
    padding: 0;
    border: none;
}
.sns-share button:hover,
.sns-share button:active,
.sns-share button:focus{
    background-color: inherit;
}
#notification{
    position: relative;
}
#notification.active::after{
    display: inline;
    content: "コピーしました";
    font-size: 10px;
    background-color: #fff;
    color: #333;
    position: absolute;
    top: 24px;
    right: -8px;
    border: 1px solid #333;
}
.single-book .codoc-continue{
    display: none;
}
.single-book .codoc-more{
    display: none;
}
.single-book .codoc-buy-info{
    display: none;
}
.single-book .codoc-buy{
    border: none;
    padding: 0;
}
.single-book .codoc-bottom{
    width: 100%;
    height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
}
.single-book .codoc-subscription-articlelist-login{
    display: none;
}
.single-book .codoc-entry .codoc-btn{
    background-color: #40a4d0;
    border-radius: 0;
    font-size: 14px;
    height: auto;
    padding: 10px;
}
.page-title{
    color: #333;
}
.series{
    font-size: 11px;
    font-weight: 600;
}
.book-page-title{
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 0;
    margin-top: 2px;
}
.book-sub-title{
    font-size: 17px;
    font-weight: 800;
}
.single-book .author{
    display: flex;
}
.author-image{
    width: 58px;
    margin-right: 13px;
}
.author-image image{
    width: 100%;
}
.author-name{
    font-size: 13px;
    font-weight: 800;
    margin: 0;
}
.author-name span{
    font-size: 11px;
}
.author-name-sub{
    font-size: 10px;
    font-weight: 600;
    margin: 0;
}
.price{
    margin: 0 0 20px;
    text-align: right;
    font-size: 20px;
    font-weight: 800;
}
.zei{
    font-size: 12px;
    font-weight: 800;
}
.before-login{
    width: 100%;
    padding: 12px 16px;
    /* border: 1px solid #ebedf0; */
    border-radius: 6px;
    background: #fff;
    text-align: center;
}
.before-login-btn{
    display: inline-block;
    background: #414141;
    padding: 12px 28px;
    color: #fff;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    border-radius: 4px;
    border: 0;
    cursor: pointer;
    width: auto;
}
a.before-login-btn:active,
a.before-login-btn:hover,
a.before-login-btn:forcus{
    color: #fff;
    background: #272727;
}

/* series slider */
.elementor-135 .elementor-element.elementor-element-7ce3a22{
    background-color: #e4e6e7;
}
.elementor-135 .elementor-widget-loop-carousel .swiper-pagination-bullet{
    background-color: #fff !important;
    opacity: 1;
    margin: 0 2px;
}
.elementor-135 .elementor-widget-loop-carousel .swiper-pagination-bullet-active{
    background-color: #a6a6a6 !important;
    margin: 0 2px;
}
.tokuten{
    border: 1px solid #d04065;
    padding: 0;
    margin: 30px 10px;
}
.tokuten h2{
    background-color: #d04065;
    padding: 13px 24px;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    text-align: center;
    margin: 0;
    line-height: 1.3;
}
.tokuten-content{
    padding: 30px;
}
.tokuten-list ul{
    padding: 0;
}
.tokuten-list li{
    list-style: none;
    background-image: url(./assets/image/icon_check.png);
    background-position: 0% 50%;
    background-repeat: no-repeat;
    background-size: 18px auto;
    padding-left: 40px;
    font-size: 11px;
    font-weight: 800;
    margin-bottom: 16px;
}
.tokuten-label{
    text-align: center;
    margin-bottom: 20px;
}
.tokuten-label span{
    display: inline-block;
    padding: 8px 20px;
    color: #d04065;
    font-size: 11px;
    font-weight: 600;
    border: 1px solid #d04065;
}
.tokuten-catch{
    color: #d04065;
    font-size: 14px;
    font-weight: 800;
    text-align: center;
}
.online-bookstore{
    padding: 20px;
    text-align: center;
}
.elementor-button-wrapper{
    text-align: center;
}
.tokuten h3{
    padding: 0 0 0 22px;
    background-image: url(./assets/image/icon_check_pink.png);
    background-position: left 4px;
    background-repeat: no-repeat;
    background-size: 12px auto;
    font-size: 13px;
    font-weight: 800;
    color: #d04065;
}
.download-epub{
    margin-top: 40px;
    margin-bottom: 50px;
    text-align: center;
}
.btn-epub{
    display: inline-block;
    width: 100%;
    max-width: 395px;
    aspect-ratio: 590 / 100;
    background-image: url(./assets/image/btn_epub.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}
.tokuten-book-item{
    display: flex;
    gap: 20px;
}
.tokuten-book-item-left{
    width: 30%;
}
.tokuten-book-item-left{
    width: 70%;
}
.tokuten-html{
    width: 100%;
}
.tokuten-html iframe{
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 9;
}
.tokuten_label{
    color: #7c7c7c;
    font-size: 10px;
    font-weight: 600;
    padding: 4px 12px;
    border: 1px solid #7c7c7c;
    border-radius: 4px;
    display: inline-block;
}
.tokuten-title{
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 3px;
}
.tokuten_title_sub{
    font-size: 10px;
    font-weight: 700;
    margin-bottom: 3px;
}
.tokuten-text{
    font-size: 10px;
    font-weight: 400;
}
.tokuten-book-item-left{
    max-width: 75px;
}
.tokuten_book{
    margin-top: 30px;
    margin-bottom: 10px;
}
.tokuten_movie{
    margin-top: 30px;
    margin-bottom: 10px;
}
.tokuten hr{
    background-color: inherit;
    border-bottom: none;
    border-color: #fff;
    margin-top: 30px;
    margin-bottom: 30px;
}
.body-container > hr,
.elementor-element.e-con-full.body-container > hr{
    background-color: inherit;
    border-bottom: none;
    border-color: #fff;
    width: calc(100% - 40px);
    margin: 4px auto 30px;
}
.single-post .post .wp-post-image{
    max-height: initial;
}
.thumbnail-wrap .post-title{
    display: none;
}
.codoc-content{
    padding: 0 30px;
}
.codoc-content.not-login{
    display: block;
    position: relative;
    overflow: hidden;
}
.codoc-content.not-login::before{
    display: block;
    width: 100%;
    height: 120px;
    content: "";
    position: absolute;
    border-style: none;
    left: 0;
    bottom: 0;
    z-index: 2;
    background: linear-gradient(rgba(255,255,255,0) 0, #fff 100px); 
}
.codoc-content h2{
    font-size: 16px;
    font-weight: 800;
    margin: 24px 0;
    line-height: 1.5;
}
.codoc-content p{
    font-size: 15px;
    font-weight: 500;
    margin: 24px 0;
    font-family: "Noto Serif JP", serif;
    line-height: 1.8;
}
.before-register{
    display: block;
    text-align: center;
    padding: 0 0 40px;
}
.comments-area a, .page-content a{
    text-decoration: none;
}
.before-register-btn{
    display: inline-block;
    background-color: #40a4d0;
    border-radius: 0;
    font-size: 14px;
    font-weight: 800;
    height: auto;
    padding: 24px 26px;
    color: #fff;
}
.before-register-btn:active,
.before-register-btn:hover{
    color: #fff;
    background-color: #333;
}
.info-book{
    display: block;
    text-align: center;
    padding: 40px 0 40px;
}
.info-book-btn{
    display: inline-block;
    background-image: url(./assets/image/btn_syoseki.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 0;
    font-size: 14px;
    font-weight: 800;
    height: auto;
    padding: 14px 26px;
    color: #fff;
}
.info-book-btn:hover,
.info-book-btn:active{
    opacity: 0.8;
    color: #fff;
}
.comment-author{
    font-size: 10px;
    display: flex;
    align-items: center;
}
#comments{
    border: 1px solid #a6a6a6;
}
.title-comments{
    background-color: #a6a6a6;
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    margin: 0;
    padding: 14px;
    text-align: center;
}
#comments .comment .avatar{
    width: 12px;
    height: auto;
    margin-right: 4px;
    position: static;
}
.says{
    display: none;
}
.comment-author .fn::after{
    display: inline;
    content: "さん";
    font-size: 10px;
    color: #333;
    font-weight: 400;
}
#comments .comment-meta{
    justify-content: flex-start;
    gap: 10px;
    align-items: center;
}
.comment-metadata a{
    color: #333;
    font-size: 10px;
}
#comments .comment-list{
    padding: 30px 20px 0;
}
#comments .comment-content{
    font-size: 10px;
    font-weight: 300;
    color: #333333;
}
#comments .comment .comment-body{
    padding: 0;
    margin-bottom: 10px;
    border-block-end: 1px solid #eee;
}
#comments .comment-respond{
    padding: 20px;
}
.comment-reply-title{
    display: none;
}
.logged-in-as{
    display: none;
}
#commentform label{
    margin-bottom: 8px;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.3;
}
#commentform input[type=text],
#commentform input[type=email],
#commentform input[type=tel],
#commentform input[type=submit],
#commentform textarea{
    font-size: 12px;
    font-weight: 400;
}

.required{
    font-size: 10px;
    color: #d04065;
}
.comment-register{
    text-align: center;
    font-size: 10px;
    font-weight: 700;
    color: #40a4d0;
    padding-bottom: 35px;
    margin: 30px 0 0;
}
.comment-register-btn,
#commentform input[type=submit]{
    display: inline-block;
    font-size: 13px;
    font-weight: 700;
    color: #fff;
    padding: 12px;
    text-align: center;
    background-color: #40a4d0;
}
.comment-register-btn:hover,
.comment-register-btn:active{
    color: #fff;
    background-color: #333;
}
.comment-register [type=button], [type=submit], button{
    display: inline-block;
    font-weight: 400;
    color: #40a4d0;
    text-align: center;
    white-space: nowrap;
    user-select: none;
    background-color: transparent;
    border: 1px solid #40a4d0;
    padding: 12px;
    font-size: 1rem;
    border-radius: 3px;
    transition: all .3s;
    font-size: 13px;
}
.comment-form-cookies-consent{
    display: flex;
    gap: 8px;
}
.status-wrap{
    display: flex;
    align-items: center;
}
.status-center{
    display: block;
    text-align: center;
    margin-bottom: 40px;
}
.project_status{
    font-size: 10px;
    padding: 2px;
    border: 1px solid #4b4b4b;
    display: inline-block;
}
.status-center .project_status{
    padding: 2px 30px;
}
.project_status.hakkan{
    color: #40a4d0;
    border-color: #40a4d0;
}
.status-wrap .series{
    font-size: 11px;
    font-weight: 600;
    color: #333;
}
.archive-description{
    font-size: 22px;
    font-weight: 800;
    color: #333;
    text-align: center;
}
.mokuji-content{
    margin: -11px 10px 40px 10px;
    padding: 40px 20px 60px;
    border: 1px solid #7C7C7C;
}
.mokuji-content h2{
    font-size: 27px;
    font-weight: 900;
    letter-spacing: 2px;
    text-align: center;
}
.mokuji_list,
.mokuji_list ul{
    list-style: none;
    font-size: 12px;
    font-weight: 800;
    color: #a1a1a1;
    padding-left: 0;
}
.mokuji_list li{
    margin-bottom: 20px;
}
.mokuji_list li:last-child a::before{
    display: inline-block;
    content: "New";
    color: #fff;
    font-size: 8px;
    font-weight: 600;
    background-color: #d04065;
    margin-right: 4px;
    padding: 2px 4px;
}
.mokuji_list li::before{
    display: inline;
    content: "▶︎";
    margin-right: 4px;
    font-size: 7px;
    vertical-align: middle;
}
.mokuji_list a{
    display: inline;
    color: #333333;
    padding-bottom: 1px;
}
.mokuji_list a span{
    border-bottom: 1px solid #333;
}
.mokuji_list a:hover span,
.mokuji_list a:active span{
    border-bottom: none;
}
.mokuji-caution{
    text-align: center;
    color: #7c7c7c;
    font-size: 10px;
    font-weight: 600;
    margin-bottom: 24px;
}
.elementor-nav-menu--dropdown.elementor-nav-menu__container{
    display: none;
}
.elementor-nav-menu.sm-vertical{
    list-style: none;
    padding-left: 0;
}
.single-post .book-content{
    background: url(./assets/image/img_kindle.jpg) center top no-repeat;
    background-size: 100% auto;
    aspect-ratio: 590 / 875;
    width: 100%;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 40px;
    margin-bottom: 40px;
}
.single-post .book-content .thumbnail{
    aspect-ratio: 480 / 647;
    width: calc(100% - 3%);
}
.single-post .book-content .thumbnail p{
    position: absolute;
    top: 28%;
    width: 186px;
    left: calc(50% - 93px);
    z-index: 10;
    background-color: #fff;
    color: #4b4b4b;
    border: 1px solid #4b4b4b;
    font-size: 14px;
    font-weight: 800;
    padding: 39px 30px;
    text-align: center;
    display: inline-block;
    line-height: 1.8;
}
.single-post .book-content.not-login .thumbnail p{
    background-color: #40a4d0;
    color: #fff;
    border: none;
}
.single-post .book-content .thumbnail-wrap {
    position: relative;
    z-index: 1;
    display: block;
    overflow: hidden;
    width: 85%;
    margin: 4px auto;
}
