/*
Theme Name: Puock Child
Theme URI: https://www.shupingba.com/
Description: My custom child theme for Puock.
Author: Your Name
Author URI: https://www.shupingba.com/about/
Template: puock
Version: 1.0.0
Text Domain: puock-child
*/

/* ========== 基础样式 ========== */
.widget-common-media-post .img img {
    width: 60px;
    height: 80px;
    object-fit: cover;
}

.post-relevant-item .title {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    color: white;
    padding: 5px;
    margin: 0;
    text-align: center;
    font-size: 14px;
    background-color: rgba(0, 0, 0, 0.6);
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.3);
}

.post-info .info-title .a-link {
    margin-top: 10px;
    display: inline-block;
}

.magazine-media-item h2.t-lg.t-line-1 {
    margin-top: 10px;
}

.post-relevant-item {
    padding: 0 5px;
    margin-bottom: 20px;
}

.post-relevant .post-relevant-item > div {
    transition: all .3s;
    width: 100%;
    border-radius: 6px;
    position: relative;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    overflow: hidden;
}

.post-relevant .post-relevant-item > div .title {
    z-index: 10;
    color: var(--light);
}

.post-relevant .post-relevant-item > div:hover {
    transform: translateY(-3px);
}

.post-relevant .post-relevant-item > div:before {
    display: none;
}

.login-required-link {
    color: #ff0000 !important;
    text-decoration: none !important;
}

.login-required-link:link,
.login-required-link:visited,
.login-required-link:hover,
.login-required-link:active {
    color: #ff0000 !important;
}

.post-item .thumbnail img {
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    will-change: transform, box-shadow;
}

.post-item .thumbnail:hover img {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}

.post-item.no-thumbnail .post-info {
    width: 100%;
    padding-left: 0;
}

.magazine-media-item .t-md.c-sub.text-2line {
    display: none !important;
}

.magazine-media-item .t-line-1 h2 {
    margin-bottom: 0;
}

/* ========== 10-31日新加样式 ========== */
.post-item-card .thumbnail {
    padding: 0 !important;
}

.post-item-card .thumbnail img {
    width: 100% !important;
    max-width: 200px !important;
    margin: 0 auto !important;
    object-fit: cover !important;
}

.post-item-card {
    padding: 0 15px !important;
}

.card-plain.post-item-card {
    margin-bottom: 25px !important;
}

article.post-item-card.no-thumbnail h2.post-title,
article.post-item-card.no-thumbnail h3.post-title {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    clip: auto !important;
    width: auto !important;
    height: auto !important;
    margin: 0 0 15px 0 !important;
    font-size: 1.2rem !important;
    line-height: 1.4 !important;
}

/* ========== 密码表单基础样式 ========== */
.post-password-form,
form[name="login"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 400px !important;
    margin: 20px 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    position: relative !important;
    z-index: 9999 !important;
    overflow: visible !important;
}

.post-password-form {
    margin: 20px auto !important;
    padding: 25px !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
    border: 1px solid #e9ecef !important;
    gap: 15px !important;
}

.post-password-form p {
    margin: 0 0 10px 0 !important;
    text-align: center !important;
    font-weight: 500 !important;
    color: #333 !important;
}

.post-password-form label {
    display: block !important;
    margin-bottom: 8px !important;
    font-weight: 500 !important;
    color: #495057 !important;
}

.post-password-form input[type="password"],
form[name="login"] input[type="password"] {
    width: 100% !important;
    min-height: 45px !important;
    padding: 12px 15px !important;
    box-sizing: border-box !important;
    border: 2px solid #e1e5e9 !important;
    border-radius: 6px !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    display: block !important;
    background: white !important;
    color: #333 !important;
    transition: all 0.3s ease !important;
}

.post-password-form input[type="password"] {
    border: 1px solid #ced4da !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    min-height: 45px !important;
    padding: 10px 15px !important;
}

/* ========== 消息样式 ========== */
form[name="login"] + p[style*="color: darkred"] {
    margin: 15px 0 !important;
    padding: 12px 15px !important;
    background: #fff5f5 !important;
    border: 1px solid #fed7d7 !important;
    border-radius: 6px !important;
    color: #c53030 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    width: 100% !important;
    max-width: 400px !important;
    box-sizing: border-box !important;
}

/* ========== 无缩略图文章修复 ========== */
.post-item-card.no-thumbnail .post-info {
    width: 100% !important;
    padding-left: 0 !important;
}

.post-item-card.no-thumbnail .info-title {
    display: block !important;
    width: 100% !important;
}

.post-item-card.no-thumbnail .info-title .a-link {
    display: block !important;
    width: 100% !important;
    margin-top: 0 !important;
    padding: 10px 0 !important;
}

.post-item-card.no-thumbnail .post-item-block {
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
}

