/*
Theme Name: 游戏资源站
Theme URI: https://your-domain.com
Description: 适配自定义样式的游戏资源站主题
Author: Custom
Version: 1.0
*/

/* 全局CSS变量（100%正确格式） */
:root {
    --bg-body: #FFFFFF;
    --bg-card: #FFFFFF;
    --text-main: #000000;
    --text-sub: #6B7280;
    --border-color: #E5E7EB;
    --primary: #4F46E5;
    --primary-light: #6366F1;
    --radius-card: 24px;
    --radius-btn: 12px;
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    --transition-speed: 0.3s;
}

/* 深色主题变量（夜晚）：纯黑灰配色 — 背景 #121212 / 卡片 #1E1E1E / 主文 #FFFFFF / 次文 #AAAAAA / 控件与描边 #333 / 主按钮 #444 */
body.dark-theme {
    --bg-body: #121212;
    --bg-card: #1E1E1E;
    --text-main: #FFFFFF;
    --text-sub: #AAAAAA;
    --border-color: #333333;
    --primary: #444444;
    --primary-light: #525252;
}

/* 夜晚主题：输入/下拉等控件背景 #333（页面底 #121212，与参考稿一致） */
.dark-theme .auth-input,
.dark-theme select.auth-input {
    background-color: #333333;
    border-color: #333333;
}

.dark-theme .auth-input:focus {
    border-color: #555555;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.06);
}

.dark-theme .auth-tab.is-active {
    color: var(--text-main);
}

.dark-theme .auth-footer-links a {
    color: var(--text-sub);
}

.dark-theme .auth-footer-links a:hover {
    color: var(--text-main);
}

/* 星空主题：顶栏/侧栏毛玻璃；板块内容区除文字与配图外背景与线透明 */
body.cosmic-theme {
    --bg-body: transparent;
    --bg-card: transparent;
    --text-main: #E8E4FF;
    --text-sub: rgba(203, 213, 245, 0.82);
    --border-color: transparent;
    --primary: #A5B4FC;
    --primary-light: #C4B5FD;
    --shadow: none;
}

body.cosmic-theme {
    background-color: transparent;
}

/* 粒子银河容器（canvas + DOM 星点/飞船/流星由 js/cosmic-bg.js 注入） */
.cosmic-bg-root {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
    background-color: #050505;
}

body.cosmic-theme .cosmic-bg-root {
    display: block;
}

body.cosmic-theme #page-container {
    position: relative;
    z-index: 1;
}

