@import url('/static/remixicon/remixicon.css');

:root {
    --bg-color: #09090b;
    --sidebar-bg: #18181b;
    --card-bg: #18181b; /* Zinc 900 */
    --hover-bg: #27272a; /* Zinc 800 */
    --border-color: #27272a;
    --primary-color: #8b5cf6;
    --primary-gradient: linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%);
    --text-color: #ffffff;
    --text-muted: #a1a1aa;
    --success-color: #10b981;
    --warning-color: #f59e0b;
    --danger-color: #ef4444;
}

/* 日间模式 */
[data-theme="light"] {
    --bg-color: #f8f8fc;
    --sidebar-bg: #ffffff;
    --card-bg: #ffffff;
    --hover-bg: #f4f4f8;
    --border-color: #e8e8f0;
    --text-color: #18181b;
    --text-muted: #6b7280;
    --primary-color: #7c3aed;
    --primary-gradient: linear-gradient(135deg, #7c3aed 0%, #c026d3 100%);
}

/* 日间模式 - Header */
[data-theme="light"] .header { background: rgba(255, 255, 255, 0.97) !important; border-bottom-color: #e8e8f0; box-shadow: 0 1px 0 #e8e8f0; }
[data-theme="light"] .logo { color: #18181b; }
[data-theme="light"] .header-btn { border-color: #e8e8f0; color: #6b7280; background: transparent; }
[data-theme="light"] .header-btn:hover { background: #f4f4f8; color: #18181b; border-color: #d1d1e0; }
[data-theme="light"] .header-points { background: #f4f4f8; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .header-points:hover { background: #ede9fe; border-color: rgba(124,58,237,0.3); }
[data-theme="light"] .user-btn { background: #f4f4f8; color: #18181b; border-color: #e8e8f0; }
[data-theme="light"] .user-btn:hover { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.3); }

/* 日间模式 - Sidebar */
[data-theme="light"] .sidebar { background: #fff; border-right-color: #e8e8f0; }
[data-theme="light"] .sidebar-title { color: #9ca3af; letter-spacing: 0.06em; }
[data-theme="light"] .menu-item { color: #374151; }
[data-theme="light"] .menu-item i { color: #9ca3af; }
[data-theme="light"] .menu-item-content span { color: #374151; }
[data-theme="light"] .menu-item .desc { color: #9ca3af; }
[data-theme="light"] .menu-item:hover { background: #f4f4f8; color: #18181b; }
[data-theme="light"] .menu-item:hover i { color: #7c3aed; }
[data-theme="light"] .menu-item.active { background: #ede9fe; border-color: rgba(124,58,237,0.25); }
[data-theme="light"] .menu-item.active i { color: #7c3aed; }
[data-theme="light"] .menu-item.active .menu-item-content span { color: #7c3aed; }
[data-theme="light"] .menu-item.active .desc { color: rgba(124,58,237,0.65); }
[data-theme="light"] .sidebar-footer { background: #fff; border-top-color: #e8e8f0; }

/* 日间模式 - Main Content */
[data-theme="light"] .main { background: #f8f8fc; }
[data-theme="light"] .panel-left { background: #fff; border-right-color: #e8e8f0; }
[data-theme="light"] .panel-right { background: #f8f8fc; }
[data-theme="light"] .panel-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .panel-header h2 { color: #18181b; }
[data-theme="light"] .panel-footer { background: #fff; border-top-color: #e8e8f0; }

/* 日间模式 - Input & Form */
[data-theme="light"] .input-box { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .input-box textarea { color: #18181b; }
[data-theme="light"] .input-box textarea::placeholder { color: #9ca3af; }

/* 日间模式 - Empty State */
[data-theme="light"] .empty-state { color: #6b7280; }
[data-theme="light"] .empty-icon { background: #f4f4f8; }
[data-theme="light"] .empty-icon i { color: #9ca3af; }

/* 日间模式 - 积分弹窗 */
[data-theme="light"] .points-modal { background: #fff; border-color: #e8e8f0; box-shadow: 0 20px 50px rgba(0,0,0,0.12); }
[data-theme="light"] .points-modal-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .points-modal-header h3 { color: #18181b; }
[data-theme="light"] .points-modal-close { color: #9ca3af; }
[data-theme="light"] .points-modal-close:hover { color: #18181b; }
[data-theme="light"] .points-stats { border-bottom-color: #e8e8f0; }
[data-theme="light"] .points-stat-item i { color: #9ca3af; }
[data-theme="light"] .points-stat-item .label { color: #6b7280; }
[data-theme="light"] .points-stat-item .value { color: #18181b; }
[data-theme="light"] .points-tab { border-color: #e8e8f0; color: #6b7280; background: #f8f8fc; }
[data-theme="light"] .points-tab:hover { border-color: rgba(124,58,237,0.3); color: #18181b; background: #f4f4f8; }
[data-theme="light"] .points-tab.active { background: #ede9fe; border-color: #7c3aed; color: #7c3aed; }
[data-theme="light"] .points-log-header h4 { color: #18181b; }
[data-theme="light"] .points-log-filter { background: #f8f8fc; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .points-log-item { border-bottom-color: #f4f4f8; }
[data-theme="light"] .points-log-title { color: #18181b; }
[data-theme="light"] .points-log-time { color: #9ca3af; }
[data-theme="light"] .points-log-empty { color: #9ca3af; }
[data-theme="light"] .points-redeem-title { color: #18181b; }
[data-theme="light"] .points-redeem-desc { color: #6b7280; }
[data-theme="light"] .points-redeem-input input { background: #f8f8fc; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .points-redeem-input input::placeholder { color: #9ca3af; }
[data-theme="light"] .points-redeem-rules { background: #f8f8fc; border: 1px solid #e8e8f0; border-radius: 10px; }
[data-theme="light"] .points-redeem-rules h5 { color: #18181b; }
[data-theme="light"] .points-redeem-rules li { color: #6b7280; }
[data-theme="light"] .points-redeem-rules li::before { color: #9ca3af; }

/* 主题切换按钮 tooltip */
.theme-tooltip { position: absolute; top: 100%; left: 50%; transform: translateX(-50%); margin-top: 8px; padding: 6px 12px; background: #fff; color: #333; font-size: 12px; border-radius: 6px; white-space: nowrap; box-shadow: 0 2px 10px rgba(0,0,0,0.15); opacity: 0; visibility: hidden; transition: all 0.2s; z-index: 1000; }
.theme-tooltip::before { content: ''; position: absolute; top: -6px; left: 50%; transform: translateX(-50%); border-left: 6px solid transparent; border-right: 6px solid transparent; border-bottom: 6px solid #fff; }
.header-btn:hover .theme-tooltip { opacity: 1; visibility: visible; }
[data-theme="light"] .theme-tooltip { background: #18181b; color: #fff; }
[data-theme="light"] .theme-tooltip::before { border-bottom-color: #18181b; }
* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; overflow: hidden; }
body { background: var(--bg-color); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'PingFang SC', sans-serif; color: var(--text-color); }

/* 顶部导航 */
.header { height: 60px; background: var(--sidebar-bg); display: flex; align-items: center; justify-content: space-between; padding: 0 24px; position: fixed; top: 0; left: 0; right: 0; z-index: 100; border-bottom: 1px solid var(--border-color); backdrop-filter: blur(10px); background: rgba(24, 24, 27, 0.8); }
.header-left { display: flex; align-items: center; }
.logo { display: flex; align-items: center; font-size: 18px; font-weight: 700; color: #fff; text-decoration: none; letter-spacing: 0.5px; }
#siteName { }
#siteName.ready { }
.logo-icon { width: 32px; height: 32px; background: var(--primary-gradient); border-radius: 8px; display: flex; align-items: center; justify-content: center; margin-right: 12px; box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3); }
.logo-icon i { color: #fff; font-size: 20px; visibility: hidden; }
.logo-icon.no-custom-logo i { visibility: visible; }
.logo-icon.has-logo { background: none; box-shadow: none; overflow: hidden; }
.logo-icon.has-logo > i { display: none; }
.header-right { display: flex; align-items: center; gap: 12px; }
.header-btn { width: 36px; height: 36px; border-radius: 50%; background: transparent; border: 1px solid var(--border-color); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-muted); transition: all 0.2s; }
.header-btn:hover { background: var(--hover-bg); color: #fff; border-color: var(--hover-bg); }
.header-btn i { font-size: 18px; }
.header-points { display: flex; align-items: center; gap: 6px; padding: 8px 16px; background: rgba(255,255,255,0.05); border: 1px solid var(--border-color); border-radius: 20px; color: #fff; font-size: 13px; font-weight: 500; }
.header-points i { font-size: 16px; color: var(--warning-color); }
.user-btn { display: flex; align-items: center; gap: 8px; background: var(--hover-bg); color: #fff; padding: 6px 12px 6px 6px; border-radius: 24px; font-size: 13px; font-weight: 500; cursor: pointer; transition: all 0.2s; border: 1px solid var(--border-color); }
.user-btn:hover { background: rgba(139,92,246,0.2); border-color: rgba(139,92,246,0.3); }
.user-btn .avatar { width: 28px; height: 28px; background: var(--primary-gradient); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.user-btn .avatar i { font-size: 14px; color: #fff; }
.user-btn .arrow { font-size: 16px; color: var(--text-muted); margin-left: 2px; }

/* 侧边栏 */
.sidebar { width: 240px; background: var(--sidebar-bg); position: fixed; top: 60px; left: 0; bottom: 0; z-index: 99; border-right: 1px solid var(--border-color); display: flex; flex-direction: column; overflow: hidden; }
.sidebar-section { flex: 1; overflow-y: auto; padding: 24px 16px 8px; }
.sidebar-section.ready { }
.sidebar-section::-webkit-scrollbar { width: 4px; }
.sidebar-section::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }
.sidebar-title { font-size: 12px; color: var(--text-muted); padding: 0 12px; margin-bottom: 12px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; }
.menu-item { display: flex; align-items: center; padding: 12px 14px; border-radius: 8px; color: #fff; cursor: pointer; transition: all 0.2s; margin-bottom: 4px; text-decoration: none; border: 1px solid transparent; }
.menu-item:hover { background: var(--hover-bg); color: #fff; }
.menu-item.active { background: rgba(139, 92, 246, 0.1); color: var(--primary-color); border-color: rgba(139, 92, 246, 0.2); }
.menu-item i { font-size: 20px; width: 24px; margin-right: 12px; display: flex; align-items: center; justify-content: center; }
.menu-item-content { flex: 1; overflow: hidden; }
.menu-item-content span { display: block; font-size: 14px; font-weight: 500; line-height: 1.2; color: #fff; }
.menu-item .desc { font-size: 11px; color: rgba(255,255,255,0.6); margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 400; }
.menu-item.active .desc { color: rgba(139, 92, 246, 0.8); }

/* 更多工具折叠菜单 */
.menu-group { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border-color); }
.menu-group-header { display: flex; align-items: center; padding: 12px 14px; border-radius: 8px; color: var(--text-muted); cursor: pointer; transition: all 0.2s; margin-bottom: 4px; user-select: none; }
.menu-group-header:hover { background: var(--hover-bg); color: #fff; }
.menu-group-header i { font-size: 20px; width: 24px; margin-right: 12px; display: flex; align-items: center; justify-content: center; }
.menu-group-header span { flex: 1; font-size: 14px; font-weight: 500; }
.menu-group-header .arrow { font-size: 16px; transition: transform 0.15s ease; }
.menu-group-header.collapsed .arrow { transform: rotate(180deg); }
.menu-group-list { overflow: hidden; max-height: 500px; transition: max-height 0.3s ease-in-out; }
.menu-group-list.collapsed { max-height: 0; }
.menu-group-list .menu-item { padding-left: 50px; padding-top: 8px; padding-bottom: 8px; margin-bottom: 2px; }
.menu-group-list .menu-item i { font-size: 16px; width: 20px; margin-right: 10px; }
.menu-group-list .menu-item-content span { font-size: 13px; }

/* 菜单标签 */
.menu-tag { padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 600; margin-left: auto; flex-shrink: 0; }
.menu-tag.hot { background: linear-gradient(135deg, #ef4444 0%, #f97316 100%); color: #fff; }
.menu-tag.new { background: linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%); color: #fff; }
.menu-tag.fire { background: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%); color: #fff; }
.menu-tag.cool { background: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%); color: #fff; }

/* 日间模式 - 更多工具 */
[data-theme="light"] .menu-group-header { color: #6b7280; }
[data-theme="light"] .menu-group-header:hover { background: #f4f4f8; color: #18181b; }

.sidebar-footer { flex-shrink: 0; position: sticky; bottom: 0; background: var(--sidebar-bg); z-index: 10; padding: 20px; border-top: 1px solid var(--border-color); }

.upgrade-card { background: var(--primary-gradient); border-radius: 12px; padding: 20px; position: relative; overflow: hidden; }
.upgrade-card::before { content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 60%); pointer-events: none; }
.upgrade-card h4 { font-size: 15px; margin-bottom: 6px; font-weight: 600; color: #fff; position: relative; }
.upgrade-card p { font-size: 12px; opacity: 0.9; margin-bottom: 16px; color: #fff; position: relative; }
.upgrade-btn { background: rgba(255,255,255,0.2); border: 1px solid rgba(255,255,255,0.3); color: #fff; padding: 8px 16px; border-radius: 20px; font-size: 12px; cursor: pointer; width: 100%; backdrop-filter: blur(4px); transition: all 0.2s; font-weight: 500; }
.upgrade-btn:hover { background: rgba(255,255,255,0.3); }

/* 主内容区 */
.main { margin-left: 240px; margin-top: 60px; height: calc(100vh - 60px); overflow: hidden; background: var(--bg-color); animation: mainEnter 0.3s ease both; }
@keyframes mainEnter { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.main::-webkit-scrollbar { width: 6px; }
.main::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; }

/* 双栏布局 */
.main-flex { display: flex; height: 100%; overflow: hidden; }
.panel-left { width: 400px; background: var(--sidebar-bg); border-right: 1px solid var(--border-color); display: flex; flex-direction: column; flex-shrink: 0; overflow: hidden; height: 100%; }
.panel-right { flex: 1; display: flex; flex-direction: column; overflow: hidden; background: var(--bg-color); }
.panel-header { padding: 24px; border-bottom: 1px solid var(--border-color); flex-shrink: 0; }
.panel-header h2 { font-size: 20px; font-weight: 600; margin-bottom: 8px; color: #fff; }
.panel-header p { font-size: 13px; color: var(--text-muted); }
.panel-body { padding: 20px; flex: 1; overflow-y: auto; min-height: 0; }
.panel-body::-webkit-scrollbar { width: 4px; }
.panel-body::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }
.panel-footer { padding: 20px; border-top: 1px solid var(--border-color); background: var(--sidebar-bg); flex-shrink: 0; }

/* 通用组件 */
.btn-primary { width: 100%; padding: 14px; background: var(--primary-gradient); border: none; border-radius: 10px; color: #fff; font-size: 15px; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: all 0.3s; box-shadow: 0 4px 15px rgba(139, 92, 246, 0.3); }
.btn-primary:hover { box-shadow: 0 8px 25px rgba(139, 92, 246, 0.5); transform: translateY(-1px); }

.input-box { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 10px; overflow: hidden; transition: border-color 0.2s; }
.input-box:focus-within { border-color: var(--primary-color); }
.input-box textarea { width: 100%; height: 120px; background: transparent; border: none; outline: none; color: #fff; font-size: 14px; line-height: 1.6; resize: none; padding: 16px; }
.input-box textarea::placeholder { color: #52525b; }

.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; text-align: center; padding: 40px; color: var(--text-muted); }
.empty-icon { width: 80px; height: 80px; background: var(--hover-bg); border-radius: 20px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.empty-icon i { font-size: 32px; color: #52525b; }

/* 响应式 */
@media (max-width: 768px) {
    .sidebar { transform: translateX(-100%); transition: transform 0.3s; }
    .sidebar.open { transform: translateX(0); }
    .main { margin-left: 0; }
    .panel-left { width: 100%; }
    .main-flex { flex-direction: column; }
}

/* Layui Layer 弹窗样式修复 - 暗色主题适配 */
body .layui-layer-dialog { background: #fff !important; border-radius: 8px !important; box-shadow: 0 4px 20px rgba(0,0,0,0.3) !important; }
body .layui-layer-dialog .layui-layer-content { color: #333 !important; }
body .layui-layer-msg { background: rgba(0,0,0,0.9) !important; border-radius: 8px !important; }
body .layui-layer-msg .layui-layer-content { color: #fff !important; }
body .layui-layer-title { background: #f8f8f8 !important; color: #333 !important; border-bottom: 1px solid #e5e5e5 !important; border-radius: 8px 8px 0 0 !important; }
body .layui-layer-btn { background: #fff !important; border-radius: 0 0 8px 8px !important; }
body .layui-layer-btn a { background: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%) !important; border: none !important; color: #fff !important; border-radius: 6px !important; }
body .layui-layer-btn .layui-layer-btn1 { background: #e5e5e5 !important; color: #666 !important; }
body .layui-layer-prompt .layui-layer-input { background: #fff !important; border: 1px solid #ddd !important; color: #333 !important; border-radius: 6px !important; }
body .layui-layer-prompt .layui-layer-input:focus { border-color: #8b5cf6 !important; }

/* 积分中心弹窗 */
.points-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.8); z-index: 1100; display: none; align-items: center; justify-content: center; backdrop-filter: blur(5px); }
.points-modal-overlay.active { display: flex; }
.points-modal { width: 520px; max-width: 95vw; max-height: 85vh; background: #141414; border-radius: 16px; border: 1px solid #2a2a2a; box-shadow: 0 20px 50px rgba(0,0,0,0.5); display: flex; flex-direction: column; overflow: hidden; }
.points-modal-header { padding: 20px 24px; border-bottom: 1px solid #2a2a2a; display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.points-modal-header h3 { font-size: 18px; color: #fff; font-weight: 600; }
.points-modal-close { color: #666; font-size: 24px; cursor: pointer; transition: color 0.2s; }
.points-modal-close:hover { color: #fff; }

.points-stats { display: flex; gap: 24px; padding: 20px 24px; border-bottom: 1px solid #2a2a2a; flex-shrink: 0; }
.points-stat-item { display: flex; align-items: center; gap: 8px; }
.points-stat-item i { font-size: 18px; color: #666; }
.points-stat-item .label { font-size: 13px; color: #888; }
.points-stat-item .value { font-size: 18px; color: #fff; font-weight: 600; margin-left: 4px; }
.points-stat-item.total .value { color: #f59e0b; }
.points-recharge-btn { margin-left: auto; padding: 6px 16px; background: linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%); border: none; border-radius: 6px; color: #fff; font-size: 12px; cursor: pointer; transition: all 0.2s; }
.points-recharge-btn:hover { opacity: 0.9; }

.points-tabs { display: flex; gap: 8px; padding: 16px 24px 0; flex-shrink: 0; }
.points-tab { padding: 10px 20px; background: transparent; border: 1px solid #333; border-radius: 8px; color: #888; font-size: 13px; cursor: pointer; transition: all 0.2s; }
.points-tab:hover { border-color: #555; color: #fff; }
.points-tab.active { background: #1f1f1f; border-color: #8b5cf6; color: #fff; }

.points-modal-body { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.points-tab-content { display: none; flex: 1; overflow: hidden; flex-direction: column; }
.points-tab-content.active { display: flex; }

/* 积分记录 Tab */
.points-log-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; flex-shrink: 0; }
.points-log-header h4 { font-size: 14px; color: #fff; font-weight: 500; }
.points-log-filter { padding: 6px 12px; background: #1a1a1a; border: 1px solid #333; border-radius: 6px; color: #fff; font-size: 12px; cursor: pointer; }
.points-log-list { flex: 1; overflow-y: auto; padding: 0 24px 16px; }
.points-log-list::-webkit-scrollbar { width: 4px; }
.points-log-list::-webkit-scrollbar-thumb { background: #333; border-radius: 2px; }
.points-log-item { display: flex; align-items: center; padding: 14px 0; border-bottom: 1px solid #1a1a1a; }
.points-log-item:last-child { border-bottom: none; }
.points-log-icon { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; margin-right: 12px; font-size: 16px; flex-shrink: 0; }
.points-log-icon.income { background: rgba(16,185,129,0.15); color: #10b981; }
.points-log-icon.expense { background: rgba(239,68,68,0.15); color: #ef4444; }
.points-log-info { flex: 1; min-width: 0; }
.points-log-title { font-size: 13px; color: #fff; margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.points-log-time { font-size: 11px; color: #666; }
.points-log-amount { font-size: 16px; font-weight: 600; flex-shrink: 0; }
.points-log-amount.income { color: #10b981; }
.points-log-amount.expense { color: #ef4444; }
.points-log-empty { text-align: center; padding: 40px; color: #666; font-size: 13px; }

/* 卡密兑换 Tab */
.points-redeem { padding: 24px; }
.points-redeem-title { font-size: 15px; color: #fff; font-weight: 500; margin-bottom: 8px; }
.points-redeem-desc { font-size: 12px; color: #888; margin-bottom: 20px; }
.points-redeem-input { display: flex; gap: 12px; margin-bottom: 24px; }
.points-redeem-input input { flex: 1; padding: 12px 16px; background: #1a1a1a; border: 1px solid #333; border-radius: 8px; color: #fff; font-size: 14px; outline: none; transition: border-color 0.2s; }
.points-redeem-input input:focus { border-color: #8b5cf6; }
.points-redeem-input input::placeholder { color: #555; }
.points-redeem-input button { padding: 12px 24px; background: linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%); border: none; border-radius: 8px; color: #fff; font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.2s; white-space: nowrap; }
.points-redeem-input button:hover { opacity: 0.9; }
.points-redeem-input button:disabled { opacity: 0.5; cursor: not-allowed; }
.points-redeem-rules { background: #1a1a1a; border-radius: 10px; padding: 16px; }
.points-redeem-rules h5 { font-size: 13px; color: #fff; margin-bottom: 12px; display: flex; align-items: center; gap: 6px; }
.points-redeem-rules h5 i { color: #f59e0b; }
.points-redeem-rules ul { list-style: none; }
.points-redeem-rules li { font-size: 12px; color: #888; padding: 4px 0; padding-left: 16px; position: relative; }
.points-redeem-rules li::before { content: '•'; position: absolute; left: 0; color: #555; }

/* 积分按钮可点击样式 */
.header-points { cursor: pointer; transition: all 0.2s; }
.header-points:hover { background: rgba(255,255,255,0.1); border-color: rgba(139,92,246,0.3); }


/* ========== 日间模式 - 页面级样式 ========== */

/* 日间模式 - VEO/Banana/Design 等页面左侧面板 */
[data-theme="light"] .veo-left { background: linear-gradient(180deg, #fff 0%, #fafafa 100%); border-right-color: #e8e8f0; }
[data-theme="light"] .veo-header { border-bottom-color: #e8e8f0; background: linear-gradient(135deg, rgba(124,58,237,0.05) 0%, transparent 100%); }
[data-theme="light"] .veo-header h2 { color: #18181b; }
[data-theme="light"] .veo-header p { color: #6b7280; }
[data-theme="light"] .veo-footer { background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, #fff 100%); border-top-color: #e8e8f0; }
[data-theme="light"] .veo-right { background: #f4f4f8; }
[data-theme="light"] .veo-right-header { background: #fff; border-bottom-color: #e8e8f0; }
[data-theme="light"] .veo-right-header h3 { color: #18181b; }
[data-theme="light"] .veo-right-body { background: #f4f4f8; }

/* 日间模式 - Section */
[data-theme="light"] .section-label { color: #18181b; }
[data-theme="light"] .section-label i { color: var(--primary-color); }

/* 日间模式 - Tab 按钮 */
[data-theme="light"] .tab-btn { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .tab-btn:hover { border-color: rgba(124,58,237,0.4); background: rgba(124,58,237,0.05); }
[data-theme="light"] .tab-btn.active { background: #ede9fe; border-color: #7c3aed; color: var(--primary-color); }

/* 日间模式 - Ratio Grid */
[data-theme="light"] .ratio-item { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .ratio-item:hover { border-color: rgba(124,58,237,0.4); background: rgba(124,58,237,0.05); }
[data-theme="light"] .ratio-item.active { background: #ede9fe; border-color: var(--primary-color); color: var(--primary-color); }

/* 日间模式 - Upload Box */
[data-theme="light"] .upload-box { border-color: rgba(124,58,237,0.2); background: linear-gradient(135deg, rgba(124,58,237,0.03) 0%, transparent 100%); }
[data-theme="light"] .upload-box:hover { border-color: rgba(124,58,237,0.4); background: linear-gradient(135deg, rgba(124,58,237,0.06) 0%, transparent 100%); }
[data-theme="light"] .upload-box .t1 { color: #18181b; }
[data-theme="light"] .upload-box .t2 { color: #6b7280; }
[data-theme="light"] .upload-box .plus-icon { border-color: rgba(124,58,237,0.3); color: var(--primary-color); }
[data-theme="light"] .upload-box .select-btn { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.3); color: var(--primary-color); }

/* 日间模式 - Prompt Section */
[data-theme="light"] .prompt-header .label { color: var(--primary-color); }
[data-theme="light"] .prompt-header .action-link { color: #6b7280; background: #f4f4f8; }
[data-theme="light"] .prompt-header .action-link:hover { color: var(--primary-color); background: #ede9fe; }
[data-theme="light"] .prompt-wrapper { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .prompt-textarea { color: #18181b; }
[data-theme="light"] .prompt-textarea::placeholder { color: #9ca3af; }
[data-theme="light"] .prompt-footer { background: #fafafa; border-top-color: #f4f4f8; }
[data-theme="light"] .prompt-footer .deepseek { color: var(--primary-color); }
[data-theme="light"] .prompt-footer .deepseek:hover { background: #ede9fe; }

/* 日间模式 - Template Section */
[data-theme="light"] .template-header .label { color: var(--primary-color); }
[data-theme="light"] .template-header .count { color: #6b7280; }
[data-theme="light"] .template-header .more { color: var(--primary-color); }
[data-theme="light"] .template-item { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .template-item:hover { border-color: rgba(124,58,237,0.5); }

/* 日间模式 - History Grid */
[data-theme="light"] .history-grid { }
[data-theme="light"] .history-card { background: #fff; border: 1px solid #e8e8f0; }
[data-theme="light"] .history-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.1); border-color: #d4d4d8; }
[data-theme="light"] .history-card-img { background: #f4f4f8; }
[data-theme="light"] .history-card-info { background: #fff; }
[data-theme="light"] .history-prompt { color: #6b7280; }
[data-theme="light"] .history-meta { color: #9ca3af; }

/* 日间模式 - Empty State */
[data-theme="light"] .empty { color: #6b7280; }
[data-theme="light"] .empty-icon { background: #f4f4f8; border-color: #e8e8f0; }
[data-theme="light"] .empty-icon i { color: #9ca3af; }
[data-theme="light"] .empty h4 { color: #18181b; }
[data-theme="light"] .empty p { color: #6b7280; }

/* 日间模式 - Preview Modal */
[data-theme="light"] .preview-modal-content { background: #fff; }
[data-theme="light"] .preview-left { background: #f4f4f8; }
[data-theme="light"] .preview-right { background: #fff; border-left-color: #e8e8f0; }
[data-theme="light"] .preview-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .preview-avatar { background: #f4f4f8; color: #9ca3af; }
[data-theme="light"] .preview-name { color: #18181b; }
[data-theme="light"] .preview-tag { color: #9ca3af; }
[data-theme="light"] .preview-action-btn { background: #f4f4f8; color: #6b7280; }
[data-theme="light"] .preview-action-btn:hover { background: #e8e8f0; color: var(--primary-color); }
[data-theme="light"] .preview-section-header > span:first-child { color: #18181b; }
[data-theme="light"] .preview-desc { color: #6b7280; }
[data-theme="light"] .preview-info-row { border-bottom-color: #f4f4f8; }
[data-theme="light"] .preview-info-label { color: #9ca3af; }
[data-theme="light"] .preview-info-value { color: #18181b; }
[data-theme="light"] .preview-footer { border-top-color: #e8e8f0; }

/* 日间模式 - Template Detail Modal */
[data-theme="light"] .tpl-detail-modal { background: #fff; }
[data-theme="light"] .tpl-detail-left { background: #f4f4f8; }
[data-theme="light"] .tpl-detail-title { color: #18181b; }
[data-theme="light"] .tpl-detail-label { color: #6b7280; }
[data-theme="light"] .tpl-detail-prompt { background: #f4f4f8; color: #374151; }
[data-theme="light"] .tpl-detail-tag { background: #ede9fe; border-color: rgba(124,58,237,0.2); }
[data-theme="light"] .tpl-detail-input-img img { border-color: #e8e8f0; }
[data-theme="light"] .tpl-blur-box { background: #f4f4f8; border-color: #e8e8f0; }
[data-theme="light"] .tpl-blur-text { color: #9ca3af; }
[data-theme="light"] .tpl-blur-overlay { background: rgba(244,244,248,0.5); }

/* 日间模式 - DeepSeek Modal */
[data-theme="light"] .deepseek-modal-content { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .deepseek-header { background: linear-gradient(135deg, rgba(124,58,237,0.05) 0%, transparent 100%); border-bottom-color: #e8e8f0; }
[data-theme="light"] .deepseek-header h4 { color: #18181b; }
[data-theme="light"] .deepseek-header .close-btn { color: #9ca3af; }
[data-theme="light"] .deepseek-header .close-btn:hover { color: #18181b; }
[data-theme="light"] .deepseek-msg.ai .msg-content { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.15); color: #18181b; }
[data-theme="light"] .deepseek-quick-btn { background: rgba(124,58,237,0.06); border-color: rgba(124,58,237,0.2); }
[data-theme="light"] .deepseek-quick-btn:hover { background: rgba(124,58,237,0.12); }
[data-theme="light"] .deepseek-prompt-box { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.2); }
[data-theme="light"] .deepseek-prompt-box .prompt-text { color: #18181b; }
[data-theme="light"] .deepseek-footer { border-top-color: #e8e8f0; }
[data-theme="light"] .deepseek-input { background: #f4f4f8; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .deepseek-input::placeholder { color: #9ca3af; }
[data-theme="light"] .deepseek-input:focus { border-color: rgba(124,58,237,0.5); }

/* 日间模式 - Prompt Modal */
[data-theme="light"] .prompt-modal-content { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .prompt-modal-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .prompt-modal-header h4 { color: #18181b; }
[data-theme="light"] .prompt-modal-header .close-btn { color: #9ca3af; }
[data-theme="light"] .prompt-modal-header .close-btn:hover { color: #18181b; }
[data-theme="light"] .prompt-modal-tip { background: rgba(124,58,237,0.06); border-color: rgba(124,58,237,0.12); color: #6b7280; }
[data-theme="light"] .prompt-modal-textarea { background: #f4f4f8; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .prompt-modal-textarea::placeholder { color: #9ca3af; }
[data-theme="light"] .prompt-modal-textarea:focus { border-color: rgba(124,58,237,0.4); }
[data-theme="light"] .prompt-modal-count { color: #9ca3af; }
[data-theme="light"] .prompt-modal-footer { border-top-color: #e8e8f0; }
[data-theme="light"] .prompt-modal-footer .btn-cancel { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .prompt-modal-footer .btn-cancel:hover { background: #e8e8f0; color: #18181b; }

/* 日间模式 - Asset Modal */
[data-theme="light"] .asset-modal-content { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .asset-modal-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .asset-modal-header h4 { color: #18181b; }
[data-theme="light"] .asset-modal-header .close-btn { color: #9ca3af; }
[data-theme="light"] .asset-sidebar { border-right-color: #e8e8f0; }
[data-theme="light"] .asset-sidebar-title { color: #9ca3af; }
[data-theme="light"] .asset-folder-item { color: #6b7280; }
[data-theme="light"] .asset-folder-item:hover { background: #f4f4f8; color: #18181b; }
[data-theme="light"] .asset-folder-item.active { background: #ede9fe; color: var(--primary-color); }
[data-theme="light"] .asset-folder-item .count { color: #9ca3af; }
[data-theme="light"] .asset-sidebar-footer { border-top-color: #e8e8f0; }
[data-theme="light"] .asset-content-header { border-bottom-color: #e8e8f0; }
[data-theme="light"] .asset-tab { color: #9ca3af; }
[data-theme="light"] .asset-tab.active { color: var(--primary-color); }
[data-theme="light"] .asset-refresh-btn { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .asset-grid-item { background: #f4f4f8; }
[data-theme="light"] .asset-grid-item:hover { border-color: #d4d4d8; }
[data-theme="light"] .asset-empty { color: #9ca3af; }
[data-theme="light"] .asset-modal-footer { border-top-color: #e8e8f0; }
[data-theme="light"] .asset-modal-footer .btn-cancel { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }

/* 日间模式 - Home Page */
[data-theme="light"] .home-main { background: #f4f4f8; }
[data-theme="light"] .feature-card { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .feature-card:hover { border-color: var(--primary-color); box-shadow: 0 4px 20px rgba(124, 58, 237, 0.1); }
[data-theme="light"] .feature-card h3 { color: #18181b; }
[data-theme="light"] .feature-card p { color: #6b7280; }
[data-theme="light"] .feature-card .bg-icon { color: #18181b; opacity: 0.03; }
[data-theme="light"] .fc-1, [data-theme="light"] .fc-2 { background: #fff; }
[data-theme="light"] .gallery-header h2 { color: #18181b; }
[data-theme="light"] .gallery-header .more { color: #6b7280; }
[data-theme="light"] .gallery-search input { background: #fff; border-color: #e8e8f0; color: #18181b; }
[data-theme="light"] .gallery-search input::placeholder { color: #9ca3af; }
[data-theme="light"] .gallery-search i { color: #9ca3af; }
[data-theme="light"] .gallery-tags { border-bottom-color: #e8e8f0; }
[data-theme="light"] .gallery-tag { color: #6b7280; background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .gallery-tag.active { color: #fff; border-color: transparent; }
[data-theme="light"] .gallery-tag:hover { color: #374151; border-color: var(--primary-color); }
[data-theme="light"] .gallery-item { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .gallery-item:hover { border-color: #d4d4d8; }
[data-theme="light"] .gallery-item .title { color: #374151; }

/* 日间模式 - Home Modal */
[data-theme="light"] .modal-content { background: #fff; border-color: #e8e8f0; }
[data-theme="light"] .modal-close { color: #9ca3af; }
[data-theme="light"] .modal-close:hover { color: #18181b; }
[data-theme="light"] .modal-left { background: #f4f4f8; border-right-color: #e8e8f0; }
[data-theme="light"] .modal-right { background: #fff; }
[data-theme="light"] .modal-header h2 { color: #18181b; }
[data-theme="light"] .modal-tag { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.15); }
[data-theme="light"] .info-label { color: #6b7280; }
[data-theme="light"] .blur-box { background: #f4f4f8; border-color: #e8e8f0; }
[data-theme="light"] .blur-text { color: #9ca3af; }
[data-theme="light"] .blur-overlay { background: rgba(244,244,248,0.3); }
[data-theme="light"] .prompt-text { color: #374151 !important; }
[data-theme="light"] .ref-img { border-color: #e8e8f0; }
[data-theme="light"] .bottom-tags .b-tag { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .bottom-tags .b-tag:hover { color: #18181b; border-color: #d4d4d8; }

/* 日间模式 - Style Grid (Design Page) */
[data-theme="light"] .style-item { background: #f4f4f8; border-color: #e8e8f0; color: #6b7280; }
[data-theme="light"] .style-item:hover { border-color: rgba(124,58,237,0.4); background: rgba(124,58,237,0.05); }
[data-theme="light"] .style-item.active { background: #ede9fe; border-color: var(--primary-color); color: var(--primary-color); }
[data-theme="light"] .style-item .name { color: #18181b; }
[data-theme="light"] .style-item.active .name { color: var(--primary-color); }

/* 日间模式 - Balance Text */
[data-theme="light"] #balanceText { color: var(--warning-color); }

/* 日间模式 - Scrollbar */
[data-theme="light"] ::-webkit-scrollbar-thumb { background: #d4d4d8; }
[data-theme="light"] ::-webkit-scrollbar-track { background: #f4f4f8; }

/* 日间模式 - 原生 input / select / textarea 全局修复 */
[data-theme="light"] input:not([type="range"]):not([type="checkbox"]):not([type="radio"]),
[data-theme="light"] select,
[data-theme="light"] textarea {
    background: #ffffff !important;
    color: #18181b !important;
    border-color: #d4d4d8 !important;
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder {
    color: #9ca3af !important;
}
[data-theme="light"] input:focus,
[data-theme="light"] select:focus,
[data-theme="light"] textarea:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.12) !important;
    outline: none !important;
}
[data-theme="light"] input:disabled,
[data-theme="light"] select:disabled,
[data-theme="light"] textarea:disabled {
    background: #f4f4f8 !important;
    color: #9ca3af !important;
}
/* select option 在白色模式下 */
[data-theme="light"] select option {
    background: #ffffff;
    color: #18181b;
}

/* 日间模式 - points-log-filter select */
[data-theme="light"] .points-log-filter {
    background: #ffffff !important;
    border-color: #d4d4d8 !important;
    color: #18181b !important;
}

/* 日间模式 - layui input 修复 */
[data-theme="light"] .layui-input,
[data-theme="light"] .layui-select,
[data-theme="light"] .layui-textarea {
    background: #ffffff !important;
    color: #18181b !important;
    border-color: #d4d4d8 !important;
}

/* 日间模式 - 表格 */
[data-theme="light"] table th {
    background: #f9f9fb !important;
    color: #374151 !important;
    border-bottom-color: #e8e8f0 !important;
}
[data-theme="light"] table td {
    color: #18181b !important;
    border-bottom-color: #f4f4f8 !important;
}
[data-theme="light"] table tr:hover td {
    background: #f9f9fb !important;
}

/* 日间模式 - 状态标签 */
[data-theme="light"] .status.active { background: #ecfdf5; color: #059669; }
[data-theme="light"] .status.inactive { background: #f4f4f8; color: #6b7280; }

/* 日间模式 - 按钮 */
[data-theme="light"] .btn-link { color: var(--primary-color) !important; }
[data-theme="light"] .btn-link:hover { background: rgba(124,58,237,0.08) !important; }
[data-theme="light"] .btn-danger { color: #ef4444 !important; }
[data-theme="light"] .btn-danger:hover { background: #fef2f2 !important; }

/* 日间模式 - tab-item */
[data-theme="light"] .tab-item { color: #6b7280; border-bottom-color: transparent; }
[data-theme="light"] .tab-item:hover { color: var(--primary-color); }
[data-theme="light"] .tab-item.active { color: var(--primary-color); border-bottom-color: var(--primary-color); }
[data-theme="light"] .tabs { border-bottom-color: #e8e8f0; }

/* 日间模式 - info-item */
[data-theme="light"] .info-item { border-bottom-color: #f4f4f8; }
[data-theme="light"] .info-item label { color: #9ca3af; }
[data-theme="light"] .info-item span { color: #18181b; }

/* 日间模式 - card */
[data-theme="light"] .card { background: #ffffff; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] .card-title { color: #18181b; }

/* 日间模式 - stat-card */
[data-theme="light"] .stat-card { background: #ffffff; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] .stat-card .value { color: #18181b; }
[data-theme="light"] .stat-card .label { color: #6b7280; }

/* 日间模式 - dropdown */
[data-theme="light"] .dropdown-menu { background: #ffffff; border-color: #e8e8f0; box-shadow: 0 4px 16px rgba(0,0,0,0.1); }
[data-theme="light"] .dropdown-item { color: #18181b; }
[data-theme="light"] .dropdown-item:hover { background: #f4f4f8; }
[data-theme="light"] .divider { border-color: #e8e8f0; }

/* 日间模式 - sidebar (index.html 租户后台) */
[data-theme="light"] .sidebar { background: #ffffff; border-right-color: #e8e8f0; }
[data-theme="light"] .menu-group-title { color: #6b7280; }
[data-theme="light"] .menu-group-title:hover { background: #f4f4f8; color: #18181b; }
[data-theme="light"] .menu-item.sub { color: #374151; }
[data-theme="light"] .menu-item.sub:hover { background: #f4f4f8; color: #18181b; }
[data-theme="light"] .menu-item.sub.active { background: #ede9fe; color: var(--primary-color); }

/* 日间模式 - header (index.html 租户后台) */
[data-theme="light"] .header { background: rgba(255,255,255,0.97) !important; border-bottom-color: #e8e8f0; }
[data-theme="light"] .header-logo span { color: #18181b; }
[data-theme="light"] .toggle-btn { color: #6b7280; }
[data-theme="light"] .toggle-btn:hover { color: #18181b; background: #f4f4f8; }
[data-theme="light"] .user-dropdown .name { color: #18181b; }
[data-theme="light"] .user-dropdown .arrow { color: #9ca3af; }
[data-theme="light"] .avatar { background: #ede9fe; color: var(--primary-color); }

/* 日间模式 - main 背景 */
[data-theme="light"] .main { background: #f4f4f8; }

/* 日间模式 - alert */
[data-theme="light"] .alert-warning { background: #fffbeb; border-color: #fde68a; color: #b45309; }
[data-theme="light"] .alert-success { background: #f0fdf4; border-color: #bbf7d0; color: #15803d; }


/* ========== 响应式自适应 ========== */

/* 平板设备 (768px - 1024px) */
@media (max-width: 1024px) {
    .sidebar { width: 200px; }
    .main { margin-left: 200px; }
    .panel-left { width: 340px; }
    .header { padding: 0 16px; }
    .header-points { padding: 6px 12px; font-size: 12px; }
}

/* 移动端设备 (小于768px) */
@media (max-width: 768px) {
    /* 隐藏侧边栏 */
    .sidebar { 
        position: fixed;
        left: -260px;
        width: 260px;
        top: 60px;
        bottom: 0;
        z-index: 200;
        transition: left 0.3s ease;
        box-shadow: none;
    }
    .sidebar.open { 
        left: 0; 
        box-shadow: 4px 0 20px rgba(0,0,0,0.3);
    }
    
    /* 侧边栏遮罩 */
    .sidebar-overlay {
        display: none;
        position: fixed;
        top: 60px;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0,0,0,0.5);
        z-index: 199;
    }
    .sidebar-overlay.active { display: block; }
    
    /* 主内容区全宽 */
    .main { margin-left: 0; }
    
    /* Header 调整 */
    .header { padding: 0 12px; }
    .logo { font-size: 16px; }
    .logo-icon { width: 28px; height: 28px; margin-right: 8px; }
    .logo-icon i { font-size: 16px; }
    .header-right { gap: 8px; }
    .header-btn { width: 32px; height: 32px; }
    .header-btn i { font-size: 16px; }
    .header-points { padding: 6px 10px; font-size: 12px; gap: 4px; }
    .header-points i { font-size: 14px; }
    .user-btn { padding: 4px 8px 4px 4px; font-size: 12px; max-width: 120px; }
    .user-btn .avatar { width: 24px; height: 24px; flex-shrink: 0; }
    .user-btn .avatar i { font-size: 12px; }
    .user-btn .user-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 60px; display: inline-block; vertical-align: middle; }
    
    /* 菜单按钮 */
    .menu-toggle { 
        display: flex !important;
        width: 36px;
        height: 36px;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        margin-right: 10px;
        border-radius: 8px;
        transition: background 0.2s;
        background: var(--hover-bg);
        border: 1px solid var(--border-color);
    }
    .menu-toggle:hover { background: var(--border-color); }
    .menu-toggle i { font-size: 20px; color: var(--text-color); }
    
    /* 双栏布局改为单栏 */
    .main-flex { flex-direction: column; height: auto; overflow-y: auto; }
    .panel-left { 
        width: 100%; 
        border-right: none; 
        border-bottom: 1px solid var(--border-color);
        max-height: none;
        height: auto;
        flex-shrink: 0;
    }
    .panel-right { 
        width: 100%; 
        min-height: 50vh;
        flex: 1;
    }
    .panel-header { padding: 16px; }
    .panel-header h2 { font-size: 18px; }
    .panel-body { padding: 16px; }
    .panel-footer { padding: 16px; }
    
    /* VEO/Banana/Design 页面 */
    .veo-left, .panel-left { 
        width: 100% !important; 
        max-height: none !important;
        height: auto !important;
    }
    .veo-right, .panel-right { 
        width: 100% !important;
        min-height: 400px;
    }
    .veo-header, .panel-header { padding: 16px; }
    .veo-header h2 { font-size: 18px; }
    .veo-body { padding: 16px; }
    .veo-footer { padding: 16px; }
    
    /* Tab 按钮 */
    .tab-btns { flex-wrap: wrap; gap: 8px; }
    .tab-btn { padding: 8px 12px; font-size: 12px; flex: 1; min-width: calc(50% - 4px); text-align: center; }
    
    /* Ratio Grid */
    .ratio-grid { gap: 8px; }
    .ratio-item { padding: 8px 10px; font-size: 11px; }
    
    /* Upload Box */
    .upload-box { padding: 24px 16px; }
    .upload-box .t1 { font-size: 13px; }
    .upload-box .t2 { font-size: 11px; }
    
    /* Prompt Section */
    .prompt-wrapper { }
    .prompt-textarea { min-height: 100px; font-size: 14px; }
    
    /* Template Grid */
    .template-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .template-item { height: 70px; }
    
    /* History Grid */
    .history-grid { 
        grid-template-columns: repeat(2, 1fr) !important; 
        gap: 10px !important;
    }
    .history-grid.grid-4 { grid-template-columns: repeat(2, 1fr) !important; }
    .history-grid.grid-2 { grid-template-columns: repeat(2, 1fr) !important; }
    .history-card-img { aspect-ratio: 16/10 !important; }
    .history-card-info { padding: 8px 10px; }
    .history-prompt { font-size: 11px; -webkit-line-clamp: 2; }
    .history-meta { font-size: 10px; }
    
    /* Empty State */
    .empty-state { padding: 30px 20px; }
    .empty-icon { width: 60px; height: 60px; }
    .empty-icon i { font-size: 24px; }
    
    /* 积分弹窗 */
    .points-modal { width: 95vw; max-height: 80vh; }
    .points-modal-header { padding: 16px; }
    .points-modal-header h3 { font-size: 16px; }
    .points-stats { padding: 16px; gap: 16px; flex-wrap: wrap; }
    .points-stat-item .value { font-size: 16px; }
    .points-tabs { padding: 12px 16px 0; gap: 6px; }
    .points-tab { padding: 8px 14px; font-size: 12px; }
    .points-log-header { padding: 12px 16px; }
    .points-log-list { padding: 0 16px 12px; }
    .points-redeem { padding: 16px; }
    .points-redeem-input { flex-direction: column; }
    .points-redeem-input button { width: 100%; }
    
    /* 按钮 */
    .btn-primary { padding: 12px; font-size: 14px; }
    
    /* 生成按钮 */
    .generate-btn { padding: 12px !important; font-size: 14px !important; }
}

/* 小屏手机 (小于480px) */
@media (max-width: 480px) {
    .header { height: 54px; }
    .main { margin-top: 54px; height: calc(100vh - 54px); }
    .sidebar { top: 54px; }
    
    .logo { font-size: 14px; }
    .logo-icon { width: 26px; height: 26px; }
    
    .header-points { padding: 4px 8px; font-size: 11px; }
    .header-points i { font-size: 12px; }
    .user-btn .user-name { display: none; }
    .user-btn .arrow { display: none; }
    .user-btn { padding: 4px; border-radius: 50%; }
    
    .panel-header h2 { font-size: 16px; }
    .panel-header p { font-size: 12px; }
    
    .tab-btn { min-width: 0 !important; flex: 1 !important; }
    
    .template-grid { grid-template-columns: repeat(2, 1fr); }
    
    .history-grid { 
        grid-template-columns: 1fr !important;
    }
    .history-card-img { aspect-ratio: 16/9 !important; }
    
    .points-modal { width: 100vw; max-width: 100vw; border-radius: 16px 16px 0 0; max-height: 85vh; }
    
    /* 小屏幕生成页面适配 */
    .veo-header h2 { font-size: 15px !important; }
    .veo-body, .page-body { padding: 12px 14px 110px !important; }
    .veo-footer, .page-footer { padding: 10px 14px !important; }
    
    /* 比例选择 - 小屏保持5列但更紧凑 */
    .ratio-grid { gap: 4px !important; }
    .ratio-item { 
        padding: 4px 2px !important; 
        height: 48px !important;
    }
    .ratio-item .icon { 
        width: 14px !important; 
        height: 14px !important; 
    }
    .ratio-item .t { font-size: 8px !important; }
    
    /* Tab 按钮小屏 */
    .tab-btn {
        padding: 8px 6px !important;
    }
    .tab-btn .t { font-size: 12px !important; }
    .tab-btn .s { font-size: 8px !important; }
    
    /* 模板卡片小屏 */
    .template-item { 
        min-width: 140px !important; 
        max-width: 140px !important;
    }
    .template-img-wrap { height: 100px !important; }
    .template-item .use-btn {
        padding: 8px 6px !important;
        font-size: 11px !important;
    }
    
    /* 右侧面板小屏 */
    .panel-right, .veo-right, .page-right {
        top: 54px !important;
        height: calc(100vh - 54px) !important;
    }
    .history-toggle-btn {
        top: 64px !important;
        right: 10px !important;
        width: 40px !important;
        height: 40px !important;
    }
    .history-toggle-btn i { font-size: 18px !important; }
}

/* 横屏模式优化 */
@media (max-width: 768px) and (orientation: landscape) {
    .main-flex { flex-direction: row; }
    .panel-left { width: 45%; max-width: 320px; border-right: 1px solid var(--border-color); border-bottom: none; }
    .panel-right { width: 55%; flex: 1; }
    .veo-left, .page-left { width: 45% !important; max-width: 320px !important; }
    .veo-right, .page-right { width: 55% !important; }
}

/* 资产管理页面响应式 */
@media (max-width: 768px) {
    .assets-container { flex-direction: column; }
    .assets-sidebar { 
        width: 100% !important; 
        border-right: none !important; 
        border-bottom: 1px solid var(--border-color);
        max-height: 200px;
        overflow-y: auto;
    }
    .assets-main { width: 100% !important; }
    .assets-grid { 
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
    }
    .asset-item { }
    .asset-item-img { height: 80px; }
    .asset-item-info { padding: 6px; }
    .asset-item-name { font-size: 11px; }
    .asset-item-size { font-size: 10px; }
    
    /* 资产弹窗 */
    .asset-modal-content { width: 95vw !important; max-width: 95vw !important; height: 80vh !important; }
    .asset-modal-body, .asset-modal-main { flex-direction: column !important; }
    .asset-sidebar { 
        width: 100% !important; 
        border-right: none !important;
        border-bottom: 1px solid var(--border-color);
        max-height: 120px !important;
        overflow-y: auto !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
    }
    .asset-sidebar .asset-sidebar-title { display: none; }
    .asset-sidebar .asset-folder-list,
    .asset-sidebar .asset-sidebar-folders {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
        padding: 8px !important;
    }
    .asset-sidebar .folder-item,
    .asset-sidebar .asset-folder-item {
        padding: 6px 12px !important;
        font-size: 12px !important;
    }
    .asset-content { width: 100% !important; }
    .asset-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 8px !important; }
    .asset-grid-item { min-height: 80px; }
    .asset-content-body { overflow-y: auto !important; }
    .asset-modal-footer { padding: 12px 16px !important; }
    .asset-modal-footer .btn { padding: 10px 20px !important; font-size: 13px !important; }
}

/* Home 页面响应式 */
@media (max-width: 768px) {
    .home-main { padding: 16px !important; }
    
    /* 功能卡片横向滚动 */
    .feature-cards {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        gap: 10px !important;
        padding-bottom: 8px !important;
        margin-bottom: 24px !important;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    .feature-cards::-webkit-scrollbar { display: none; }
    .feature-cards { scrollbar-width: none; -ms-overflow-style: none; }
    .feature-card { 
        min-width: 180px !important;
        flex: 0 0 auto !important;
        height: auto !important;
        scroll-snap-align: start;
    }
    .feature-card img {
        width: 100% !important;
        height: auto !important;
    }
    
    /* Banner 调整 - 移动端轮播图（参考样式：宽屏横幅） */
    .banner-swiper {
        height: 120px !important;
        margin-bottom: 12px !important;
        border-radius: 10px !important;
    }
    .banner-swiper .swiper-wrapper {
        height: 100% !important;
    }
    .banner-swiper .swiper-slide {
        height: 100% !important;
    }
    .banner-swiper .swiper-slide img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
    }
    
    /* 画廊标题区 */
    .gallery-header { 
        flex-direction: column !important; 
        align-items: flex-start !important; 
        gap: 12px !important;
        margin-bottom: 16px !important;
    }
    .gallery-header h2 { font-size: 16px; }
    .gallery-search { width: 100%; margin-left: 0 !important; }
    .gallery-search input { width: 100%; font-size: 14px; padding: 10px 40px 10px 14px; }
    
    /* 标签换行显示 */
    .gallery-tags { 
        flex-wrap: wrap !important;
        gap: 8px !important;
        padding-bottom: 12px !important;
        margin-bottom: 16px !important;
    }
    .gallery-tag { 
        font-size: 12px !important;
        padding: 6px 12px !important;
        white-space: nowrap;
    }
    
    /* 画廊2列瀑布流 */
    .gallery-grid { 
        column-count: 2 !important;
        column-gap: 12px !important;
    }
    .gallery-item { 
        margin-bottom: 12px !important;
        border-radius: 10px !important;
    }
    .gallery-item .tag { 
        font-size: 9px !important;
        padding: 3px 6px !important;
        top: 8px !important;
        left: 8px !important;
    }
    .gallery-item .info { padding: 10px 12px !important; }
    .gallery-item .title { font-size: 12px !important; }
}

/* 模板详情弹窗响应式 */
@media (max-width: 768px) {
    .preview-modal-content, .tpl-detail-modal { 
        width: 100% !important; 
        max-width: 100% !important;
        height: 100% !important;
        flex-direction: column !important;
        overflow-y: auto !important;
        border-radius: 0 !important;
    }
    .preview-left, .tpl-detail-left { 
        width: 100% !important; 
        height: auto !important;
        min-height: 180px !important;
        max-height: 45vh !important;
        flex-shrink: 0;
        padding: 12px !important;
    }
    .preview-left video, .preview-left .preview-video {
        width: 100% !important;
        max-height: 40vh !important;
        object-fit: contain !important;
        border-radius: 8px !important;
    }
    .preview-left img, .tpl-detail-left img {
        max-width: 100% !important;
        max-height: 40vh !important;
        object-fit: contain !important;
    }
    .preview-left .preview-image {
        width: 100% !important;
        max-height: 40vh !important;
        object-fit: contain !important;
    }
    .preview-right, .tpl-detail-right { 
        width: 100% !important;
        flex: 1;
        overflow-y: auto;
        padding: 14px 16px !important;
        border-left: none !important;
        border-top: 1px solid var(--border-color) !important;
    }
    .preview-header { 
        padding: 10px 0 !important;
        flex-wrap: wrap;
        gap: 8px;
    }
    .preview-actions {
        gap: 6px !important;
    }
    .preview-action-btn {
        width: 32px !important;
        height: 32px !important;
    }
    .preview-body { padding: 0 !important; }
    .preview-footer { padding: 10px 0 !important; }
    .preview-desc {
        font-size: 12px !important;
        max-height: 60px !important;
        overflow-y: auto !important;
    }
    .preview-info-row {
        padding: 8px 0 !important;
        font-size: 12px !important;
    }
    .preview-ref-img {
        max-width: 80px !important;
        max-height: 80px !important;
    }
    .preview-create-btn {
        width: 100% !important;
        padding: 10px !important;
        font-size: 13px !important;
    }
    
    /* 模板详情弹窗内容 */
    .tpl-detail-title { font-size: 16px !important; margin-bottom: 14px !important; }
    .tpl-detail-section { overflow: visible !important; }
    .tpl-detail-prompt { max-height: 120px !important; font-size: 12px !important; }
    .tpl-detail-tags { gap: 6px !important; margin-top: 12px !important; }
    .tpl-detail-tag { padding: 3px 10px !important; font-size: 10px !important; }
    .tpl-detail-use-btn { margin-top: 14px !important; padding: 12px !important; font-size: 13px !important; }
    .tpl-blur-box { max-height: 100px !important; }
    
    .modal-content {
        flex-direction: column !important;
        max-height: 85vh;
        overflow-y: auto !important;
    }
    .modal-left {
        width: 100% !important;
        height: 200px !important;
        min-height: 200px !important;
        flex-shrink: 0;
        padding: 16px !important;
    }
    .modal-left img {
        max-height: 100% !important;
    }
    .modal-right {
        width: 100% !important;
        flex: 1;
        overflow-y: auto;
        padding: 16px !important;
    }
}

/* DeepSeek 弹窗响应式 */
@media (max-width: 768px) {
    .deepseek-modal-content {
        width: 95vw !important;
        max-width: 95vw !important;
        height: 80vh !important;
        max-height: 80vh !important;
    }
    .deepseek-header { padding: 12px 16px; }
    .deepseek-body { padding: 12px 16px; }
    .deepseek-footer { padding: 12px 16px; }
    .deepseek-quick-btns { flex-wrap: wrap; }
    .deepseek-quick-btn { font-size: 11px; padding: 6px 10px; }
}

/* 提示词弹窗响应式 */
@media (max-width: 768px) {
    .prompt-modal-content {
        width: 95vw !important;
        max-width: 95vw !important;
    }
    .prompt-modal-header { padding: 12px 16px; }
    .prompt-modal-body { padding: 16px; }
    .prompt-modal-footer { padding: 12px 16px; }
}

/* 租户后台响应式 */
@media (max-width: 768px) {
    .admin-sidebar {
        position: fixed;
        left: -260px;
        width: 260px;
        transition: left 0.3s ease;
        z-index: 200;
    }
    .admin-sidebar.open { left: 0; }
    .admin-main { margin-left: 0 !important; }
    .admin-header { padding: 0 12px; }
    
    .stats-grid { 
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    .stat-card { padding: 16px !important; }
    .stat-card .value { font-size: 20px !important; }
    
    .card { padding: 16px !important; }
    .card-title { font-size: 14px !important; }
    
    table { font-size: 12px; }
    th, td { padding: 10px 8px; }
    
    .form-row input, .form-row select, .form-row textarea {
        font-size: 14px;
    }
}

/* 触摸设备优化 */
@media (hover: none) and (pointer: coarse) {
    .menu-item { padding: 14px; }
    .tab-btn { padding: 12px 16px; }
    .ratio-item { padding: 10px 12px; }
    .btn-primary { padding: 14px; }
    .header-btn { width: 40px; height: 40px; }
}

/* 打印样式 */
@media print {
    .sidebar, .header, .panel-footer, .veo-footer { display: none !important; }
    .main { margin: 0 !important; }
    .panel-left { width: 100% !important; }
}


/* ========== 移动端右侧面板折叠 ========== */
@media (max-width: 768px) {
    /* 右侧面板默认隐藏 */
    .panel-right, .veo-right, .page-right {
        position: fixed;
        top: 60px;
        right: -100%;
        width: 100% !important;
        height: calc(100vh - 60px) !important;
        z-index: 150;
        transition: right 0.3s ease;
        background: var(--bg-color);
    }
    .panel-right.open, .veo-right.open, .page-right.open {
        right: 0;
    }
    
    /* 左侧面板 - flex列布局，footer固定在底部 */
    .panel-left, .veo-left, .page-left {
        width: 100% !important;
        height: calc(100vh - 60px) !important;
        max-height: none !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
    }
    
    /* 主布局 */
    .main-flex, .veo-main, .page-main {
        flex-direction: column;
        height: calc(100vh - 60px);
        overflow: hidden;
    }
    
    /* 左侧面板内部布局 */
    .veo-header {
        padding: 14px 16px !important;
        flex-shrink: 0;
    }
    .veo-header h2 {
        font-size: 16px !important;
    }
    .veo-header p {
        font-size: 11px !important;
    }
    .veo-body {
        padding: 14px 16px 16px !important;
        flex: 1 !important;
        overflow-y: auto !important;
        min-height: 0 !important;
    }
    .page-body {
        padding: 14px 16px 16px !important;
        flex: 1 !important;
        overflow-y: auto !important;
        min-height: 0 !important;
    }
    .veo-footer, .page-footer {
        position: relative !important;
        flex-shrink: 0 !important;
        padding: 12px 16px !important;
        padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
        background: var(--sidebar-bg) !important;
        border-top: 1px solid var(--border-color) !important;
        z-index: 100 !important;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.3) !important;
    }
    
    /* 页面头部移动端适配 */
    .page-header {
        padding: 14px 16px 10px !important;
        flex-shrink: 0;
    }
    .page-header h2 {
        font-size: 16px !important;
    }
    
    /* 模板横向滚动 */
    .template-section {
        margin-bottom: 16px !important;
        overflow: visible !important;
    }
    .template-grid {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        gap: 12px !important;
        padding-bottom: 10px !important;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    .template-grid::-webkit-scrollbar { height: 3px; }
    .template-grid::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }
    .template-item {
        min-width: 150px !important;
        max-width: 150px !important;
        flex-shrink: 0 !important;
        scroll-snap-align: start;
        border-radius: 10px !important;
        overflow: visible !important;
        display: flex !important;
        flex-direction: column !important;
    }
    .template-img-wrap {
        height: 110px !important;
        flex-shrink: 0 !important;
        overflow: hidden !important;
        border-radius: 10px 10px 0 0 !important;
    }
    .template-item .use-btn {
        padding: 10px 8px !important;
        font-size: 12px !important;
        flex-shrink: 0 !important;
        border-radius: 0 0 10px 10px !important;
    }
    
    /* 比例选择网格 - 5列 */
    .ratio-grid {
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 6px !important;
    }
    .ratio-item {
        padding: 6px 2px !important;
        height: 52px !important;
    }
    .ratio-item .icon {
        width: 16px !important;
        height: 16px !important;
        margin-bottom: 2px !important;
    }
    .ratio-item .t {
        font-size: 9px !important;
    }
    .ratio-item .s {
        font-size: 8px !important;
    }
    
    /* Tab 按钮 - 不换行 */
    .tabs, .tabs-flex, .tab-btns {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 8px !important;
    }
    .tab-btn {
        flex: 1 !important;
        min-width: 0 !important;
        padding: 10px 6px !important;
    }
    .tab-btn .t {
        font-size: 12px !important;
    }
    .tab-btn .s {
        font-size: 9px !important;
    }
    
    /* Section 间距 */
    .section {
        margin-bottom: 14px !important;
    }
    .section-label {
        font-size: 11px !important;
        margin-bottom: 8px !important;
    }
    
    /* 上传区域 */
    .upload-box {
        padding: 20px 14px !important;
    }
    .upload-box .t1 {
        font-size: 12px !important;
    }
    .upload-box .t2 {
        font-size: 10px !important;
    }
    .upload-box .select-btn {
        font-size: 11px !important;
        padding: 8px 16px !important;
        position: relative;
        z-index: 2;
        min-height: 36px;
    }
    
    /* 提示词区域 */
    .prompt-textarea {
        height: 80px !important;
        font-size: 13px !important;
    }
    .prompt-header .label {
        font-size: 11px !important;
    }
    .prompt-header .action-link {
        font-size: 10px !important;
        padding: 4px 8px !important;
    }
    
    /* 生成按钮 */
    .gen-btn {
        padding: 14px !important;
        font-size: 14px !important;
        border-radius: 24px !important;
    }
    
    /* 展开按钮 */
    .history-toggle-btn {
        display: flex !important;
        position: fixed;
        top: 70px;
        right: 12px;
        width: 44px;
        height: 44px;
        background: var(--primary-gradient);
        border-radius: 50%;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        z-index: 140;
        box-shadow: 0 4px 15px rgba(139, 92, 246, 0.4);
        transition: all 0.2s;
    }
    .history-toggle-btn:hover {
        transform: scale(1.05);
    }
    .history-toggle-btn i {
        font-size: 20px;
        color: #fff;
    }
    .history-toggle-btn .badge {
        position: absolute;
        top: -4px;
        right: -4px;
        min-width: 18px;
        height: 18px;
        background: #ef4444;
        border-radius: 9px;
        font-size: 10px;
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 4px;
    }
    
    /* 关闭按钮 */
    .panel-close-btn {
        display: flex !important;
        position: absolute;
        top: 16px;
        right: 16px;
        width: 36px;
        height: 36px;
        background: var(--hover-bg);
        border-radius: 50%;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        z-index: 10;
        border: 1px solid var(--border-color);
    }
    .panel-close-btn:hover {
        background: var(--border-color);
    }
    .panel-close-btn i {
        font-size: 18px;
        color: var(--text-muted);
    }
    
    /* 遮罩层 */
    .panel-overlay {
        display: none;
        position: fixed;
        top: 60px;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0,0,0,0.5);
        z-index: 145;
    }
    .panel-overlay.active {
        display: block;
    }
    
    /* 右侧面板内部 */
    .veo-right-header, .page-right-header {
        padding: 14px 16px !important;
        padding-right: 60px !important;
    }
    .veo-right-body, .page-right-body {
        padding: 12px !important;
    }
    
    /* 历史记录网格 - 2列 */
    .history-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    .history-card-img {
        aspect-ratio: 16/10 !important;
    }
    .history-card-info {
        padding: 8px !important;
    }
    .history-prompt {
        font-size: 10px !important;
        height: 24px !important;
    }
    .history-meta {
        font-size: 9px !important;
    }
    
    /* Layui弹窗移动端全屏适配 */
    .layui-layer {
        border-radius: 0 !important;
    }
    .layui-layer-content {
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
    }
}

/* 桌面端隐藏这些按钮 */
@media (min-width: 769px) {
    .history-toggle-btn { display: none !important; }
    .panel-close-btn { display: none !important; }
    .panel-overlay { display: none !important; }
    .menu-toggle { display: none !important; }
}

/* 日间模式适配 */
[data-theme="light"] .history-toggle-btn {
    box-shadow: 0 4px 15px rgba(124, 58, 237, 0.3);
}
[data-theme="light"] .panel-close-btn {
    background: #f4f4f8;
    border-color: #e8e8f0;
}
[data-theme="light"] .panel-close-btn:hover {
    background: #e8e8f0;
}
[data-theme="light"] .panel-close-btn i {
    color: #6b7280;
}
[data-theme="light"] .menu-toggle {
    background: #f4f4f8;
    border-color: #e8e8f0;
}
[data-theme="light"] .menu-toggle:hover {
    background: #e8e8f0;
}
[data-theme="light"] .menu-toggle i {
    color: #18181b;
}

/* ========== 全局滚动条美化 ========== */

/* 暗色主题（默认） */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(113, 113, 122, 0.4) transparent;
}

*::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

*::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 3px;
}

*::-webkit-scrollbar-thumb {
    background: rgba(113, 113, 122, 0.35);
    border-radius: 3px;
    transition: background 0.2s;
}

*::-webkit-scrollbar-thumb:hover {
    background: rgba(139, 92, 246, 0.6);
}

*::-webkit-scrollbar-corner {
    background: transparent;
}

/* 日间模式滚动条 */
[data-theme="light"] * {
    scrollbar-color: rgba(161, 161, 170, 0.4) transparent;
}

[data-theme="light"] *::-webkit-scrollbar-track {
    background: transparent;
}

[data-theme="light"] *::-webkit-scrollbar-thumb {
    background: rgba(161, 161, 170, 0.4);
}

[data-theme="light"] *::-webkit-scrollbar-thumb:hover {
    background: rgba(124, 58, 237, 0.5);
}

/* 通用分页组件 */
.pager{display:flex;align-items:center;justify-content:center;gap:4px;padding:10px 0;flex-shrink:0}
.pager-btn{min-width:28px;height:28px;padding:0 6px;border:1px solid #333;border-radius:6px;background:transparent;color:#888;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.pager-btn:hover{border-color:#a855f7;color:#a855f7}
.pager-btn.active{background:#a855f7;border-color:#a855f7;color:#fff}
.pager-btn.disabled{opacity:.3;cursor:not-allowed;pointer-events:none}
.pager-info{font-size:10px;color:#666;margin:0 4px}
[data-theme="light"] .pager-btn{border-color:#d4d4d8;color:#71717a}
[data-theme="light"] .pager-btn:hover{border-color:#7c3aed;color:#7c3aed}
[data-theme="light"] .pager-btn.active{background:#7c3aed;border-color:#7c3aed;color:#fff}
[data-theme="light"] .pager-info{color:#a1a1aa}

/* 历史记录网格 - 整洁Grid布局 */
.history-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.history-grid .history-card{position:relative;border-radius:10px;overflow:hidden;background:#1a1a1a;transition:all .25s ease}
.history-grid .history-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.history-card-img{position:relative;background:#0a0a0a;overflow:hidden;aspect-ratio:16/10}
.history-card-img img,.history-card-img video{width:100%;height:100%;object-fit:cover;display:block}
.history-card-img.history-loading,.history-card-img.history-failed{display:flex;align-items:center;justify-content:center}
.history-card-img.history-loading i{font-size:22px;color:#a855f7;animation:spin 1s linear infinite}
.history-card-img.history-failed i{font-size:22px;color:#ef4444}
.history-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;background:rgba(139,92,246,.85);border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:all .2s}
.history-play-btn:hover{background:rgba(139,92,246,1);transform:translate(-50%,-50%) scale(1.1)}
.history-play-btn i{color:#fff;font-size:14px;margin-left:2px}
.history-status{position:absolute;top:8px;left:8px;display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:10px;color:#fff;font-weight:500;backdrop-filter:blur(4px)}
.history-status i{width:5px;height:5px;background:#fff;border-radius:50%}
.history-model{position:absolute;top:8px;right:8px;padding:3px 8px;background:rgba(255,255,255,.92);border-radius:4px;font-size:10px;color:#333;font-weight:600;backdrop-filter:blur(4px)}
.history-card-info{padding:10px 12px}
.history-prompt{font-size:11px;color:#a1a1aa;line-height:1.5;height:34px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.history-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:10px;color:#71717a}
.history-meta i{margin-right:3px}
/* 4列网格变体（图片类页面） */
.history-grid.grid-4{grid-template-columns:repeat(4,1fr)}
.history-grid.grid-4 .history-card-img{aspect-ratio:1/1}
/* 2列网格变体（grok等宽页面） */
.history-grid.grid-2{grid-template-columns:repeat(2,1fr)}
.history-card .delete-btn{position:absolute;top:6px;right:6px;width:24px;height:24px;background:rgba(0,0,0,.65);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;cursor:pointer;z-index:5;opacity:0;transition:all .2s;backdrop-filter:blur(4px)}
.history-card:hover .delete-btn{opacity:1}
.history-card .delete-btn:hover{background:#ef4444;transform:scale(1.1)}
[data-theme="light"] .history-card .delete-btn{background:rgba(255,255,255,.8);color:#71717a}
[data-theme="light"] .history-card .delete-btn:hover{background:#ef4444;color:#fff}

/* ========== 登录/注册弹窗 ========== */
.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:10000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(6px);animation:authFadeIn .25s ease}
.auth-modal-overlay.active{display:flex}
@keyframes authFadeIn{from{opacity:0}to{opacity:1}}
@keyframes authSlideUp{from{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

.auth-modal{width:420px;max-width:92vw;background:linear-gradient(180deg,#141418 0%,#1a1a20 100%);border-radius:20px;border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(168,85,247,.1);position:relative;padding:36px 32px 32px;animation:authSlideUp .3s ease both}

.auth-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:rgba(161,161,170,.5);font-size:20px;cursor:pointer;transition:all .2s;z-index:2}
.auth-modal-close:hover{background:rgba(255,255,255,.08);color:#fff}

.auth-modal-top{text-align:center;margin-bottom:28px}
.auth-modal-logo{width:56px;height:56px;background:linear-gradient(135deg,#a855f7 0%,#6366f1 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 8px 24px rgba(168,85,247,.35)}
.auth-modal-logo i{font-size:28px;color:#fff}
.auth-modal-title{font-size:22px;font-weight:700;color:#fff;margin-bottom:6px}
.auth-modal-desc{font-size:13px;color:rgba(161,161,170,.7)}

.auth-tabs-wrap{display:flex;background:rgba(255,255,255,.04);border-radius:12px;padding:4px;margin-bottom:24px;border:1px solid rgba(255,255,255,.06)}
.auth-tab-item{flex:1;padding:10px;text-align:center;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;color:rgba(161,161,170,.7);transition:all .25s}
.auth-tab-item:hover:not(.active){color:#fff}
.auth-tab-item.active{background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);color:#fff;box-shadow:0 4px 12px rgba(168,85,247,.35)}

.auth-form-panel{display:none}
.auth-form-panel.active{display:block;animation:authSlideUp .25s ease both}

.auth-field{margin-bottom:18px}
.auth-input-wrap{display:flex;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:0 14px;transition:all .25s}
.auth-input-wrap:focus-within{border-color:rgba(168,85,247,.5);box-shadow:0 0 0 3px rgba(168,85,247,.1);background:rgba(168,85,247,.03)}
.auth-input-wrap i{font-size:18px;color:rgba(161,161,170,.4);margin-right:10px;flex-shrink:0;transition:color .2s}
.auth-input-wrap:focus-within i{color:#a855f7}
.auth-input-wrap input{flex:1;height:48px;background:transparent;border:none;outline:none;color:#fff;font-size:14px}
.auth-input-wrap input::placeholder{color:rgba(82,82,91,.8)}

.auth-submit-btn{width:100%;height:50px;background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s;box-shadow:0 4px 20px rgba(168,85,247,.35);margin-top:6px}
.auth-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(168,85,247,.45)}
.auth-submit-btn:active{transform:translateY(0)}
.auth-submit-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

.auth-switch{text-align:center;margin-top:18px;font-size:13px;color:rgba(161,161,170,.6)}
.auth-switch a{color:#a855f7;text-decoration:none;font-weight:500;transition:color .2s}
.auth-switch a:hover{color:#c084fc;text-decoration:underline}

/* 日间模式 - 登录弹窗 */
[data-theme="light"] .auth-modal-overlay{background:rgba(0,0,0,.45)}
[data-theme="light"] .auth-modal{background:linear-gradient(180deg,#fff 0%,#fafafa 100%);border-color:#e4e4e7;box-shadow:0 30px 80px rgba(0,0,0,.15),0 0 0 1px rgba(124,58,237,.08)}
[data-theme="light"] .auth-modal-close{color:#a1a1aa}
[data-theme="light"] .auth-modal-close:hover{background:rgba(0,0,0,.05);color:#18181b}
[data-theme="light"] .auth-modal-title{color:#18181b}
[data-theme="light"] .auth-modal-desc{color:#71717a}
[data-theme="light"] .auth-tabs-wrap{background:#f4f4f5;border-color:#e4e4e7}
[data-theme="light"] .auth-tab-item{color:#71717a}
[data-theme="light"] .auth-tab-item:hover:not(.active){color:#18181b}
[data-theme="light"] .auth-tab-item.active{background:linear-gradient(135deg,#7c3aed 0%,#9333ea 100%);color:#fff}
[data-theme="light"] .auth-input-wrap{background:#f4f4f5;border-color:#e4e4e7}
[data-theme="light"] .auth-input-wrap:focus-within{border-color:rgba(124,58,237,.5);box-shadow:0 0 0 3px rgba(124,58,237,.08);background:#fff}
[data-theme="light"] .auth-input-wrap i{color:#a1a1aa}
[data-theme="light"] .auth-input-wrap:focus-within i{color:#7c3aed}
[data-theme="light"] .auth-input-wrap input{color:#18181b}
[data-theme="light"] .auth-input-wrap input::placeholder{color:#a1a1aa}
[data-theme="light"] .auth-submit-btn{background:linear-gradient(135deg,#7c3aed 0%,#9333ea 100%);box-shadow:0 4px 20px rgba(124,58,237,.25)}
[data-theme="light"] .auth-submit-btn:hover{box-shadow:0 8px 30px rgba(124,58,237,.35)}
[data-theme="light"] .auth-switch{color:#a1a1aa}
[data-theme="light"] .auth-switch a{color:#7c3aed}
[data-theme="light"] .auth-switch a:hover{color:#6d28d9}

/* 移动端 - 登录弹窗 */
@media(max-width:480px){
.auth-modal{padding:28px 20px 24px;border-radius:16px}
.auth-modal-logo{width:48px;height:48px;border-radius:14px}
.auth-modal-logo i{font-size:24px}
.auth-modal-title{font-size:20px}
.auth-modal-top{margin-bottom:22px}
}

/* ========== 充值按钮 ========== */
.header-recharge-btn{display:flex;align-items:center;gap:4px;padding:6px 14px;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:20px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;border:none;box-shadow:0 2px 8px rgba(245,158,11,.3)}
.header-recharge-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(245,158,11,.45)}
.header-recharge-btn i{font-size:14px}
[data-theme="light"] .header-recharge-btn{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);color:#fff}

/* ========== 套餐充值弹窗 ========== */
.recharge-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:10000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.recharge-modal-overlay.active{display:flex}
.recharge-modal{width:520px;max-width:94vw;max-height:90vh;overflow-y:auto;background:linear-gradient(180deg,#141418 0%,#1a1a20 100%);border-radius:20px;border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 80px rgba(0,0,0,.6);position:relative;padding:32px;animation:authSlideUp .3s ease both}
.recharge-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:rgba(161,161,170,.5);font-size:20px;cursor:pointer;transition:all .2s;z-index:2}
.recharge-modal-close:hover{background:rgba(255,255,255,.08);color:#fff}
.recharge-modal-header{text-align:center;margin-bottom:24px}
.recharge-modal-icon{width:52px;height:52px;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 8px 24px rgba(245,158,11,.3)}
.recharge-modal-icon i{font-size:26px;color:#fff}
.recharge-modal-header h3{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.recharge-modal-header p{font-size:13px;color:rgba(161,161,170,.7)}

/* 套餐卡片 */
.recharge-packages{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.recharge-pkg{background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.08);border-radius:14px;padding:18px 12px;text-align:center;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.recharge-pkg:hover{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.04)}
.recharge-pkg.selected{border-color:#f59e0b;background:rgba(245,158,11,.08);box-shadow:0 0 0 2px rgba(245,158,11,.2)}
.recharge-pkg.selected::after{content:'✓';position:absolute;top:8px;right:10px;font-size:14px;color:#f59e0b;font-weight:700}
.pkg-points{margin-bottom:8px}
.pkg-points-num{font-size:26px;font-weight:800;background:linear-gradient(135deg,#f59e0b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.pkg-price{font-size:18px;font-weight:700;color:#fff;margin-right:6px}
.pkg-original-price{font-size:12px;color:#666;text-decoration:line-through}
.pkg-name{font-size:12px;color:#888;margin-top:6px}
.pkg-desc{font-size:11px;color:#666;margin-top:4px}

/* 支付方式 */
.recharge-pay-section{border-top:1px solid rgba(255,255,255,.06);padding-top:18px}
.recharge-pay-label{font-size:13px;color:#888;margin-bottom:10px}
.recharge-pay-methods{display:flex;gap:10px;margin-bottom:16px}
.recharge-pay-method{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.08);border-radius:12px;cursor:pointer;transition:all .2s;font-size:14px;color:#ccc}
.recharge-pay-method:hover{border-color:rgba(255,255,255,.2)}
.recharge-pay-method.active{border-color:#8b5cf6;background:rgba(139,92,246,.08)}
.recharge-pay-method i{font-size:22px}
.recharge-submit-btn{width:100%;height:48px;background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s;box-shadow:0 4px 20px rgba(168,85,247,.35)}
.recharge-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(168,85,247,.45)}
.recharge-submit-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

/* 二维码支付 */
.pay-qr-container{text-align:center;padding:10px 0}
.pay-qr-info{margin-bottom:16px}
.pay-qr-pkg{font-size:15px;color:#ccc;margin-bottom:4px}
.pay-qr-amount{font-size:32px;font-weight:800;color:#f59e0b}
.pay-qr-code{margin:0 auto 14px;padding:16px;background:#fff;border-radius:12px;display:flex;justify-content:center;align-items:center;width:232px}
.pay-qr-code canvas,.pay-qr-code img{border-radius:4px}
.pay-qr-tip{font-size:13px;color:#888;margin-bottom:10px;display:flex;align-items:center;justify-content:center}
.pay-qr-status{font-size:13px;color:#f59e0b;display:flex;align-items:center;justify-content:center;gap:6px}

/* 日间模式 - 充值弹窗 */
[data-theme="light"] .recharge-modal{background:linear-gradient(180deg,#fff 0%,#fafafa 100%);border-color:#e4e4e7;box-shadow:0 30px 80px rgba(0,0,0,.15)}
[data-theme="light"] .recharge-modal-close{color:#a1a1aa}
[data-theme="light"] .recharge-modal-close:hover{background:rgba(0,0,0,.05);color:#18181b}
[data-theme="light"] .recharge-modal-header h3{color:#18181b}
[data-theme="light"] .recharge-modal-header p{color:#71717a}
[data-theme="light"] .recharge-pkg{background:#f9fafb;border-color:#e4e4e7}
[data-theme="light"] .recharge-pkg:hover{border-color:rgba(245,158,11,.5);background:rgba(245,158,11,.04)}
[data-theme="light"] .recharge-pkg.selected{border-color:#f59e0b;background:rgba(245,158,11,.06)}
[data-theme="light"] .pkg-price{color:#18181b}
[data-theme="light"] .pkg-name{color:#6b7280}
[data-theme="light"] .pkg-desc{color:#9ca3af}
[data-theme="light"] .recharge-pay-section{border-top-color:#e4e4e7}
[data-theme="light"] .recharge-pay-label{color:#6b7280}
[data-theme="light"] .recharge-pay-method{background:#f9fafb;border-color:#e4e4e7;color:#374151}
[data-theme="light"] .recharge-pay-method:hover{border-color:#d4d4d8}
[data-theme="light"] .recharge-pay-method.active{border-color:#7c3aed;background:rgba(124,58,237,.06)}
[data-theme="light"] .recharge-submit-btn{background:linear-gradient(135deg,#7c3aed 0%,#9333ea 100%);box-shadow:0 4px 20px rgba(124,58,237,.25)}
[data-theme="light"] .pay-qr-pkg{color:#374151}
[data-theme="light"] .pay-qr-tip{color:#6b7280}
[data-theme="light"] .pay-qr-status{color:#d97706}

/* 移动端 - 充值弹窗 */
@media(max-width:600px){
.recharge-modal{padding:24px 16px}
.recharge-packages{grid-template-columns:repeat(2,1fr);gap:8px}
.pkg-points-num{font-size:22px}
.pkg-price{font-size:16px}
.recharge-pay-methods{flex-direction:column;gap:8px}
}

@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