.post-item-card.no-thumbnail .post-info {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

.post-item-card.no-thumbnail .info-title {
    order: 1 !important;
}

.post-item-card.no-thumbnail .info-meta {
    order: 2 !important;
    flex: 1 !important;
}

.post-item-card.no-thumbnail .info-footer {
    order: 3 !important;
}

/* ========== 密码保护文章特殊处理 ========== */
.post-item-card:has(form[name="login"]) .text-2line,
.post-item-list:has(form[name="login"]) .text-2line {
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    display: block !important;
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    white-space: normal !important;
}

.post-item-card:has(form[name="login"]) .text-2line p:first-child,
.post-item-list:has(form[name="login"]) .text-2line p:first-child {
    margin-bottom: 15px !important;
    padding: 15px !important;
    background: #f8f9fa !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 8px !important;
    color: #374151 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.post-item-card:has(form[name="login"]) form[name="login"],
.post-item-list:has(form[name="login"]) form[name="login"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    margin: 15px 0 !important;
}

.post-item-card .text-2line,
.post-item-list .text-2line {
    -webkit-line-clamp: 4;
    line-clamp: 4;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ========== 通用样式 ========== */
.entry-content form[name="login"],
.post-content form[name="login"],
.article-content form[name="login"] {
    margin: 25px 0 !important;
}



/* ========== 响应式设计 ========== */
@media (max-width: 768px) {
    .post-password-form,
    form[name="login"] {
        max-width: 100% !important;
        margin: 15px 0 !important;
    }
    
    .post-password-form {
        padding: 20px !important;
        margin: 15px auto !important;
    }
    
    .post-password-form input[type="password"],
    .post-password-form input[type="submit"],
    form[name="login"] input[type="password"],
    form[name="login"] input[type="submit"] {
        min-height: 42px !important;
        font-size: 16px !important;
    }
    
    p:has(+ form[name="login"]),
    form[name="login"] + p[style*="color: darkred"] {
        max-width: 100% !important;
    }
}

/* 分类目录子分类悬停灰色 */
.child-cat .abhl:hover {
    background-color: #d1d5db !important;
    color: #111827 !important;
}

/* 主菜单悬停底部蓝条改为灰色 */
#menus>ul>li:hover:after,
#menus>ul>li.menu-current:after {
    background: #6b7280 !important;
}

/* ========== 修复图片高度问题 ========== */
.magazine-media-item .img {
    display: none !important;
}

.post-item .thumbnail,
.post-item-list .thumbnail,
.post-item-card .thumbnail {
    height: 280px !important;
    overflow: hidden !important;
    border-radius: 8px !important;
}

.post-item .thumbnail img,
.post-item-list .thumbnail img,
.post-item-card .thumbnail img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}

/* ========== 文章标题多行省略 ========== */
.post-item .info-title .a-link,
.post-item-card .info-title .a-link,
.post-item-list .info-title .a-link,
.magazine-media-item .t-line-1 h2 a,
.media-link .a-link {
    white-space: normal !important;
    text-nowrap: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    line-height: 1.5 !important;
}

.t-line-1,
.text-truncate {
    white-space: normal !important;
    text-nowrap: normal !important;
}

/* ========== 隐藏小工具箭头 ========== */
.widget_common_posts .media-link .fa-angle-right,
.widget-common-media-post .fa-angle-right,
.media-link .fa-angle-right {
    display: none !important;
}

/* ========== 手机端优化 ========== */
@media (max-width: 767px) {
    .post-item-list .thumbnail {
        height: 160px !important;
        width: 120px !important;
        flex-shrink: 0 !important;
        margin-right: 15px !important;
    }
    
    .post-item-list .thumbnail img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }
    
    .post-item-list .post-info {
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
    }
}



/* ========== 统一密码表单样式 ========== */
form[name="login"] input[type="password"] {
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 12px !important;
    box-sizing: border-box !important;
    border: 2px solid #d1d5db !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    background: #f9fafb !important;
    color: #374151 !important;
}

form[name="login"] input[type="submit"] {
    min-height: 42px !important;
    padding: 10px 20px !important;
    background-color: #6b7280 !important;
    color: white !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

form[name="login"] input[type="submit"]:hover {
    background-color: #4b5563 !important;
}

p:has(+ form[name="login"]) {
    margin-bottom: 15px !important;
    padding: 15px !important;
    background: #f8f9fa !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 8px !important;
    color: #374151 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

/* 修复文章内容区域的密码提示框样式 */
.entry-content p:has(+ form[name="login"]),
.post-content p:has(+ form[name="login"]),
.article-content p:has(+ form[name="login"]) {
    margin-bottom: 20px !important;
    padding: 15px !important;
    background: #f8f9fa !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 8px !important;
    color: #374151 !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    width: 100% !important;
    max-width: 400px !important;
    box-sizing: border-box !important;
}



/* 书籍推荐页面 - 核心样式（移至子主题） */
/* 1. 列表项：修复hover层级抖动 */
#books-main li {
    position: relative;
    z-index: 1;
}

/* 2. 链接容器：统一过渡+固定宽度 */
#books-main a {
    display: block;
    margin: 0 auto;
    border-radius: 4px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    text-decoration: none;
    position: relative;
    z-index: 2;
    transition: all 0.3s ease;
    width: 120px; /* 固定宽度，确保截断标准一致 */
}

/* 3. 链接hover效果 */
#books-main a:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* 4. 图片：基础样式 */
#books-main a img,
#books-main .cover {
    width: 120px !important;
    height: 160px !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 auto !important;
    border: none !important;
    border-radius: 4px !important;
}

/* 5. 文字样式（选一种即可！） */
/* 👉 选项A：单行省略号（推荐，排版整洁） */
#books-main a p {
    margin-top: 8px !important;
    height: 20px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    width: 100% !important;
    text-align: center !important;
}

/* 👉 选项B：自动换行显示全部（取消上面A的注释，注释掉A） */
/* #books-main a p {
    margin-top: 8px !important;
    margin-bottom: 5px !important;
    white-space: normal !important;
    overflow: visible !important;
    height: auto !important;
    text-align: center !important;
    font-size: 12px !important;
} */

/* 6. 分页样式 */
.pagination {
    margin: 30px 0;
    pointer-events: auto;
}
.pagination li {
    margin: 0 4px;
}
.pagination a {
    transition: all 0.2s ease;
}
.pagination .active a {
    background-color: #0d6efd;
    border-color: #0d6efd;
}

/* 7. 统计文字 */
.books-count {
    text-align: center;
    color: #6c757d;
    margin: 10px 0 20px;
}

/* 8. tooltip层级 */
[data-bs-toggle="tooltip"] {
    z-index: 10;
    pointer-events: auto;
}