.cosmic-bg-root .cosmic-galaxy-canvas {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.cosmic-bg-root .cosmic-star {
    position: absolute;
    background: #fff;
    border-radius: 50%;
    animation: cosmic-twinkle 3s infinite alternate;
    z-index: 2;
}

.cosmic-bg-root .cosmic-ship {
    position: absolute;
    width: 8px;
    height: 4px;
    left: 0;
    background: #87ceeb;
    clip-path: polygon(0 50%, 50% 0, 100% 50%, 50% 100%);
    animation: cosmic-fly 20s linear infinite;
    z-index: 3;
}

.cosmic-bg-root .cosmic-meteor {
    position: absolute;
    width: 2px;
    height: 15px;
    background: linear-gradient(to top, #fff, transparent);
    animation: cosmic-meteor-anim 1s linear forwards;
    z-index: 3;
}

@keyframes cosmic-twinkle {
    0% {
        opacity: 0.2;
    }
    100% {
        opacity: 1;
    }
}

@keyframes cosmic-fly {
    0% {
        transform: translateX(-10px);
    }
    100% {
        transform: translateX(100vw);
    }
}

@keyframes cosmic-meteor-anim {
    0% {
        transform: translate(0, 0) rotate(45deg);
        opacity: 1;
    }
    100% {
        transform: translate(100px, 100px) rotate(45deg);
        opacity: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cosmic-bg-root .cosmic-star,
    .cosmic-bg-root .cosmic-ship,
    .cosmic-bg-root .cosmic-meteor {
        animation: none !important;
    }
}

html:has(body.cosmic-theme) {
    min-height: 100%;
    background-color: #050505;
}

.cosmic-theme .section-card,
.cosmic-theme .ad-banner,
.cosmic-theme .carousel-container {
    background-color: transparent;
    box-shadow: none;
    border-color: transparent;
}

.cosmic-theme .section-card:hover {
    border-color: transparent;
}

.cosmic-theme .auth-page {
    background-color: transparent;
}

.cosmic-theme .auth-container.auth-card {
    background: transparent;
    box-shadow: none;
    border-color: transparent;
}

.cosmic-theme .article-detail-card {
    background: transparent;
    box-shadow: none;
    border-color: transparent;
}

.cosmic-theme .overlay {
    background: transparent;
}

.cosmic-theme .game-comment-list .comment {
    background: transparent;
}

.cosmic-theme .game-comment-form input[type="text"],
.cosmic-theme .game-comment-form input[type="email"],
.cosmic-theme .game-comment-form input[type="url"],
.cosmic-theme .game-comment-form textarea#comment {
    background: transparent;
}

.cosmic-theme .article-img.no-img {
    background: transparent;
}

.cosmic-theme .auth-tabs {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .auth-input {
    background: transparent;
}

.cosmic-theme .auth-toggle-pwd:hover {
    background: transparent;
}

.cosmic-theme .article-detail-comment-btn,
.cosmic-theme .article-detail-fav-btn {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .article-detail-comment-btn:hover,
.cosmic-theme .article-detail-fav-btn:hover {
    border-color: transparent;
}

.cosmic-theme .auth-msg--error,
.cosmic-theme .auth-msg--success {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .auth-btn-secondary,
.cosmic-theme .auth-btn-secondary:hover:not(:disabled) {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .auth-btn {
    background: transparent;
    color: var(--primary);
}

.cosmic-theme .auth-btn:hover {
    background: transparent;
    color: var(--primary-light);
}

.cosmic-theme .sidebar-divider {
    background-color: rgba(255, 255, 255, 0.1);
}

.cosmic-theme .swiper-slide {
    background: transparent !important;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9);
}

.cosmic-theme .pagination a.page-numbers {
    background: transparent;
    box-shadow: none;
}

.cosmic-theme .pagination a.page-numbers:hover {
    background: transparent;
    color: var(--primary-light);
}

.cosmic-theme .pagination span.page-numbers.current {
    background: transparent;
    color: var(--primary);
}

.cosmic-theme .page-btn {
    background: transparent;
    color: var(--text-sub);
}

.cosmic-theme .page-btn:hover:not(.disabled) {
    background: transparent;
    color: var(--primary);
}

.cosmic-theme .article-detail-toolbar--after {
    border-top-color: transparent;
}

.cosmic-theme .article-detail-meta {
    border-bottom-color: transparent;
}

.cosmic-theme .auth-tab.is-active {
    background: transparent;
    box-shadow: none;
}

.cosmic-theme .auth-input:focus {
    box-shadow: none;
    outline: 1px solid var(--primary);
    outline-offset: 2px;
}

.cosmic-theme .article-item {
    border-color: transparent;
}

.cosmic-theme .game-new-post-textarea {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .game-new-post-preview-remove {
    background: transparent;
    color: var(--text-main);
}

.cosmic-theme .game-new-post-preview-remove:hover {
    background: transparent;
    color: #f87171;
}

.cosmic-theme .auth-profile-tab {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .auth-profile-tab:hover {
    border-color: transparent;
    color: var(--text-main);
}

.cosmic-theme .auth-profile-tab.is-active {
    background: transparent;
    color: var(--primary);
    border-color: transparent;
}

.cosmic-theme .auth-profile-section {
    border-top-color: transparent;
}

/* 全局重置 */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent;
}

/* 页面主体 */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background-color: var(--bg-body);
    color: var(--text-main);
    line-height: 1.6;
    padding-top: 60px; /* 适配导航栏高度，避免内容被遮挡 */
    transition: background-color 0.3s, color 0.3s;
}

/* 顶部导航栏 - 强化固定效果，确保无空隙 */
.top-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 60px; /* 固定高度，与侧边栏top值严格匹配 */
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
    z-index: 1001; /* 高于侧边栏，确保始终在顶层 */
    margin: 0; /* 强制清除margin，避免空隙 */
}

.dark-theme .top-nav {
    background: rgba(18, 18, 18, 0.95);
    border-color: #333333;
}

.cosmic-theme .top-nav {
    background: rgba(15, 23, 42, 0.4);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* 导航容器 */
.nav-left, .nav-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

/* 导航项 */
.nav-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-main);
    cursor: pointer;
    transition: color 0.2s;
    user-select: none;
}

.nav-item:hover {
    color: var(--primary);
}

/* 主容器 */
.main-container {
    max-width: 680px;
    margin: 0 auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* 轮播容器 */
.carousel-container {
    width: 100%;
    height: 180px;
    border-radius: var(--radius-card);
    overflow: hidden;
    box-shadow: var(--shadow);
    position: relative;
}

.mySwiper {
    width: 100%;
    height: 100% !important;
}

/* 轮播滑块（文字紧贴横线上方） */
.swiper-slide {
    width: 100%;
    height: 100%;
    background: #4F46E5;
    display: flex !important;
    align-items: flex-start !important; 
    justify-content: center !important;
    color: #ffffff !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    padding-top: 120px !important;
    margin: 0 !important;
}

/* ========== 关键修改：轮播分页器（三条横线） ========== */
.swiper-pagination {
    position: absolute !important;
    bottom: 15px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    z-index: 20;
    display: flex !important;
    gap: 8px !important;
    margin: 0 !important;
}

/* 覆盖Swiper默认的分页点样式，改为横线 */
.swiper-pagination-bullet {
    width: 25px !important;
    height: 4px !important;
    background-color: rgba(255, 255, 255, 0.6) !important;
    border-radius: 2px !important;
    margin: 0 !important;
    opacity: 1 !important;
    border: none !important; /* 清除默认点的边框 */
}

/* 激活状态的横线样式 */
.swiper-pagination-bullet-active {
    background-color: #ffffff !important;
}
/* ====================================================== */

/* 广告位 */
.ad-banner { 
    width: 100%; 
    height: 40px; 
    background-color: var(--bg-card); 
    border-radius: var(--radius-card); 
    box-shadow: var(--shadow); 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    color: var(--text-sub); 
    font-size: 14px; 
    border: 1px dashed var(--border-color); 
}

/* 模块卡片 */
.section-card { 
    background-color: var(--bg-card); 
    border-radius: var(--radius-card); 
    padding: 20px; 
    box-shadow: var(--shadow); 
    cursor: pointer; 
    border: 1px solid transparent; 
    overflow: hidden; 
    transition: transform 0.2s, border-color 0.2s; 
}

.section-card:hover { 
    transform: translateY(-2px); 
    border-color: var(--primary-light); 
}

.section-card.section-card--empty {
    cursor: default;
}

.section-card.section-card--empty .arrow {
    visibility: hidden;
}

.section-card.section-card--empty:hover {
    transform: none;
    border-color: transparent;
}

.home-section-hot-emoji {
    margin-right: 4px;
}

/* 模块标题 */
.section-title { 
    font-size: 16px; 
    font-weight: 600; 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
}

.section-title .arrow { 
    font-size: 16px; 
    transition: transform 0.3s; 
    color: var(--text-sub); 
}

.section-card.active .arrow { 
    transform: rotate(180deg); 
}

/* 模块内容 */
.section-content { 
    max-height: 0; 
    opacity: 0; 
    overflow: hidden; 
    transition: max-height 0.4s cubic-bezier(0, 1, 0, 1), opacity 0.3s; 
    margin-top: 10px; 
    color: var(--text-sub); 
    font-size: 14px; 
}

.section-card.active .section-content { 
    max-height: 500px; 
    opacity: 1; 
    transition: max-height 0.4s ease-in-out, opacity 0.3s; 
}

/* 侧边栏（最终修复版） */
.sidebar { 
    position: fixed; 
    top: 60px; /* 严格贴在导航栏正下方，无重叠 */
    right: -300px; 
    width: 280px; 
    height: calc(100vh - 60px); 
    background-color: var(--bg-card); 
    box-shadow: -4px 0 15px rgba(0,0,0,0.1); 
    z-index: 1000; /* 永远低于导航栏 1001 */
    padding: 0 20px 20px; 
    transition: right 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
    display: flex; 
    flex-direction: column;
    margin: 0;
    border-top: none; /* 无顶部边框，不蹭导航栏 */
}

/* 星空主题：侧栏半透明（无 backdrop 模糊） */
body.cosmic-theme .sidebar {
    background-color: rgba(15, 23, 42, 0.32);
    box-shadow: -8px 0 36px rgba(0, 0, 0, 0.35);
    border-left: 1px solid rgba(255, 255, 255, 0.06);
}

.sidebar.open { 
    right: 0; 
}

/* 搜索框以下区域独立滚动（菜单项多时不撑破视口） */
.sidebar-scroll {
    flex: 1;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

/* 搜索框容器：自动留白，不贴导航栏 */
.sidebar-search-container {
    margin-top: 16px;
    flex-shrink: 0;
}

/* 侧栏搜索：输入框 + 按钮 */
.sidebar-search-row {
    display: flex;
    align-items: stretch;
    gap: 10px;
    margin-bottom: 20px;
}

/* 侧边栏搜索框 */
.sidebar-search { 
    flex: 1;
    min-width: 0;
    width: auto;
    padding: 12px 16px; 
    background: #F3F4F6; 
    border: none; 
    border-radius: 12px; 
    font-size: 14px; 
    margin-bottom: 0; 
    outline: none; 
}

.sidebar-search-btn {
    flex-shrink: 0;
    width: 46px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
    font-family: inherit;
}

.sidebar-search-btn:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.dark-theme .sidebar-search-btn {
    background: #333333;
    border-color: #333333;
}

.dark-theme .sidebar-search-btn:hover {
    border-color: #555555;
    color: var(--text-main);
}

.cosmic-theme .sidebar-search-btn {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--text-main);
}

.cosmic-theme .sidebar-search-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(165, 180, 252, 0.45);
    color: var(--primary-light);
}

.dark-theme .sidebar-search { 
    background: #333333; 
    color: var(--text-main); 
}

.cosmic-theme .sidebar-search {
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-main);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* 侧边栏分隔线 */
.sidebar-divider { 
    height: 1px; 
    background-color: var(--border-color); 
    margin-bottom: 20px; 
}

/* 侧边栏菜单 */
.sidebar-menu-item { 
    padding: 16px; 
    font-size: 16px; 
    color: var(--text-main); 
    cursor: pointer; 
    border-radius: 12px; 
    transition: background 0.2s; 
    margin-bottom: 8px; 
    display: flex;
    align-items: center; 
    gap: 10px; 
    border-bottom: 1px solid var(--border-color); 
}

.sidebar-menu-item:hover { 
    background-color: #F3F4F6; 
    color: var(--primary); 
}

.dark-theme .sidebar-menu-item:hover { 
    background-color: #333333; 
}

.cosmic-theme .sidebar-menu-item {
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

.cosmic-theme .sidebar-menu-item:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

/* 侧边栏链接 */
.sidebar-menu-item a {
    color: var(--text-main) !important;
    text-decoration: none !important;
    width: 100%;
    display: block;
}

.sidebar-menu-item a:hover {
    color: var(--primary) !important;
}

/* 遮罩层 —— 【完整修复】 */
.overlay { 
    position: fixed; 
    top: 60px; /* 👇 只改这一行：从导航栏下方开始，不覆盖导航栏 */
    left: 0; 
    width: 100%; 
    height: calc(100vh - 60px); /* 👇 高度匹配侧边栏，不碰导航栏 */
    background: rgba(0,0,0,0.2); 
    z-index: 999; 
    opacity: 0; 
    visibility: hidden; 
    transition: all 0.3s; 
}

.overlay.show { 
    opacity: 1; 
    visibility: visible; 
}

/* 文章项 */
.article-item {
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
    transition: color 0.2s;
}

.article-item:last-child {
    border-bottom: none;
}

.article-item a {
    color: var(--text-sub);
    text-decoration: none;
}

.article-item a:hover {
    color: var(--primary);
    text-decoration: underline;
}

/* 登录/注册页布局 */
.auth-page {
    min-height: calc(100vh - 120px);
    padding: 24px 16px 48px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    background-color: var(--bg-body);
}

.auth-container.auth-card {
    width: 100%;
    max-width: 400px;
    margin: 24px auto 0;
    padding: 28px 24px 26px;
    background-color: var(--bg-card);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
}

.auth-container.auth-card.auth-card--wide {
    max-width: 520px;
}

.auth-profile-section {
    padding-top: 4px;
    margin-bottom: 8px;
    border-top: 1px solid var(--border-color);
}

.auth-profile-section:first-of-type {
    border-top: none;
    padding-top: 0;
}

.auth-profile-section--avatar {
    border-top: none;
    padding-top: 0;
}

.auth-profile-group-field {
    margin-bottom: 4px;
}

.auth-profile-tab-row {
    display: flex;
    gap: 10px;
    margin-top: 4px;
}

.auth-profile-tab {
    flex: 1;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    color: var(--text-sub);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.auth-profile-tab:hover {
    border-color: var(--primary);
    color: var(--text-main);
}

.auth-profile-tab.is-active {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

.auth-profile-panel[hidden] {
    display: none !important;
}

.auth-profile-panel {
    margin-bottom: 4px;
}

.auth-section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-main);
    margin: 0 0 12px;
}

.auth-textarea {
    min-height: 88px;
    resize: vertical;
    line-height: 1.5;
}

select.auth-input {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.auth-avatar-preview-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 12px;
}

img.auth-avatar-preview,
img.user-profile-avatar {
    border-radius: 50%;
    border: 2px solid var(--border-color);
}

input[type="file"].auth-input {
    padding: 10px 12px;
    font-size: 14px;
}

.auth-avatar-upload-field .auth-avatar-upload-slot {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.auth-file-input-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.auth-btn-upload-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 44px;
    font-size: 15px;
}

.auth-avatar-file-name {
    margin: 0;
    min-height: 1.25em;
    font-size: 13px;
    color: var(--text-sub);
    word-break: break-all;
}

.auth-brand {
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--text-sub);
    margin-bottom: 20px;
}

/* Tab */
.auth-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 22px;
    padding: 4px;
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    border: 1px solid var(--border-color);
}

.auth-tab {
    flex: 1;
    padding: 10px 12px;
    border: none;
    border-radius: calc(var(--radius-btn) - 2px);
    background: transparent;
    color: var(--text-sub);
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
    font-family: inherit;
}

.auth-tab:hover {
    color: var(--text-main);
}

.auth-tab.is-active {
    background: var(--bg-card);
    color: var(--primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.auth-panel {
    display: none;
}

.auth-panel.is-visible {
    display: block;
}

.auth-title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 18px;
    text-align: center;
    color: var(--text-main);
}

.auth-title--panel {
    margin-bottom: 16px;
}

.auth-msg {
    padding: 10px 12px;
    border-radius: var(--radius-btn);
    font-size: 14px;
    line-height: 1.45;
    margin-bottom: 16px;
    text-align: center;
}

.auth-msg--error {
    background: rgba(239, 68, 68, 0.1);
    color: #b91c1c;
    border: 1px solid rgba(239, 68, 68, 0.25);
}

.dark-theme .auth-msg--error,
.cosmic-theme .auth-msg--error {
    color: #fca5a5;
}

.auth-msg--success {
    background: rgba(16, 185, 129, 0.12);
    color: #047857;
    border: 1px solid rgba(16, 185, 129, 0.25);
}

.dark-theme .auth-msg--success,
.cosmic-theme .auth-msg--success {
    color: #6ee7b7;
}

.auth-hint {
    font-size: 12px;
    color: var(--text-sub);
    line-height: 1.45;
    margin-top: -8px;
    margin-bottom: 4px;
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.auth-form-register {
    gap: 16px;
}

.auth-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.auth-field-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-main);
}

.auth-field-optional {
    font-weight: 400;
    color: var(--text-sub);
    font-size: 12px;
}

.auth-inline-row {
    display: flex;
    gap: 10px;
    align-items: stretch;
}

.auth-inline-row .auth-input {
    flex: 1;
    min-width: 0;
}

.auth-btn-secondary {
    flex-shrink: 0;
    padding: 0 14px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    color: var(--primary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s, border-color 0.2s;
    font-family: inherit;
}

.auth-btn-secondary:hover:not(:disabled) {
    border-color: var(--primary);
    background: var(--bg-card);
}

.auth-btn-secondary:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}

.auth-register-feedback {
    margin-bottom: 14px;
}

.auth-register-feedback[hidden] {
    display: none !important;
}

.auth-label-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--text-sub);
    cursor: pointer;
    user-select: none;
}

