/* 
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.11
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: 13px;
    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-widget-tabs .elementor-tab-content p {
    font-size: 16px;
    line-height: 1.8;
}

.elementor-tabs h2,
.elementor-tabs h3,
.elementor-tabs h4 {
    font-weight: 800;
    font-style: normal;
    font-size: 16px;
    line-height: 1.6;
}

.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,
.single-video .codoc-continue {
    /* display: none; */
}

.single-book .codoc-more,
.single-video .codoc-more {
    /* display: none; */
}

.single-book .codoc-buy-info,
.single-video .codoc-buy-info {
    /* display: none; */
}

.single-book .codoc-buy,
.single-video .codoc-buy {
    /* border: none;
    padding: 0; */
}

.single-book .codoc-bottom,
.single-video .codoc-bottom {
    /* width: 100%;
    height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0; */
}

.single-book .codoc-subscription-articlelist-login,
.single-video .codoc-subscription-articlelist-login {
    /* display: none; */
}

.single-book .codoc-entry .codoc-btn,
.single-video .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;
}

.project a {
    font-size: 11px;
    font-weight: 600;
    color: rgb(11, 90, 182);
}

.project a:hover,
.project a:active {
    color: rgb(67, 94, 124);
}


.book-page-title {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 0;
    margin-top: 2px;
}

.book-sub-title {
    font-size: 17px;
    font-weight: 800;
    line-height: 1.5;
}

.single-book .author,
.single-post .author,
.single-video .author {
    display: flex;
    margin-top: 16px;
}

.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: 18px;
    font-weight: 800;
    margin: 24px 0;
    line-height: 1.5;
}

.codoc-content p {
    font-size: 16px;
    font-weight: 500;
    margin: 24px 0;
    /* font-family: "Noto Serif JP", serif; */
    line-height: 1.9;
}

.codoc-content.center {
    text-align: center;
}

.codoc-content.center p.owned-label {
    display: inline-block;
    padding: 8px 30px;
    background-color: #cecece;
    border-radius: 6px;
    font-size: 14px;
}

.codoc-content iframe,
.page-content iframe {
    width: 100%;
    aspect-ratio: 800 / 450;
}

.before-register {
    display: block;
    text-align: center;
    padding: 0 0 40px;
}

.comments-area a,
.page-content a {
    text-decoration: none;
    word-break: break-all;
}

.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,
.overview {
    margin: -11px 10px 40px 10px;
    padding: 40px 0 40px;
    /* border: 1px solid #7C7C7C; */
}

.mokuji-content>h2 {
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 2px;
    text-align: left;
    margin-bottom: 20px;
}

.mokuji_list>h2 {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 2px;
    text-align: left;
    margin-top: 20px;
    margin-bottom: 10px;
}

.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;
}

/* 個別削除用 */
.postid-4009 .tab-section {
    display: none;
}

.single-video .page-content .elementor-tabs .elementor-tabs-wrapper {
    display: none;
}