.auth-label-row input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--primary);
}

.auth-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background-color: var(--bg-body);
    color: var(--text-main);
    outline: none;
    font-size: 15px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.auth-input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.18);
}

.auth-input::placeholder {
    color: var(--text-sub);
    opacity: 0.85;
}

.auth-password-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.auth-password-wrap .auth-input {
    padding-right: 44px;
}

.auth-toggle-pwd {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text-sub);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s, color 0.2s;
}

.auth-toggle-pwd:hover {
    background: var(--bg-body);
    color: var(--primary);
}

.auth-btn {
    width: 100%;
    padding: 13px 16px;
    margin-top: 4px;
    border: none;
    border-radius: var(--radius-btn);
    background-color: var(--primary);
    color: white;
    font-weight: 500;
    font-size: 15px;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s;
}

.auth-btn:hover {
    background-color: var(--primary-light);
}

.auth-btn:active {
    transform: scale(0.99);
}

input.auth-btn {
    -webkit-appearance: none;
    appearance: none;
}

.auth-footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px 16px;
    margin-top: 18px;
    font-size: 14px;
}

.auth-footer-links a {
    color: var(--primary);
    text-decoration: none;
}

.auth-footer-links a:hover {
    text-decoration: underline;
}

.auth-note {
    margin-top: 14px;
    font-size: 12px;
    color: var(--text-sub);
    line-height: 1.5;
    text-align: center;
}

/* 个人中心等沿用旧类名 */
.auth-container:not(.auth-card) {
    max-width: 400px;
    margin: 40px auto;
    padding: 20px;
    background-color: var(--bg-card);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
}

.auth-link {
    text-align: center;
    margin-top: 15px;
    font-size: 14px;
}

.auth-link a {
    color: var(--primary);
    text-decoration: none;
}

.auth-link a:hover {
    text-decoration: underline;
}

/* 菜单图标 */
.ri-menu-3-line {
    font-size: 18px !important;
    margin-right: 5px;
}

/* ---------- 分类页（category.php 等） ---------- */
.category-page {
    padding-top: 80px;
    background-color: #f9fafb;
    min-height: 100vh;
}

.dark-theme .category-page {
    background-color: var(--bg-body);
}

.cosmic-theme .category-page {
    background-color: transparent;
}

.category-title-card {
    background: #fff;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 16px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.dark-theme .category-title-card {
    background: var(--bg-card) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

.cosmic-theme .category-title-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.category-title {
    font-size: 28px;
    font-weight: 700;
    margin: 0;
    color: #111827;
}

.dark-theme .category-title,
.cosmic-theme .category-title {
    color: var(--text-main);
}

.notice-card {
    background: #fffbeb;
    border: 1px solid #fef3c7;
    border-radius: 12px;
    padding: 16px;
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 16px;
}

.dark-theme .notice-card {
    background: #252525 !important;
    border: 1px solid #333333 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

.cosmic-theme .notice-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.notice-img img {
    width: 60px;
    height: 60px;
    border-radius: 10px;
    object-fit: cover;
}

.notice-info .notice-title,
.notice-card .notice-title {
    font-size: 16px;
    color: #92400e;
    margin: 0 0 4px;
    font-weight: 600;
}

.dark-theme .notice-card .notice-title {
    color: var(--text-main) !important;
}

.cosmic-theme .notice-card .notice-title {
    color: #fcd34d !important;
}

.notice-info .notice-desc {
    font-size: 14px;
    color: #b45309;
    margin: 0;
}

/* 分类页可点击公告条：固定高度，文案多行省略 */
.notice-card.notice-card--interactive {
    height: 72px;
    min-height: 72px;
    max-height: 72px;
    box-sizing: border-box;
    padding: 8px 10px;
    margin-bottom: 1px;
    gap: 8px;
    background: #fff9e6;
    border: 1px solid #fef3c7;
    border-radius: 8px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
    cursor: pointer;
    align-items: center;
    overflow: hidden;
}

.dark-theme .notice-card.notice-card--interactive {
    background: #252525 !important;
    border-color: #333333 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

.cosmic-theme .notice-card.notice-card--interactive {
    background: rgba(15, 23, 42, 0.45) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: none !important;
}

.notice-card--interactive:focus {
    outline: 2px solid var(--primary-light, #6366f1);
    outline-offset: 2px;
}

.notice-card--interactive:focus:not(:focus-visible) {
    outline: none;
}

.notice-card--interactive .notice-img {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    flex-shrink: 0;
    border-radius: 6px;
    overflow: hidden;
}

.notice-card--interactive .notice-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.notice-card--interactive .notice-info {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
}

.notice-card--interactive .notice-title {
    margin: 0 !important;
    padding: 0;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1.3;
    color: #8b4513 !important;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    word-break: break-word;
}

.dark-theme .notice-card--interactive .notice-title,
.cosmic-theme .notice-card--interactive .notice-title {
    color: var(--text-main) !important;
}

.notice-card--interactive .notice-hint {
    margin: 2px 0 0;
    padding: 0;
    font-size: 11px;
    line-height: 1.2;
    color: #a16207;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dark-theme .notice-card--interactive .notice-hint,
.cosmic-theme .notice-card--interactive .notice-hint {
    color: var(--text-sub) !important;
}

.notice-card--interactive .notice-card__chev {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    color: #a16207;
    font-size: 18px;
    line-height: 1;
}

.cosmic-theme .notice-card--interactive .notice-card__chev {
    color: var(--primary-light) !important;
}

.sign-card {
    background: #fff;
    border-radius: 12px;
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.dark-theme .sign-card {
    background: var(--bg-card) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

.cosmic-theme .sign-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* 覆盖 category.php 内联签到按钮色块 */
.cosmic-theme .sign-card .sign-btn,
.cosmic-theme .sign-card #noLoginSignBtn {
    background: transparent !important;
    color: var(--primary) !important;
    border: none !important;
}

.cosmic-theme .sign-card .sign-btn.signed {
    background: transparent !important;
    color: #6ee7b7 !important;
}

.cosmic-theme .sign-card .sign-btn:hover:not(.signed):not(:disabled) {
    background: transparent !important;
    color: var(--primary-light) !important;
}

.cosmic-theme .sign-card .sign-points > span:first-child {
    color: var(--text-sub) !important;
}

.cosmic-theme .sign-card .sign-desc {
    color: var(--text-sub) !important;
}

/* 分类页等处 .points-num 带内联颜色时统一用主色字 */
.dark-theme .sign-card .points-num {
    color: var(--text-main) !important;
}

.cosmic-theme .points-num {
    color: var(--primary) !important;
}

.sign-info .sign-points,
.sign-points {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sign-points span:first-child {
    font-size: 16px;
    color: #6b7280;
}

.dark-theme .sign-card .sign-points > span:first-child {
    color: var(--text-sub) !important;
}

.dark-theme .sign-points span:first-child,
.cosmic-theme .sign-points span:first-child {
    color: var(--text-sub);
}

.points-num {
    font-size: 40px;
    font-weight: 700;
    color: #4f46e5;
}

.sign-desc {
    font-size: 14px;
    color: #6b7280;
    margin: 8px 0 0;
}

.sign-btn {
    background: #4f46e5;
    color: #fff;
    padding: 14px 28px;
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    font-size: 16px;
    border: none;
    transition: 0.3s;
}

.sign-btn.signed {
    background: #10b981;
    cursor: default;
}

.sign-btn:hover:not(.signed) {
    background: #4338ca;
    transform: translateY(-2px);
}

.lock-tag {
    color: #f97316;
    font-size: 15px;
    margin-left: 8px;
    font-weight: 500;
}

.free-tag {
    color: #10b981;
    font-size: 15px;
    margin-left: 8px;
    font-weight: 500;
}

.article-item-card {
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.dark-theme .article-item-card {
    background: var(--bg-card) !important;
    border-bottom: 1px solid #333333 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15) !important;
}

.cosmic-theme .article-item-card {
    background: transparent !important;
    border: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

.cosmic-theme .article-item-card .article-title a {
    color: var(--text-main) !important;
}

.cosmic-theme .article-item-card .article-desc {
    color: var(--text-sub) !important;
}

.cosmic-theme .article-item-card .article-meta,
.cosmic-theme .article-item-card .article-meta span {
    color: var(--text-sub) !important;
}

/* 排序工具条（toolbar-sort-post.php 内联白底） */
.cosmic-theme .module-sort-toolbar {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
}

.cosmic-theme .module-sort-toolbar > div:first-child {
    color: var(--text-sub) !important;
}

.cosmic-theme .gr-toolbar-sort {
    background: transparent !important;
    color: var(--text-sub) !important;
    border: 1px solid transparent !important;
}

.cosmic-theme .gr-toolbar-sort.is-active {
    color: var(--primary) !important;
    font-weight: 600;
}

.cosmic-theme .gr-toolbar-post {
    background: transparent !important;
    color: #34d399 !important;
    border: 1px solid transparent !important;
}

/* 夜晚主题：排序条与按钮（覆盖 toolbar-sort-post.php 内联色） */
.dark-theme .module-sort-toolbar {
    background: var(--bg-card) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

.dark-theme .module-sort-toolbar > div:first-child {
    color: var(--text-sub) !important;
}

.dark-theme a.gr-toolbar-sort:not(.is-active) {
    background: #333333 !important;
    color: var(--text-main) !important;
    border: 1px solid #333333 !important;
}

.dark-theme a.gr-toolbar-sort.is-active {
    background: var(--primary) !important;
    color: #ffffff !important;
    border: 1px solid var(--primary) !important;
}

.dark-theme a.gr-toolbar-post {
    background: #047857 !important;
    color: #ffffff !important;
    border: 1px solid #065f46 !important;
}

.dark-theme .sign-card .sign-desc {
    color: var(--text-sub) !important;
}

.dark-theme .sign-card .sign-btn,
.dark-theme .sign-card #noLoginSignBtn {
    background: var(--primary) !important;
    color: #ffffff !important;
}

.dark-theme .sign-card .sign-btn:hover:not(.signed):not(:disabled) {
    background: var(--primary-light) !important;
}

.dark-theme .sign-card .sign-btn.signed {
    background: #065f46 !important;
    color: #ecfdf5 !important;
}

.dark-theme .article-item-card .article-title a {
    color: var(--text-main) !important;
}

.dark-theme .article-item-card .article-desc {
    color: var(--text-sub) !important;
}

.dark-theme .article-item-card .article-meta,
.dark-theme .article-item-card .article-meta span {
    color: var(--text-sub) !important;
}

.dark-theme .article-item-card .pending-tag {
    color: #fbbf24 !important;
}

.dark-theme .article-list-empty {
    color: var(--text-sub) !important;
}

/* 星空主题：板块列表区仅保留文字/数字与缩略图，其余底与线透明 */
.cosmic-theme .article-desc,
.cosmic-theme .article-meta,
.cosmic-theme .article-meta span {
    color: var(--text-sub);
}

.cosmic-theme .sign-desc {
    color: var(--text-sub);
}

.cosmic-theme .notice-info .notice-desc,
.cosmic-theme .notice-card .notice-desc {
    color: var(--text-sub);
}

.cosmic-theme .article-img {
    background: transparent;
    box-shadow: none;
}

.cosmic-theme .swiper-pagination-bullet {
    background-color: rgba(255, 255, 255, 0.22) !important;
}

.cosmic-theme .swiper-pagination-bullet-active {
    background-color: rgba(255, 255, 255, 0.55) !important;
}

.article-img {
    width: 80px;
    height: 80px;
    border-radius: 10px;
    overflow: hidden;
    flex-shrink: 0;
}

.article-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-img.no-img {
    background: #e5e7eb;
}

.article-right {
    flex: 1;
}

.article-title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 6px;
}

.article-title a {
    color: #111827;
    text-decoration: none;
}

.dark-theme .article-title a,
.cosmic-theme .article-title a {
    color: #f9fafb;
}

.article-desc {
    font-size: 15px;
    color: #6b7280;
    margin: 0 0 10px;
    line-height: 1.5;
}

.article-meta {
    display: flex;
    gap: 20px;
    font-size: 14px;
    color: #6b7280;
    flex-wrap: wrap;
}

.article-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* 分页：paginate_links（分类页）+ .page-btn（回收站模板） */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 15px;
    padding: 0 10px 20px;
}

.pagination a.page-numbers,
.pagination span.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    padding: 8px 14px;
    border-radius: var(--radius-btn);
    text-decoration: none;
    font-size: 14px;
    transition: background 0.2s, color 0.2s;
}

.pagination a.page-numbers {
    background: var(--bg-card);
    color: var(--text-main);
    box-shadow: var(--shadow);
}

.pagination a.page-numbers:hover {
    background: var(--primary);
    color: #fff;
}

.pagination span.page-numbers.current {
    background: var(--primary);
    color: #fff;
    cursor: default;
}

.pagination span.page-numbers.dots {
    background: transparent;
    box-shadow: none;
    color: var(--text-sub);
}

.page-btn {
    padding: 12px 24px;
    border-radius: 10px;
    background: #e5e7eb;
    color: #6b7280;
    text-decoration: none;
    font-size: 16px;
    transition: 0.3s;
}

.page-btn:hover:not(.disabled) {
    background: #4f46e5;
    color: #fff;
}

.page-btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.page-info {
    font-size: 16px;
    color: #6b7280;
}

/* 前台发帖（与 auth-card 一致，略加宽） */
.auth-container.auth-card.auth-card--post {
    max-width: 640px;
}

.game-new-post-textarea {
    min-height: 200px;
    font-family: inherit;
}

.game-post-dual-field {
    margin-bottom: 4px;
}

.game-post-dual-field .game-new-post-textarea {
    min-height: 140px;
}

.game-post-dual-hint {
    margin: 0 0 8px;
    font-size: 12px;
    line-height: 1.45;
    color: var(--text-muted, #6b7280);
}

.article-detail-content--public {
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-color, rgba(0, 0, 0, 0.08));
}

.article-detail-content--locked {
    margin-top: 4px;
}

.article-paywall-locked--after-free {
    margin-top: 12px;
}

.game-new-post-admin-only {
    padding: 12px;
    border-radius: var(--radius-btn);
    border: 1px dashed var(--border-color);
    background: var(--bg-body);
}

.dark-theme .game-new-post-admin-only {
    border-color: #4b5563;
}

.cosmic-theme .game-new-post-admin-only {
    background: transparent;
    border-color: transparent;
}

.cosmic-theme .game-new-post-preview-item {
    background: transparent;
    border-color: transparent;
}

.game-new-post-previews {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.game-new-post-preview-item {
    position: relative;
    width: 76px;
    height: 76px;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    background: var(--bg-body);
}

.game-new-post-preview-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.game-new-post-preview-remove {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 22px;
    height: 22px;
    padding: 0;
    border: none;
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.game-new-post-preview-remove:hover {
    background: #ef4444;
}

.game-post-inline-img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
}

/* 四大板块：仅上一页 / 下一页 */
.game-prev-next-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.game-pn-page-info {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-sub);
    min-width: 7em;
    text-align: center;
}

.game-pn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 120px;
    padding: 10px 18px;
    border-radius: var(--radius-btn);
    background: var(--primary);
    color: #fff !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    border: none;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s;
}

.game-pn-btn:hover:not(.game-pn-btn--disabled) {
    background: var(--primary-light);
}

.game-pn-btn--disabled {
    background: var(--border-color);
    color: var(--text-sub) !important;
    cursor: default;
    opacity: 0.85;
}

.dark-theme .game-pn-btn--disabled {
    background: #333333;
    color: var(--text-sub) !important;
}

.cosmic-theme .game-pn-btn--disabled {
    background: transparent;
    color: var(--text-sub) !important;
}

.cosmic-theme .game-pn-btn {
    background: transparent;
    color: var(--primary) !important;
    border: 1px solid transparent;
}

.cosmic-theme .game-pn-btn:hover:not(.game-pn-btn--disabled) {
    background: transparent;
    color: var(--primary-light) !important;
}

/* 文章详情页 */
.article-detail-page {
    max-width: 680px;
    margin: 0 auto;
    padding: 16px 16px 40px;
}

.article-detail-card {
    background: var(--bg-card);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
    padding: 20px 22px 24px;
    margin-bottom: 16px;
}

.article-detail-title {
    margin: 0 0 14px;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--text-main);
}

.article-detail-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    margin-bottom: 12px;
}

.article-detail-toolbar--after {
    margin-top: 20px;
    margin-bottom: 0;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.article-detail-comment-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: var(--radius-btn);
    border: 1px solid var(--border-color);
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none !important;
    font-family: inherit;
    transition: border-color 0.2s, background 0.2s, color 0.2s;
}

.article-detail-comment-btn:hover {
    border-color: var(--primary);
    color: var(--primary);
}

button.article-detail-comment-btn {
    cursor: pointer;
}

.article-detail-delete-btn {
    border-color: rgba(185, 28, 28, 0.45);
    color: #b91c1c;
}

.article-detail-delete-btn:hover {
    border-color: #b91c1c;
    color: #dc2626;
}

.article-detail-fav-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: var(--radius-btn);
    border: 1px solid var(--border-color);
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: border-color 0.2s, background 0.2s, color 0.2s;
}

.article-detail-fav-btn:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.article-detail-fav-btn.is-on {
    border-color: #f59e0b;
    background: rgba(245, 158, 11, 0.12);
    color: #b45309;
}

.dark-theme .article-detail-fav-btn.is-on {
    color: #fcd34d;
    background: rgba(245, 158, 11, 0.15);
}

.cosmic-theme .article-detail-fav-btn.is-on {
    color: #fcd34d;
    background: transparent;
    border-color: transparent;
}

.article-detail-fav-btn:disabled {
    opacity: 0.65;
    cursor: wait;
}

.article-detail-stat {
    font-size: 13px;
    color: var(--text-sub);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.article-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    font-size: 13px;
    color: var(--text-sub);
    padding-bottom: 14px;
    margin-bottom: 4px;
    border-bottom: 1px solid var(--border-color);
}

.article-detail-content {
    margin-top: 16px;
    font-size: 15px;
    line-height: 1.75;
    color: var(--text-main);
}

.article-detail-content img {
    max-width: 100%;
    height: auto;
    border-radius: 10px;
}

/* 积分付费：详情页锁定区与购买弹窗 */
.article-paywall-actions {
    margin-top: 18px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.article-unlock-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: var(--radius-btn);
    border: 1px solid var(--primary);
    background: var(--primary);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.2s, transform 0.15s;
}

.article-unlock-btn:hover {
    opacity: 0.92;
}

.article-unlock-btn--primary {
    flex: 1;
    min-width: 0;
    justify-content: center;
}

.article-paywall-hint {
    margin: 0;
    font-size: 13px;
    color: var(--text-sub);
}

.article-paywall-locked {
    margin-top: 28px;
    min-height: 220px;
    border-radius: var(--radius-card);
    border: 1px dashed var(--border-color);
    background: var(--bg-body);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 32px 20px;
}

.article-paywall-locked-inner {
    max-width: 280px;
}

.article-paywall-lock-icon {
    font-size: 52px;
    color: var(--text-sub);
    opacity: 0.55;
    display: block;
    margin: 0 auto 12px;
}

.article-paywall-locked-title {
    margin: 0 0 6px;
    font-size: 17px;
    font-weight: 600;
    color: var(--text-main);
}

.article-paywall-locked-desc {
    margin: 0;
    font-size: 14px;
    color: var(--text-sub);
    line-height: 1.5;
}

body.game-unlock-modal-active {
    overflow: hidden;
}

/* ---------- 文章搜索结果页 search.php ---------- */
.game-search-page__intro {
    background: #fff;
    border-radius: 16px;
    padding: 16px 18px;
    margin-bottom: 12px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.dark-theme .game-search-page__intro {
    background: var(--bg-card);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.cosmic-theme .game-search-page__intro {
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.game-search-page__title {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--text-main);
}

.game-search-page__keyword {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
    color: var(--text-sub);
}

.game-search-page__list {
    margin-bottom: 4px;
}

.game-search-page__result {
    background: #fff;
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 8px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
    border: 1px solid #f0f0f0;
}

.dark-theme .game-search-page__result {
    background: var(--bg-card);
    border-color: var(--border-color);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.cosmic-theme .game-search-page__result {
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

.game-search-page__result-title {
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.35;
}

.game-search-page__result-title a {
    color: var(--text-main);
    text-decoration: none;
}

.game-search-page__result-title a:hover {
    color: var(--primary);
}

.game-search-page__snippet {
    margin: 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-sub);
}

.game-search-page__empty {
    margin: 0;
    padding: 48px 16px;
    text-align: center;
    font-size: 14px;
    color: var(--text-sub);
}

.game-search-page__pager {
    margin-top: 8px;
    padding-bottom: 24px;
}

.game-unlock-modal {
    position: fixed;
    inset: 0;
    z-index: 100050;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}

.game-unlock-modal[hidden] {
    display: none !important;
}

.game-unlock-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(2px);
}

.game-unlock-modal__panel {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 380px;
    padding: 22px 22px 18px;
    border-radius: var(--radius-card);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
}

.game-unlock-modal__title {
    margin: 0 0 12px;
    font-size: 18px;
    font-weight: 600;
    color: var(--text-main);
}

.game-unlock-modal__text {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-main);
}

.game-unlock-modal__points {
    margin: 0 0 16px;
    font-size: 14px;
    color: var(--text-sub);
}

.game-unlock-modal__guest {
    margin: 0 0 16px;
    font-size: 14px;
    color: var(--text-sub);
}

.game-unlock-modal__guest a {
    color: var(--primary);
    font-weight: 600;
}

.game-unlock-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.game-unlock-modal__cancel {
    padding: 10px 16px;
    border-radius: var(--radius-btn);
    border: 1px solid var(--border-color);
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 14px;
    cursor: pointer;
    font-family: inherit;
}

.game-unlock-modal__cancel:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.article-detail-card--comments {
    padding-top: 18px;
}

.article-detail-comments-heading {
    margin: 0 0 14px;
    font-size: 18px;
    font-weight: 600;
    color: var(--text-main);
    display: flex;
    align-items: center;
    gap: 8px;
}

.article-detail-comments-count {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-sub);
}

.game-comment-list {
    list-style: none;
    margin: 0 0 16px;
    padding: 0;
}

.game-comment-list .comment {
    list-style: none;
    margin: 0 0 12px;
    padding: 0;
    border: none;
    background: transparent;
}

.game-comment-list .comment-body {
    display: grid;
    grid-template-columns: 1fr auto;
    column-gap: 12px;
    row-gap: 12px;
    align-items: center;
    padding: 20px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-card);
}

.game-comment-list .pingback .comment-body,
.game-comment-list .trackback .comment-body {
    display: block;
    font-size: 14px;
    line-height: 1.6;
    color: var(--text-main);
}

.game-comment-list .comment-meta {
    display: contents;
}

.game-comment-list .comment-author {
    grid-row: 1;
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    min-width: 0;
}

.game-comment-list .says {
    display: none;
}

.game-comment-list .comment-awaiting-moderation {
    grid-row: 2;
    grid-column: 1 / -1;
    margin: 0;
    font-size: 13px;
    font-style: normal;
    color: var(--text-sub);
}

.game-comment-list .avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    flex-shrink: 0;
}

.game-comment-list .children {
    list-style: none;
    margin: 10px 0 0 12px;
    padding: 0;
}

.comment-author .fn,
.comment-author .fn a {
    font-weight: 500;
    font-size: 15px;
    color: var(--text-main);
    text-decoration: none;
}

.game-comment-list a.game-comment-author-profile:hover {
    color: var(--primary);
    text-decoration: underline;
}

.game-comment-author-admin {
    color: var(--comment-admin-label-color, #22c55e);
    font-weight: 600;
}

.dark-theme .game-comment-author-admin {
    color: var(--comment-admin-label-color, #4ade80);
}

.cosmic-theme .game-comment-author-admin {
    color: var(--comment-admin-label-color, #86efac);
}

.game-comment-list .game-comment-author-level {
    font-size: 0.867em;
    font-weight: 500;
}

.game-comment-list .comment-metadata,
.game-comment-list .comment-metadata a {
    grid-column: 1;
    justify-self: start;
    font-size: 13px;
    color: var(--text-sub);
}

.game-comment-list .comment-body:not(:has(.comment-awaiting-moderation)) .comment-metadata,
.game-comment-list .comment-body:not(:has(.comment-awaiting-moderation)) .comment-metadata a {
    grid-row: 3;
}

.game-comment-list .comment-body:has(.comment-awaiting-moderation) .comment-metadata,
.game-comment-list .comment-body:has(.comment-awaiting-moderation) .comment-metadata a {
    grid-row: 4;
}

.game-comment-list .comment-metadata a {
    text-decoration: none;
}

.game-comment-list .comment-metadata a:hover {
    color: var(--text-main);
}

.game-comment-list .comment-content {
    grid-column: 1 / -1;
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-main);
}

.game-comment-list .comment-body:not(:has(.comment-awaiting-moderation)) .comment-content {
    grid-row: 2;
}

.game-comment-list .comment-body:has(.comment-awaiting-moderation) .comment-content {
    grid-row: 3;
}

.game-comment-list .reply {
    grid-column: 2;
    justify-self: end;
    margin: 0;
    font-size: 13px;
}

.game-comment-list .comment-body:not(:has(.comment-awaiting-moderation)) .reply {
    grid-row: 3;
}

.game-comment-list .comment-body:has(.comment-awaiting-moderation) .reply {
    grid-row: 4;
}

.game-comment-list .reply a {
    color: var(--text-sub);
    text-decoration: none;
    transition: color 0.2s ease;
}

.game-comment-list .reply a:hover {
    color: var(--text-main);
}

.game-comments-closed {
    font-size: 14px;
    color: var(--text-sub);
    margin-bottom: 12px;
}

.game-comment-form .comment-form-author,
.game-comment-form .comment-form-email,
.game-comment-form .comment-form-url {
    margin-bottom: 12px;
}

.game-comment-form label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 6px;
    color: var(--text-main);
}

.game-comment-form input[type="text"],
.game-comment-form input[type="email"],
.game-comment-form input[type="url"] {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 15px;
}

.game-comment-form textarea#comment {
    width: 100%;
    min-height: 120px;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    color: var(--text-main);
    font-size: 15px;
    font-family: inherit;
    line-height: 1.5;
    resize: vertical;
}

.game-comment-form .form-submit {
    margin-top: 12px;
}

.game-comment-must-log-in {
    font-size: 14px;
    line-height: 1.5;
    color: var(--text-sub);
    margin-bottom: 12px;
}

.game-comment-must-log-in a {
    color: var(--primary);
    font-weight: 600;
}

/* 个人中心文章列表（外层滑动区域，避免文章过多撑满页面） */
.profile-post-list-scroll {
    max-height: min(360px, 48vh);
    overflow-y: auto;
    overflow-x: hidden;
    margin-top: 10px;
    padding: 6px 10px 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-btn);
    background: var(--bg-body);
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.profile-post-list-scroll:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

.profile-post-list-scroll::-webkit-scrollbar {
    width: 8px;
}

.profile-post-list-scroll::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}

.profile-post-list-scroll::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

.profile-post-list-scroll::-webkit-scrollbar-thumb:hover {
    background: var(--text-sub);
}

/* 个人中心文章列表 */
.profile-post-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.profile-post-item {
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
}

.profile-post-item:last-child {
    border-bottom: none;
}

.profile-post-link {
    display: block;
    font-size: 15px;
    font-weight: 500;
    color: var(--primary);
    text-decoration: none;
    margin-bottom: 4px;
}

.profile-post-link:hover {
    text-decoration: underline;
}

.profile-post-meta {
    display: block;
    font-size: 12px;
    color: var(--text-sub);
}

.profile-posts-block {
    margin-top: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}

/* ---------- 管理员用户列表（user-list.php） ---------- */
.game-ulist-page .game-ulist-inner {
    max-width: 640px;
    margin: 0 auto;
    padding: 15px 16px 32px;
}

.game-ulist-title-card .game-ulist-lead {
    margin: 10px 0 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-sub);
}

.game-ulist-notice--ok {
    background: #ecfdf5 !important;
    border-color: #a7f3d0 !important;
}

.game-ulist-notice--ok .game-ulist-notice-title {
    color: #065f46 !important;
    margin: 0;
}

.game-ulist-notice--err {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
}

.game-ulist-notice--err .game-ulist-notice-title {
    color: #b91c1c !important;
    margin: 0;
}

.dark-theme .game-ulist-notice--ok,
.cosmic-theme .game-ulist-notice--ok {
    background: rgba(16, 185, 129, 0.12) !important;
    border-color: rgba(16, 185, 129, 0.35) !important;
}

.dark-theme .game-ulist-notice--ok .game-ulist-notice-title,
.cosmic-theme .game-ulist-notice--ok .game-ulist-notice-title {
    color: #6ee7b7 !important;
}

.dark-theme .game-ulist-notice--err,
.cosmic-theme .game-ulist-notice--err {
    background: rgba(239, 68, 68, 0.12) !important;
    border-color: rgba(239, 68, 68, 0.35) !important;
}

.dark-theme .game-ulist-notice--err .game-ulist-notice-title,
.cosmic-theme .game-ulist-notice--err .game-ulist-notice-title {
    color: #fca5a5 !important;
}

.game-ulist-toolbar {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
    padding: 16px;
    margin-bottom: 14px;
}

.cosmic-theme .game-ulist-toolbar {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

.game-ulist-search-form {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-bottom: 14px;
}

.game-ulist-search-input {
    flex: 1;
    min-width: 160px;
    margin: 0 !important;
}

.game-ulist-search-btn {
    flex-shrink: 0;
    margin: 0 !important;
}

.game-ulist-sort-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
    font-size: 14px;
}

.game-ulist-sort-label {
    color: var(--text-sub);
    font-weight: 500;
}

.game-ulist-sort-link {
    color: var(--primary);
    text-decoration: none;
    font-weight: 500;
    padding: 6px 10px;
    border-radius: var(--radius-btn);
    border: 1px solid transparent;
}

.game-ulist-sort-link:hover {
    text-decoration: underline;
    background: rgba(99, 102, 241, 0.08);
}

.game-ulist-sort-link.is-active {
    border-color: var(--primary);
    background: rgba(99, 102, 241, 0.1);
}

.game-ulist-hint,
.game-ulist-meta {
    font-size: 13px;
    color: var(--text-sub);
    margin: 0 0 10px;
    line-height: 1.45;
}

.game-ulist-cards {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.game-ulist-empty {
    text-align: center;
    padding: 40px 16px;
    color: var(--text-sub);
    font-size: 14px;
    background: var(--bg-card);
    border-radius: var(--radius-card);
    border: 1px solid var(--border-color);
}

.game-ulist-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.cosmic-theme .game-ulist-card {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

/* 折叠行：仅 summary 显示用户名 + 三项数值 */
.game-ulist-details > summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 14px;
    min-height: 48px;
    user-select: none;
}

.game-ulist-details > summary::-webkit-details-marker {
    display: none;
}

.game-ulist-details > summary::marker {
    content: '';
}

.game-ulist-summary-text {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px 10px;
    flex: 1;
    min-width: 0;
}

.game-ulist-summary-login {
    font-weight: 600;
    font-size: 15px;
    color: var(--text-main);
    flex-shrink: 0;
}

.game-ulist-summary-stats {
    font-size: 13px;
    color: var(--text-sub);
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    min-width: 0;
}

.game-ulist-summary-dot {
    opacity: 0.45;
}

.game-ulist-summary-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    font-size: 12px;
    color: var(--text-sub);
}

.game-ulist-summary-hint {
    font-weight: 500;
}

.game-ulist-hint-open {
    display: none;
}

.game-ulist-details[open] .game-ulist-hint-closed {
    display: none;
}

.game-ulist-details[open] .game-ulist-hint-open {
    display: inline;
}

.game-ulist-summary-chevron {
    font-size: 20px;
    color: var(--primary);
    transition: transform 0.2s ease;
}

.game-ulist-details[open] > summary .game-ulist-summary-chevron {
    transform: rotate(180deg);
}

.game-ulist-details[open] > summary .game-ulist-summary-hint {
    color: var(--primary);
}

.game-ulist-details[open] > summary {
    border-bottom: 1px solid var(--border-color);
}

.game-ulist-drawer {
    padding: 0;
}

.game-ulist-drawer-head {
    padding: 14px 16px 0;
}

.game-ulist-drawer-level {
    margin: 6px 0 0;
    font-size: 12px;
    color: var(--text-sub);
}

.game-ulist-details .game-ulist-card-body {
    padding-top: 10px;
}

.game-ulist-card-head {
    padding: 16px;
    border-bottom: 1px solid var(--border-color);
}

.game-ulist-card-identity {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 12px;
}

.game-ulist-avatar {
    border-radius: 12px;
    flex-shrink: 0;
}

.game-ulist-card-name {
    margin: 0 0 4px;
    font-size: 17px;
    font-weight: 600;
    color: var(--text-main);
}

p.game-ulist-card-name {
    font-size: 16px;
}

.game-ulist-card-sub {
    margin: 0;
    font-size: 13px;
    color: var(--text-sub);
    word-break: break-all;
}

.game-ulist-card-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    font-size: 13px;
    color: var(--text-sub);
}

.game-ulist-card-stats strong {
    color: var(--text-main);
}

.game-ulist-card-body {
    padding: 14px 16px 8px;
}

.game-ulist-block {
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
}

.game-ulist-block:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.game-ulist-block-title {
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-main);
}

.game-ulist-inline-form {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 10px;
}

.game-ulist-mini-label {
    font-size: 12px;
    color: var(--text-sub);
    width: 100%;
    margin-bottom: -4px;
}

.game-ulist-num-input {
    width: 100px;
    margin: 0 !important;
}

.game-ulist-btn {
    margin: 0 !important;
}

.game-ulist-pwd-note {
    font-size: 12px;
    color: var(--text-sub);
    margin: 0 0 8px;
    line-height: 1.45;
}

.game-ulist-fake-pwd {
    margin-bottom: 12px;
}

.game-ulist-fake-pwd .auth-input {
    color: var(--text-sub);
    cursor: not-allowed;
    margin: 0 !important;
}

.game-ulist-pwd-form .game-ulist-mini-label {
    margin-bottom: 6px;
}

.game-ulist-pwd-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.game-ulist-pwd-row .auth-input {
    flex: 1;
    min-width: 160px;
    margin: 0 !important;
}

.game-ulist-muted {
    font-size: 13px;
    color: var(--text-sub);
    margin: 0;
}

.game-ulist-btn-del {
    padding: 10px 16px;
    border-radius: var(--radius-btn);
    border: 1px solid #fecaca;
    background: #fef2f2;
    color: #b91c1c;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
}

.game-ulist-btn-del:hover {
    background: #fee2e2;
}

.dark-theme .game-ulist-btn-del,
.cosmic-theme .game-ulist-btn-del {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.4);
    color: #fca5a5;
}

.game-ulist-card-foot {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 16px;
    padding: 12px 16px;
    background: var(--bg-body);
    border-top: 1px solid var(--border-color);
}

.cosmic-theme .game-ulist-card-foot {
    background: rgba(0, 0, 0, 0.15);
}

.game-ulist-link {
    font-size: 13px;
    color: var(--primary);
    text-decoration: none;
}

.game-ulist-link:hover {
    text-decoration: underline;
}

.game-ulist-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 20px;
}

.game-ulist-page-info {
    font-size: 14px;
    color: var(--text-sub);
}

.game-ulist-footer {
    margin-top: 24px;
    justify-content: center;
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* 侧栏「兑换码」可点击项 */
.sidebar-menu-item--action {
    cursor: pointer;
    user-select: none;
}

.sidebar-menu-item--action span {
    color: var(--text-main) !important;
}

.game-redeem-modal .game-redeem-input {
    width: 100%;
    margin-top: 10px;
    box-sizing: border-box;
}

.game-redeem-feedback {
    margin-top: 10px;
    font-size: 14px;
    line-height: 1.45;
}

.game-redeem-feedback--ok {
    color: #059669;
}

.game-redeem-feedback--err {
    color: #dc2626;
}

.game-redeem-vip-hint {
    margin-top: 12px;
    font-size: 13px;
    color: var(--text-sub);
}

.game-redeem-vip-hint summary {
    cursor: pointer;
    color: var(--primary);
}

.game-redeem-vip-hint-list {
    margin: 8px 0 0;
    padding-left: 1.2em;
}

.game-redeem-actions {
    margin-top: 14px;
}

/* 收件箱：未读条、详情弹窗 */
.game-inbox-item--clickable {
    cursor: pointer;
}

.game-inbox-item--clickable:focus {
    outline: 2px solid var(--accent, #6366f1);
    outline-offset: 2px;
}

.game-inbox-item--unread {
    border-left: 3px solid var(--accent, #6366f1);
}

.game-inbox-detail-modal .game-unlock-modal__panel {
    max-width: min(480px, 100%);
}

.game-inbox-detail-modal .game-inbox-modal__hint {
    margin: 0 0 14px;
    font-size: 13px;
    color: var(--text-sub, #6b7280);
    text-align: center;
}

.game-inbox-detail-modal .game-inbox-modal__time {
    margin: 0 0 10px;
    font-size: 13px;
    color: var(--text-sub, #6b7280);
}

.game-inbox-detail-modal .game-inbox-modal__body {
    margin: 0;
    font-size: 15px;
    line-height: 1.65;
    color: var(--text-main, #374151);
    white-space: pre-wrap;
    word-break: break-word;
}

.game-inbox-item__preview a,
.game-inbox-detail-modal .game-inbox-modal__body a {
    color: var(--accent, #6366f1);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.game-inbox-item__preview a:hover,
.game-inbox-detail-modal .game-inbox-modal__body a:hover {
    opacity: 0.9;
}

/* 分类页：公告弹窗 */
.game-notice-modal .game-unlock-modal__panel {
    max-width: min(440px, 100%);
}

.game-notice-modal .game-unlock-modal__title {
    margin-bottom: 10px;
}

.game-notice-modal__hint {
    margin: 0 0 8px;
    font-size: 13px;
    color: var(--text-sub, #6b7280);
    text-align: center;
}

.game-notice-modal__body {
    margin: 0 0 16px;
    max-height: min(52vh, 360px);
    overflow-y: auto;
    padding-right: 4px;
    font-size: 14px;
    line-height: 1.65;
    color: var(--text-main, #374151);
    word-break: break-word;
}

.game-notice-modal__body p:first-child {
    margin-top: 0;
}

.game-notice-modal__body p:last-child {
    margin-bottom: 0;
}

.game-notice-modal__default {
    margin: 0;
}

.game-notice-modal__body a {
    color: var(--primary-light, #6366f1);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.game-notice-modal__actions {
    margin-top: 4px;
    justify-content: flex-end;
    align-items: center;
}

.game-notice-modal__edit {
    margin-right: auto;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-sub, #6b7280);
    text-decoration: none;
}

.game-notice-modal__edit:hover {
    color: var(--primary, #4f46e5);
    text-decoration: underline;
}
