/* =================================================================
   创世纪引擎 V21.1 - 终极整合版 CSS
   ================================================================= */
:root {
    --primary-color: #00f5d4; --secondary-color: #9b5de5; --accent-color: #f15bb5;
    --bg-color: #0d1117; --content-bg: #161b22; --border-color: #30363d;
    --text-color: #e6edf3; --text-muted: #8b949e; --font-display: 'Orbitron', sans-serif;
    --font-body: 'Noto Sans SC', sans-serif;
    --success-color: #28a745; --error-color: #dc3545; --info-color: #17a2b8;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background-color: var(--bg-color); color: var(--text-color); padding: 20px; }
.hidden { display: none !important; }

/* 整体布局 */
.main-container { width: 100%; max-width: 1600px; margin: 0 auto; }
.main-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 25px; flex-wrap: wrap; gap: 20px; }
.main-header h1 { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.5rem); color: var(--primary-color); }
.user-auth-section { display: flex; align-items: center; gap: 10px; }
#app-content.disabled { opacity: 0.4; pointer-events: none; filter: blur(3px); transition: all 0.5s ease; }

/* 导航标签 */
.main-nav-tabs { display: flex; border-bottom: 2px solid var(--border-color); margin-bottom: 25px; overflow-x: auto; scrollbar-width: none; }
.main-nav-tabs::-webkit-scrollbar { display: none; }
.main-tab { padding: 15px 20px; cursor: pointer; border: none; background: none; color: var(--text-muted); font-size: 0.95em; font-weight: 500; transition: all 0.3s ease; white-space: nowrap; position: relative; }
.main-tab::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 100%; height: 2px; background-color: var(--primary-color); transform: scaleX(0); transition: transform 0.3s ease; }
.main-tab:hover { color: var(--text-color); }
.main-tab.active { color: var(--primary-color); }
.main-tab.active::after { transform: scaleX(1); }
.main-tab .fas { margin-right: 8px; }
.tab-content { display: none; animation: fadeIn 0.5s ease; }
.tab-content.active { display: block; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

/* styles.css */

/* styles.css */
/* 当容器有 .database-panels-hidden 类时，隐藏资料库的导航入口 */
.main-nav-tabs.database-panels-hidden .database-tab {
    display: none;
}


/* [!!新增!!] 为开关按钮添加一个“激活”状态的样式 */
#toggle-database-btn.active {
    color: var(--primary-color);
    border-color: var(--primary-color);
    box-shadow: 0 0 8px rgba(0, 245, 212, 0.5);
}


/* 通用组件 */
textarea, input, select { background-color: var(--bg-color); border: 1px solid var(--border-color); border-radius: 8px; padding: 10px; color: var(--text-color); font-family: var(--font-body); width: 100%; }
.action-btn, .settings-btn { border: none; cursor: pointer; font-weight: 500; transition: all 0.3s ease; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 20px; border-radius: 8px; }
.settings-btn { background-color: var(--content-bg); color: var(--text-muted); border: 1px solid var(--border-color); }
.action-btn:disabled, .settings-btn:disabled { cursor: not-allowed; background: var(--border-color); color: var(--text-muted); opacity: 0.6; background-image: none; }
.modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.7); backdrop-filter: blur(5px); display: flex; justify-content: center; align-items: center; z-index: 2000; }
.modal-content { background: var(--content-bg); padding: 25px; border-radius: 12px; width: 90%; max-width: 500px; border: 1px solid var(--border-color); }
.modal-content.large { max-width: 800px; }
.modal-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border-color); padding-bottom: 15px; margin-bottom: 20px; }
.close-btn { background: none; border: none; color: var(--text-muted); font-size: 24px; cursor: pointer; }
.modal-footer { display: flex; justify-content: flex-end; align-items: center; gap: 10px; margin-top: 20px; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; margin-bottom: 10px; font-weight: 500; color: var(--text-muted); }

/* 灵感系统 */
.inspiration-panel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(450px, 1fr)); gap: 25px; }
.inspiration-section { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 25px; }
.inspiration-section h3, .panel-h3 { color: var(--primary-color); margin-top: 0; margin-bottom: 20px; border-bottom: 1px solid var(--border-color); padding-bottom: 10px; }
.tag-selector-container { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px; background-color: var(--bg-color); border-radius: 8px; border: 1px solid var(--border-color); max-height: 120px; overflow-y: auto; }
.tag { background-color: var(--content-bg); color: var(--text-muted); border: 1px solid var(--border-color); padding: 5px 12px; border-radius: 15px; font-size: 0.9em; cursor: pointer; }
.tag.selected { background-color: var(--accent-color); color: white; border-color: var(--accent-color); font-weight: bold; }
.combo-preview-card { margin-top: 20px; padding: 20px; border: 1px dashed var(--primary-color); border-radius: 8px; background-color: var(--bg-color); }
.combo-preview-card strong { color: var(--primary-color); }
.template-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.choice-card { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 20px; cursor: pointer; transition: all 0.3s ease; }
.choice-card:hover { transform: translateY(-5px); box-shadow: 0 8px 25px rgba(0, 245, 212, 0.15); border-color: var(--primary-color); }
.choice-card h4 { color: var(--primary-color); margin: 0 0 10px 0; }
.choice-card p { font-size: 0.95em; color: var(--text-muted); line-height: 1.6; }
.arc-section { margin-top: 15px; padding-top: 15px; border-top: 1px dashed var(--border-color); }
.arc-section h5 { color: var(--accent-color); margin-bottom: 8px; }
.arc-section p { font-size: 0.95em; line-height: 1.7; white-space: pre-wrap; }

/* AI审核反馈 */
#inspiration-validation-feedback, #worldview-validation-feedback { margin-top: 20px; padding: 15px; border-radius: 8px; border: 1px solid; transition: all 0.3s ease; background-color: var(--bg-color); }
.status-pending { border-color: var(--text-muted); }
.status-validating { border-color: var(--info-color); animation: pulse-border 1.5s infinite; }
.status-approved { border-color: var(--success-color); }
.status-rejected { border-color: var(--error-color); }
#inspiration-validation-status-text, #wv-validation-status-text { font-weight: bold; margin-bottom: 8px; }
#inspiration-validation-feedback-content, #wv-validation-feedback-content { font-size: 0.9em; line-height: 1.6; white-space: pre-wrap; }
#inspiration-validation-feedback-content strong, #wv-validation-feedback-content strong { color: var(--primary-color); }
@keyframes pulse-border { 0% { box-shadow: 0 0 0 0 rgba(23, 162, 184, 0.7); } 70% { box-shadow: 0 0 0 10px rgba(23, 162, 184, 0); } 100% { box-shadow: 0 0 0 0 rgba(23, 162, 184, 0); } }

/* 世界观设定 */
.document-panel { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 25px; }
#worldview-summary h3 { margin-top: 0; color: var(--primary-color); border-bottom: 1px solid var(--border-color); padding-bottom: 15px; margin-bottom: 15px; }
#worldview-summary p { line-height: 1.7; }
.worldview-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 20px; margin-top: 25px; }
.worldview-section-container { background-color: var(--bg-color); border: 1px solid var(--border-color); border-radius: 8px; padding: 20px; display: flex; flex-direction: column; }
.worldview-section label { font-weight: bold; color: var(--primary-color); margin-bottom: 10px; }
.worldview-section textarea { flex-grow: 1; resize: vertical; min-height: 250px; background-color: transparent; border: none; padding: 0; color: var(--text-muted); }
.worldview-actions { margin-top: 25px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 15px; }

/* 项目管理 */
#project-list-container { max-height: 60vh; overflow-y: auto; border: 1px solid var(--border-color); border-radius: 8px; padding: 10px; background: var(--bg-color); }
.project-item { display: flex; align-items: center; padding: 15px; border-bottom: 1px solid var(--border-color); transition: background-color 0.2s ease; }
.project-item:last-child { border-bottom: none; }
.project-item:hover { background-color: var(--border-color); }
.project-item.active { background-color: var(--border-color); border-left: 3px solid var(--primary-color); margin-left: -13px; padding-left: 25px; }
.project-info { flex-grow: 1; }
.project-info h4 { margin: 0 0 5px 0; color: var(--text-color); }
.project-info small { font-size: 0.8em; color: var(--text-muted); }
.project-actions { display: flex; gap: 8px; flex-shrink: 0; }
.project-actions .action-btn, .project-actions .settings-btn { padding: 6px 12px; font-size: 0.9em; }

/* AI助手 */
#assistant-widget { position: fixed; bottom: 30px; right: 30px; z-index: 1000; }
#assistant-toggle-btn { width: 60px; height: 60px; border-radius: 50%; background-color: var(--primary-color); color: var(--bg-color); border: none; font-size: 24px; cursor: pointer; display: flex; justify-content: center; align-items: center; box-shadow: 0 4px 15px rgba(0, 245, 212, 0.4); }
#assistant-window { position: absolute; bottom: 80px; right: 0; width: 380px; height: 550px; background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; box-shadow: 0 8px 30px rgba(0,0,0,0.3); display: flex; flex-direction: column; overflow: hidden; }
.assistant-header { display: flex; justify-content: space-between; align-items: center; padding: 10px 15px; background-color: var(--bg-color); }
.assistant-header h3 { margin-right: auto; }
#assistant-status { font-size: 0.8em; padding: 3px 8px; border-radius: 10px; color: white; transition: background-color 0.3s ease; }
#assistant-messages { flex-grow: 1; padding: 15px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.ai-message, .user-message { padding: 10px 15px; border-radius: 18px; max-width: 90%; line-height: 1.5; word-wrap: break-word; }
.user-message { background-color: var(--secondary-color); color: var(--content-bg); align-self: flex-end; border-bottom-right-radius: 4px; }
.ai-message { background-color: var(--bg-color); color: var(--text-color); align-self: flex-start; border-bottom-left-radius: 4px; }
.ai-message strong { color: var(--primary-color); }

/* 通知 */
#notification-container { position: fixed; top: 20px; right: 20px; z-index: 3000; display: flex; flex-direction: column; gap: 10px; width: 320px; }
.notification { padding: 15px 20px; border-radius: 8px; color: var(--text-color); background-color: var(--content-bg); border-left: 4px solid var(--border-color); box-shadow: 0 4px 12px rgba(0,0,0,0.25); animation: slideInAndOut 4s ease-out forwards; }
@keyframes slideInAndOut { 0%, 100% { opacity: 0; transform: translateX(100%); } 15%, 85% { opacity: 1; transform: translateX(0); } }

/* =================================================================
   新功能: 人物系统 (角色系统、原型、生成器)
   ================================================================= */

/* 通用文档面板样式 */
.document-panel h3 {
    color: var(--primary-color);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
    margin-top: 25px;
    margin-bottom: 20px;
}
.document-panel h4 {
    color: var(--accent-color);
    margin-top: 20px;
    margin-bottom: 10px;
}
.document-panel .sub-section {
    padding-left: 15px;
    border-left: 3px solid var(--border-color);
    margin-bottom: 20px;
}

/* 1. 角色系统 (数据库) */
.tags-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
}
.tag-item {
    background-color: var(--content-bg);
    color: var(--text-muted);
    padding: 4px 10px;
    border-radius: 15px;
    font-size: 0.9em;
    border: 1px solid var(--border-color);
}
.data-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 15px;
}
.data-table th, .data-table td {
    border: 1px solid var(--border-color);
    padding: 12px;
    text-align: left;
}
.data-table th {
    background-color: var(--bg-color);
    color: var(--primary-color);
}
.data-table td:first-child {
    font-weight: bold;
    color: var(--text-color);
}

/* 2. 角色原型 */
.archetype-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}
.archetype-card {
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 20px;
}
.archetype-card h4 {
    margin-top: 0;
    color: var(--accent-color);
}
.archetype-card p {
    font-size: 0.95em;
    line-height: 1.7;
    color: var(--text-muted);
}
.archetype-card ul {
    padding-left: 20px;
    margin-top: 10px;
    font-size: 0.9em;
}

/* 3. 角色生成器 */
/* styles.css - 修改后 */
.char-generator-layout, 
.story-generator-layout, 
.emotion-generator-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 25px;
}
.char-gen-controls, .char-gen-display {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
}
.char-gen-display h4 { color: var(--accent-color); }
.char-card-field { margin-bottom: 15px; }
.char-card-field label { font-weight: bold; color: var(--primary-color); display: block; margin-bottom: 5px; }
.char-card-field p { background: var(--bg-color); padding: 10px; border-radius: 5px; min-height: 20px; }

.character-deck-container {
    margin-top: 25px;
}
.character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 15px;
}
.character-card-slot {
    height: 200px;
    border: 1px dashed var(--border-color);
    border-radius: 8px;
    padding: 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    background-color: rgba(0,0,0,0.2);
    transition: all 0.3s ease;
}
.character-card-slot.filled {
    border-style: solid;
    border-color: var(--primary-color);
    background-color: var(--content-bg);
    cursor: pointer;
}
.character-card-slot.filled:hover {
    transform: scale(1.05);
    box-shadow: 0 0 15px rgba(0, 245, 212, 0.3);
}
.character-card-slot h5 { margin: 0 0 8px 0; color: var(--primary-color); }
.character-card-slot p { font-size: 0.8em; color: var(--text-muted); margin: 2px 0; }

/* [!!新增!!] 角色生成器与卡牌系统炫酷样式 */
.char-generator-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 25px;
}
.char-gen-controls, .char-gen-display {
    background: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    box-shadow: none;
}
.char-gen-controls h3, .char-gen-display h3, .character-deck-container h3 {
    color: var(--primary-color);
    text-shadow: 0 0 5px rgba(0, 245, 212, 0.5);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
    margin-bottom: 20px;
}
#char-gen-source {
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}
#char-gen-source h4 {
    margin-top: 0;
    color: var(--accent-color);
}
#char-gen-source p {
    font-size: 0.9em;
    color: var(--text-muted);
}
.char-card-field {
    margin-bottom: 15px;
}
.char-card-field label {
    font-weight: bold;
    color: var(--primary-color);
    display: block;
    margin-bottom: 8px;
    font-size: 0.9em;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.char-card-field p {
    background: var(--bg-color);
    padding: 12px;
    border-radius: 5px;
    min-height: 22px;
    color: var(--text-color);
    font-size: 0.95em;
    white-space: pre-wrap;
    border-left: 3px solid var(--accent-color);
}
.character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 20px;
    margin-top: 20px;
}
/* =================================================================
   [!!升级!!] 角色生成器 - 炫酷扑克牌卡组样式 V2
   ================================================================= */
.char-generator-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 25px;
}
.char-gen-controls, .char-gen-display {
    background: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    box-shadow: none;
}
.char-gen-controls h3, .char-gen-display h3, .character-deck-container h3 {
    color: var(--primary-color);
    text-shadow: 0 0 5px rgba(0, 245, 212, 0.5);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
    margin-bottom: 20px;
}
#char-gen-source {
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}
#char-gen-source h4 { margin-top: 0; color: var(--accent-color); }
#char-gen-source p { font-size: 0.9em; color: var(--text-muted); }
.char-card-field { margin-bottom: 15px; }
.char-card-field label { font-weight: bold; color: var(--primary-color); display: block; margin-bottom: 8px; font-size: 0.9em; text-transform: uppercase; letter-spacing: 1px; }
.char-card-field p { background: var(--bg-color); padding: 12px; border-radius: 5px; min-height: 22px; color: var(--text-color); font-size: 0.95em; white-space: pre-wrap; border-left: 3px solid var(--accent-color); }

.character-deck-container { margin-top: 25px; }
.character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

/* --- 全新扑克牌样式 --- */
.poker-card {
    height: 240px; /* 稍微调高一点以容纳更多细节 */
    border-radius: 10px;
    padding: 10px;
    display: flex;
    flex-direction: column;
    position: relative; /* 关键：为绝对定位的子元素提供坐标系 */
    overflow: hidden;
    background: var(--bg-color);
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    border: 1px solid var(--border-color);
}
.poker-card.filled:hover {
    transform: translateY(-10px) scale(1.08);
    box-shadow: 0 20px 30px rgba(0, 0, 0, 0.6);
    cursor: pointer;
}
.poker-card.empty {
    border: 2px dashed var(--border-color);
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
}
/* 中央的巨型花色“头像” */
.poker-card::before {
    content: attr(data-suit); /* 读取HTML的data-suit属性 */
    font-family: 'Times New Roman', serif;
    font-size: 9em;
    font-weight: bold;
    color: rgba(0, 0, 0, 0.2);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}
/* JQK人头牌的特殊“头像”标识 */
.poker-card.face-card::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    border: 2px solid rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    z-index: 2;
}

.card-corner {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    z-index: 3;
}
.card-corner.top-left {
    top: 8px;
    left: 10px;
}
.card-corner.bottom-right {
    bottom: 8px;
    right: 10px;
    transform: rotate(180deg); /* 核心：右下角旋转180度 */
}
.poker-card .rank {
    font-size: 1.8em;
    font-weight: 700;
    font-family: 'Orbitron', sans-serif;
}
.poker-card .suit {
    font-size: 1.5em;
    font-family: 'Times New Roman', serif;
}

/* 红黑花色 */
.poker-card.suit-hearts, .poker-card.suit-diams { color: #ff4757; }
.poker-card.suit-spades, .poker-card.suit-clubs { color: #e6edf3; }

/* 中央的角色信息 */
.card-body {
    position: relative; /* 调整为相对定位，居中 */
    text-align: center;
    z-index: 3;
    margin: auto; /* 让它在flex容器中自动居中 */
    background: rgba(13, 17, 23, 0.7);
    padding: 8px 5px;
    border-radius: 5px;
    width: 90%;
}
.card-body h5 {
    margin: 0;
    color: var(--primary-color);
    font-size: 1em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.card-body p {
    font-size: 0.8em;
    color: var(--text-muted);
    margin: 5px 0 0 0;
}
.poker-card.empty .card-body {
    display: none;
}

/* 大小王特殊样式 */
.poker-card.joker {
    justify-content: center;
    align-items: center;
}
.poker-card.joker::before {
    font-size: 5em;
}
.poker-card.joker.big { color: #ff4757; }
.poker-card.joker.small { color: #e6edf3; }.poker-card.suit-hearts .suit, .poker-card.suit-diams .suit {
    color: #ff4757;
}
.poker-card.suit-spades .suit, .poker-card.suit-clubs .suit {
    color: #e6edf3;
}
.poker-card .card-body {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 100%;
    padding: 0 5px;
}
.poker-card .card-body h5 {
    margin: 0;
    color: var(--primary-color);
    font-size: 1em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.poker-card .card-body p {
    font-size: 0.8em;
    color: var(--text-muted);
    margin: 5px 0 0 0;
}
.poker-card.joker {
    justify-content: center;
    align-items: center;
}
.poker-card.joker .suit {
    font-size: 4em;
    color: var(--accent-color);
}
/* [!!新增!!] 角色生成器与卡牌系统炫酷样式 */
.char-generator-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 25px;
}
.char-gen-controls, .char-gen-display {
    background: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    box-shadow: none;
}
.char-gen-controls h3, .char-gen-display h3, .character-deck-container h3 {
    color: var(--primary-color);
    text-shadow: 0 0 5px rgba(0, 245, 212, 0.5);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
    margin-bottom: 20px;
}
#char-gen-source {
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}
#char-gen-source h4 {
    margin-top: 0;
    color: var(--accent-color);
}
#char-gen-source p {
    font-size: 0.9em;
    color: var(--text-muted);
}
.char-card-field {
    margin-bottom: 15px;
}
.char-card-field label {
    font-weight: bold;
    color: var(--primary-color);
    display: block;
    margin-bottom: 8px;
    font-size: 0.9em;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.char-card-field p {
    background: var(--bg-color);
    padding: 12px;
    border-radius: 5px;
    min-height: 22px;
    color: var(--text-color);
    font-size: 0.95em;
    white-space: pre-wrap;
    border-left: 3px solid var(--accent-color);
}
.character-deck-container {
    margin-top: 25px;
}
.character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 20px;
    margin-top: 20px;
}
.poker-card {
    height: 220px;
    border-radius: 10px;
    padding: 10px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    background: var(--bg-color);
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.poker-card.filled:hover {
    transform: translateY(-10px) scale(1.05);
    box-shadow: 0 15px 25px rgba(0, 0, 0, 0.5);
    cursor: pointer;
}
.poker-card.empty {
    border: 2px dashed var(--border-color);
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 0.9em;
}
.poker-card .card-header, .poker-card .card-footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    text-shadow: 0 0 3px rgba(0,0,0,0.5);
}
.poker-card .card-footer {
    transform: rotate(180deg);
}
.poker-card .rank {
    font-size: 1.8em;
    font-weight: bold;
}
.poker-card .suit {
    font-size: 1.5em;
}
.poker-card.suit-hearts .rank, .poker-card.suit-diams .rank { color: #ff4757; }
.poker-card.suit-hearts .suit, .poker-card.suit-diams .suit { color: #ff4757; }
.poker-card.suit-spades .rank, .poker-card.suit-clubs .rank { color: #e6edf3; }
.poker-card.suit-spades .suit, .poker-card.suit-clubs .suit { color: #e6edf3; }
.poker-card .card-body {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 100%;
    padding: 0 5px;
}
.poker-card .card-body h5 {
    margin: 0;
    color: var(--primary-color);
    font-size: 1em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.poker-card .card-body p {
    font-size: 0.8em;
    color: var(--text-muted);
    margin: 5px 0 0 0;
}
.poker-card.joker {
    justify-content: center;
    align-items: center;
}
.poker-card.joker .suit {
    font-size: 4em;
}
.poker-card.joker.big { color: #ff4757; }
.poker-card.joker.small { color: #e6edf3; }

/* =================================================================
   新功能: 情节系统 & 情绪系统 面板样式
   ================================================================= */

/* 可折叠部分的基础样式 */
.document-panel details {
    border-left: 3px solid var(--border-color);
    padding: 10px 0 10px 15px;
    margin-bottom: 10px;
    background-color: rgba(0,0,0,0.1);
    border-radius: 0 8px 8px 0;
}
.document-panel details summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.1em;
    color: var(--primary-color);
    margin-bottom: 10px;
}
.document-panel details[open] summary {
    color: var(--accent-color);
}
.document-panel details p {
    margin-left: 15px;
}
.document-panel details .sub-section {
    border-color: #444; /* 嵌套的sub-section颜色变浅 */
}

/* 情节系统中的列表 */
.plot-list {
    list-style: none;
    padding-left: 0;
}
.plot-list li {
    background-color: var(--bg-color);
    padding: 8px 12px;
    border-radius: 5px;
    margin-bottom: 5px;
    font-size: 0.95em;
}

/* 情绪系统中的表格 */
.emotion-table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
}
.emotion-table th, .emotion-table td {
    border: 1px solid var(--border-color);
    padding: 12px;
    text-align: left;
}
.emotion-table th {
    background-color: var(--bg-color);
    color: var(--primary-color);
}
.emotion-table td:first-child {
    font-weight: bold;
    color: var(--text-color);
}


/* AI创作词典面板 */
.dictionary-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 25px;
}
.dictionary-controls {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
}
.dictionary-output {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    min-height: 50vh;
}
#dictionary-output-content {
    white-space: pre-wrap;
    line-height: 1.9;
}
/* =================================================================
   [!!升级!!] 情节系统 - 表格样式
   ================================================================= */

.plot-table-container {
    max-height: 80vh; /* 设定一个最大高度，超出部分可滚动 */
    overflow-y: auto;
    border: 1px solid var(--border-color);
    border-radius: 8px;
}

.plot-table {
    width: 100%;
    border-collapse: collapse;
}

.plot-table th, .plot-table td {
    border-bottom: 1px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    padding: 12px 15px;
    text-align: left;
    vertical-align: top; /* 垂直居上对齐 */
}

.plot-table th:last-child, .plot-table td:last-child {
    border-right: none;
}

.plot-table thead th {
    background-color: var(--bg-color);
    color: var(--primary-color);
    position: sticky; /* 让表头在滚动时固定 */
    top: 0;
    z-index: 10;
}

.plot-table tbody tr:nth-child(even) {
    background-color: rgba(0, 0, 0, 0.2);
}

.plot-table tbody tr:hover {
    background-color: rgba(0, 245, 212, 0.1);
}

.plot-table td {
    font-size: 0.95em;
    color: var(--text-muted);
}

/* 对不同层级的列设置不同宽度和颜色，增强结构感 */
.plot-table td:nth-child(1) { width: 8%; font-weight: bold; color: var(--accent-color); }
.plot-table td:nth-child(2) { width: 12%; font-weight: bold; color: var(--text-color); }
.plot-table td:nth-child(3) { width: 15%; }
.plot-table td:nth-child(4) { width: 15%; }
.plot-table td:nth-child(5) { width: 50%; }


/* styles.css */

/* [!!新增!!] AI生成内容的可编辑区域统一样式 */
.editable-ai-content {
    background-color: var(--bg-color);
    border: 1px dashed var(--border-color); /* 使用虚线以区别于用户输入区 */
    color: var(--text-muted);
    padding: 10px;
    border-radius: 5px;
    width: 100%;
    transition: all 0.3s ease;
    resize: vertical; /* 允许用户垂直调整大小 */
}

.editable-ai-content:focus {
    color: var(--text-color);
    border-color: var(--primary-color);
    background-color: #000;
    box-shadow: 0 0 10px rgba(0, 245, 212, 0.3);
}

/* 调整一下灵感系统中的label，适配新布局 */
#combo-preview .form-group label {
    font-size: 0.9em;
    color: var(--primary-color);
    margin-bottom: 5px;
}
/* styles.css */

/* [!!新增!!] 智能标题生成器相关样式 */

/* 将标题的 label 和 input/button 排在同一行 */
#combo-preview .form-group[data-layout="inline"] {
    display: flex;
    align-items: center;
    gap: 10px;
}

#combo-preview .form-group[data-layout="inline"] label {
    flex-shrink: 0; /* 防止label被压缩 */
    margin-bottom: 0;
}

#generate-title-btn {
    padding: 8px 12px;
    font-size: 0.9em;
    flex-shrink: 0;
}

/* 标题选项弹窗样式 */
#title-options-container {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 15px;
}

.title-option-card {
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    padding: 15px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.title-option-card:hover {
    border-color: var(--primary-color);
    background-color: rgba(0, 245, 212, 0.1);
}
/* styles.css */

/* [!!新增!!] 故事链/情绪链容器样式 */
.story-chain-container, .emotion-chain-container {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.story-card-item, .emotion-card-item {
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    border-left: 3px solid var(--accent-color);
}

.story-card-item h4, .emotion-card-item h4 {
    margin-top: 0;
    margin-bottom: 10px;
    color: var(--primary-color);
}


/* styles.css */

/* [!!新增!!] 新版蓝图骨架面板样式 */
.blueprint-layout {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
    gap: 25px;
}

.blueprint-section {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.blueprint-section h3 {
    color: var(--primary-color);
    margin-top: 0;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
}

.outline-controls {
    display: flex;
    gap: 15px;
    background-color: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    transition: opacity 0.5s ease;
}

.outline-controls.disabled {
    opacity: 0.5;
    pointer-events: none;
}

#blueprint-weaving-output, #blueprint-outline-output {
    flex-grow: 1;
    min-height: 400px;
    white-space: pre-wrap;
    line-height: 1.8;
    color: var(--text-muted);
    background-color: var(--bg-color);
    padding: 20px;
    border-radius: 8px;
}

/* styles.css */

/* [!!新增!!] 美化融合策略输出样式 */
#blueprint-weaving-output h4 {
    color: var(--primary-color);
    margin-top: 25px;
    margin-bottom: 10px;
    border-left: 3px solid var(--primary-color);
    padding-left: 10px;
}

.weaving-card {
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 15px;
}

.weaving-card h5 {
    color: var(--accent-color);
    margin-top: 0;
    margin-bottom: 15px;
}

.weaving-card p {
    margin-bottom: 10px;
    line-height: 1.7;
}

.weaving-card p strong {
    color: var(--text-color);
}

/* styles.css */

/* [!!新增!!] “圣典执笔者”工作台布局样式 */
.scribe-layout {
    display: grid;
    grid-template-columns: 1fr 2fr; /* 左栏占1/3，右栏占2/3 */
    gap: 25px;
    align-items: flex-start; /* 顶部对齐 */
}

.scribe-references, .scribe-workspace {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
}

.scribe-references h3, .scribe-workspace h3 {
    color: var(--primary-color);
    margin-top: 0;
    margin-bottom: 20px;
}

/* 参考资料区：可折叠样式 */
.scribe-references details {
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}

.scribe-references summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.1em;
    color: var(--accent-color);
}

.reference-content {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--border-color);
    font-size: 0.9em;
    line-height: 1.8;
    color: var(--text-muted);
    white-space: pre-wrap; /* 保留换行和空格 */
}

.reference-content textarea {
    min-height: 200px;
    background-color: #000;
}

/* 工作区控件样式 */
.scribe-controls {
    display: flex;
    gap: 15px;
    align-items: flex-end; /* 让按钮和下拉框底部对齐 */
    margin-bottom: 20px;
}

.scribe-controls .form-group {
    flex-grow: 1; /* 让下拉框占据更多空间 */
    margin-bottom: 0;
}

/* =================================================================
   V21.2 新增样式: 圣典执笔者工作台
   ================================================================= */

.scribe-layout {
    display: grid;
    grid-template-columns: 1fr 2fr; /* 左栏占1/3，右栏占2/3 */
    gap: 25px;
    align-items: flex-start; /* 顶部对齐 */
}

.scribe-references, .scribe-workspace {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    height: calc(85vh - 50px); /* 设定一个高度 */
    overflow-y: auto; /* 超出部分可滚动 */
}

.scribe-references h3, .scribe-workspace h3 {
    color: var(--primary-color);
    margin-top: 0;
    margin-bottom: 20px;
    position: sticky; /* 让标题在滚动时固定 */
    top: -25px; /* 抵消padding */
    background-color: var(--content-bg);
    padding: 15px 0;
    z-index: 10;
}

/* 参考资料区：可折叠样式 */
.scribe-references details {
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}

.scribe-references summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.1em;
    color: var(--accent-color);
}

.reference-content {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--border-color);
    font-size: 0.9em;
    line-height: 1.8;
    color: var(--text-muted);
    white-space: pre-wrap;
}

.canon-content p {
    margin-bottom: 10px;
}

/* 工作区控件样式 */
.scribe-controls {
    display: flex;
    gap: 15px;
    align-items: flex-end;
    margin-bottom: 20px;
}

.scribe-controls .form-group {
    flex-grow: 1;
    margin-bottom: 0;
}

#scribe-output-content {
    min-height: 60vh;
    line-height: 2; /* 增大行高，适应手机阅读 */
}

/* =================================================================
   V21.2 新增样式: 圣典执笔者工作台
   ================================================================= */

.scribe-layout {
    display: grid;
    grid-template-columns: 1fr 2fr; /* 左栏占1/3，右栏占2/3 */
    gap: 25px;
    align-items: flex-start; /* 顶部对齐 */
}

.scribe-references, .scribe-workspace {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    height: calc(85vh - 50px); /* 设定一个高度 */
    overflow-y: auto; /* 超出部分可滚动 */
}

.scribe-references h3, .scribe-workspace h3 {
    color: var(--primary-color);
    margin-top: 0;
    margin-bottom: 20px;
    position: sticky; /* 让标题在滚动时固定 */
    top: -25px; /* 抵消padding */
    background-color: var(--content-bg);
    padding: 15px 0;
    z-index: 10;
}

/* 参考资料区：可折叠样式 */
.scribe-references details {
    border: 1px solid var(--border-color);
    background-color: var(--bg-color);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}

.scribe-references summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.1em;
    color: var(--accent-color);
}

.reference-content {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--border-color);
    font-size: 0.9em;
    line-height: 1.8;
    color: var(--text-muted);
    white-space: pre-wrap;
}

.canon-content p {
    margin-bottom: 10px;
}

/* 工作区控件样式 */
.scribe-controls {
    display: flex;
    gap: 15px;
    align-items: flex-end;
    margin-bottom: 20px;
}

.scribe-controls .form-group {
    flex-grow: 1;
    margin-bottom: 0;
}

#scribe-output-content {
    min-height: 60vh;
    line-height: 2; /* 增大行高，适应手机阅读 */
}

/* =================================================================
   [!!新增!!] V21.5 - 人物详情弹窗优化布局
   ================================================================= */

/* 为弹窗内的主要内容区域创建一个新的三栏网格布局 */
.modal-char-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 创建三个宽度相等的列 */
    gap: 20px; /* 定义列与列之间的间距 */
    align-items: flex-start; /* 确保列内容从顶部对齐 */
}

/* 定义网格中的每一列 */
.modal-char-column {
    display: flex;
    flex-direction: column;
    gap: 18px; /* 定义列内部表单项的垂直间距 */
}

/* 调整弹窗内文本域的高度，使其更加紧凑 */
#character-detail-modal .modal-body textarea {
    min-height: 80px; /* 设置一个合理的最小高度 */
    resize: vertical; /* 允许用户垂直调整大小 */
}

/* 确保标签和输入框适配新布局 */
#character-detail-modal .char-card-field {
    margin-bottom: 0; /* 移除旧的底部边距，使用gap代替 */
}

/* 让弹窗底部的状态文本和按钮布局更清晰 */
#character-detail-modal .modal-footer {
    display: flex;
    justify-content: space-between; /* 状态文本居左，按钮居右 */
    align-items: center;
}

/* =================================================================
   V30.0 - 全新人物卡系统样式
   ================================================================= */
.character-deck-container .inspiration-section {
    margin-bottom: 25px;
}
.character-deck-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}
.character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 20px;
    min-height: 200px;
    padding-top: 5px;
}
.char-profile-card {
    background: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: all 0.3s ease;
    cursor: pointer;
    position: relative;
    box-shadow: 0 2px 5px rgba(0,0,0,0.3);
}
.char-profile-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 245, 212, 0.2);
    border-color: var(--primary-color);
}
.char-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 10px;
}
.char-card-header h5 {
    color: var(--primary-color);
    margin: 0;
    font-size: 1.2em;
    font-family: var(--font-display);
}
.char-card-header span {
    font-size: 0.9em;
    color: var(--text-muted);
    background: var(--bg-color);
    padding: 3px 8px;
    border-radius: 5px;
}
.char-card-body p {
    margin: 0 0 5px 0;
    font-size: 0.9em;
    color: var(--text-color);
    line-height: 1.6;
}
.char-card-body strong {
    color: var(--text-muted);
    margin-right: 8px;
    font-weight: 500;
}
.delete-char-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 20px;
    line-height: 1;
    opacity: 0.2;
    transition: all 0.3s ease;
    padding: 5px;
}
.char-profile-card:hover .delete-char-btn {
    opacity: 1;
}
.delete-char-btn:hover {
    color: var(--error-color);
    transform: scale(1.2) rotate(90deg);
}
/* 拖拽占位符样式 */
.sortable-ghost {
    opacity: 0.3;
    background: var(--primary-color);
    border-radius: 8px;
}

/* =================================================================
   创世纪引擎 V40.0 - 主题切换 & 视觉升级补丁
   ================================================================= */

/* --- 1. 定义两种主题的核心变量 --- */
/* 默认加载赛博朋克主题 */
body {
    --primary-color: #00f5d4;      /* 霓虹青色 */
    --secondary-color: #9b5de5;    /* 电光紫色 */
    --accent-color: #f15bb5;       /* 品红/粉色 */
    --bg-color: #0d1117;          /* 深邃黑 */
    --content-bg: #161b22;        /* 面板黑 */
    --border-color: #30363d;      /* 边框灰 */
    --text-color: #e6edf3;        /* 主文本白 */
    --text-muted: #8b949e;        /* 次要文本灰 */
    --font-display: 'Orbitron', sans-serif;
    --font-body: 'Noto Sans SC', sans-serif;
    --glow-color: rgba(0, 245, 212, 0.5); /* 辉光色 */
    --bg-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.08) 1px, transparent 0);
    --bg-size: 25px 25px;
    --success-color: #28a745;
    --error-color: #dc3545;
    --info-color: #17a2b8;
}

body.theme-cyberpunk {
    --primary-color: #00f5d4;
    --secondary-color: #9b5de5;
    --accent-color: #f15bb5;
    --bg-color: #0d1117;
    --content-bg: #161b22;
    --border-color: #30363d;
    --text-color: #e6edf3;
    --text-muted: #8b949e;
    --font-display: 'Orbitron', sans-serif;
    --font-body: 'Noto Sans SC', sans-serif;
    --glow-color: rgba(0, 245, 212, 0.5);
    --bg-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.08) 1px, transparent 0);
    --bg-size: 25px 25px;
}

body.theme-fantasy {
    --primary-color: #e6a75a;      /* 华丽金 */
    --secondary-color: #8a0707;    /* 贵族红 */
    --accent-color: #4a2c0f;       /* 深木色 */
    --bg-color: #2e261e;          /* 深棕背景 */
    --content-bg: #f5eeda;        /* 羊皮纸 */
    --border-color: #8c785d;      /* 旧木边框 */
    --text-color: #3d2b1f;        /* 墨水黑 */
    --text-muted: #7a5c43;        /* 浅棕文本 */
    --font-display: 'Cinzel', serif;
    --font-body: 'Noto Sans SC', serif;
    --glow-color: rgba(230, 167, 90, 0.4); /* 金色辉光 */
    --bg-image: url('https://www.transparenttextures.com/patterns/leather.png');
    --bg-size: auto;
}

body.theme-light {
    --primary-color: #2a9d8f;      /* 清新绿 */
    --secondary-color: #8338ec;    /* 柔和紫 */
    --accent-color: #e76f51;       /* 活力橙 (作为辅助强调) */
    --bg-color: #f8f9fa;          /* 极浅灰背景 */
    --content-bg: #ffffff;        /* 内容区纯白 */
    --border-color: #dee2e6;      /* 边框浅灰 */
    --text-color: #212529;        /* 主文本深灰 */
    --text-muted: #6c757d;        /* 次要文本中灰 */
    --font-display: 'Noto Sans SC', sans-serif; /* 换一个更柔和的标题字体 */
    --font-body: 'Noto Sans SC', sans-serif;
    --glow-color: rgba(42, 157, 143, 0.2); /* 绿色辉光 */
    --bg-image: none; /* 浅色模式不需要背景图 */
    --bg-size: auto;
}

/* --- 2. 应用变量到全局和基础元素 --- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-body);
    background-color: var(--bg-color);
    color: var(--text-color);
    background-image: var(--bg-image);
    background-size: var(--bg-size);
    transition: background-color 0.5s ease, color 0.5s ease;
    line-height: 1.6;
}

h1, h2, h3, h4, h5 {
    font-family: var(--font-display);
    color: var(--primary-color);
    margin-bottom: 0.5em;
}
h1 { font-size: 2.5em; text-shadow: 0 0 10px var(--glow-color); }
p { margin-bottom: 1em; }

/* --- 3. 重构关键组件样式 --- */
.main-container {
    max-width: 1400px;
    margin: 20px auto;
    padding: 20px;
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.main-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 20px;
}

.main-nav-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.main-tab {
    padding: 10px 15px;
    cursor: pointer;
    border: 1px solid var(--border-color);
    background-color: transparent;
    color: var(--text-muted);
    border-radius: 5px;
    transition: all 0.3s ease;
}
.main-tab:hover {
    color: var(--primary-color);
    border-color: var(--primary-color);
}
.main-tab.active {
    background-color: var(--primary-color);
    color: var(--bg-color);
    font-weight: bold;
    box-shadow: 0 0 15px var(--glow-color);
}

.tab-content { display: none; }
.tab-content.active { display: block; }

/* 按钮统一样式 */
.action-btn, .settings-btn {
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 1em;
    transition: all 0.3s ease;
    text-transform: uppercase;
}
.action-btn {
    background: var(--primary-color);
    color: var(--bg-color);
    border: 1px solid var(--primary-color);
    box-shadow: 0 0 10px var(--glow-color);
    font-family: var(--font-display);
}
.action-btn:hover:not(:disabled) {
    transform: scale(1.05);
    box-shadow: 0 0 20px var(--glow-color);
}
.action-btn:disabled {
    background: var(--border-color);
    color: var(--text-muted);
    cursor: not-allowed;
    box-shadow: none;
}
.settings-btn {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-muted);
}
.settings-btn:hover:not(:disabled) {
    color: var(--primary-color);
    border-color: var(--primary-color);
}

/* 主题切换器 */
.theme-switcher { display: flex; border-radius: 8px; overflow: hidden; border: 1px solid var(--border-color); }
.theme-btn { padding: 8px 15px; cursor: pointer; border: none; background-color: var(--content-bg); color: var(--text-muted); transition: all 0.3s ease; }
.theme-btn.active { background-color: var(--primary-color); color: var(--bg-color); font-weight: bold; }

/* --- 4. 核心重构：人物卡生成器 - 扑克牌风格 --- */
#character-deck-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 30px;
}

.char-profile-card {
    aspect-ratio: 2.5 / 3.5; /* 扑克牌标准比例 */
    padding: 15px;
    border-radius: 12px;
    cursor: grab;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    position: relative;
    overflow: hidden;
}
.char-profile-card:active { cursor: grabbing; }

/* 赛博朋克主题卡牌 */
.theme-cyberpunk .char-profile-card {
    background: linear-gradient(145deg, #1e242c, #1a1f27);
    box-shadow: 3px 3px 8px #0b0e11, -3px -3px 8px #212833, inset 0 0 2px var(--primary-color);
    border: 1px solid var(--border-color);
}
.theme-cyberpunk .char-profile-card:hover {
    transform: translateY(-10px) scale(1.05);
    box-shadow: 0 15px 25px rgba(0,0,0,0.5), 0 0 20px var(--glow-color);
    border-color: var(--primary-color);
}

/* 西方奇幻主题卡牌 */
.theme-fantasy .char-profile-card {
    background-color: var(--content-bg);
    background-image: url('https://www.transparenttextures.com/patterns/old-paper.png');
    border: 2px solid var(--border-color);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.2), 3px 3px 8px rgba(0,0,0,0.4);
}
.theme-fantasy .char-profile-card:hover {
    transform: translateY(-10px) scale(1.05);
    box-shadow: 0 15px 25px rgba(74, 44, 15, 0.4);
}

/* 卡牌内部结构 - 使用绝对定位实现扑克牌布局 */
.char-profile-card .char-card-header,
.char-profile-card .char-card-footer {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    font-weight: 700;
}
.char-profile-card .char-card-header { top: 10px; left: 15px; }
.char-profile-card .char-card-footer { bottom: 10px; right: 15px; transform: rotate(180deg); }

.char-profile-card .char-card-header h5,
.char-profile-card .char-card-footer h5 {
    font-size: 1.5em; /* 点数 */
    font-family: var(--font-display);
    color: var(--text-color);
    margin: 0;
}
.theme-cyberpunk .char-profile-card .char-card-header h5,
.theme-cyberpunk .char-profile-card .char-card-footer h5 {
     color: var(--primary-color);
}
.char-profile-card .char-card-header span,
.char-profile-card .char-card-footer span {
    font-size: 1.8em; /* 花色 */
    color: var(--secondary-color);
}
.theme-fantasy .char-card-header span,
.theme-fantasy .char-card-footer span {
    font-family: 'Times New Roman', serif;
}

/* 卡牌中央内容 */
.char-profile-card .char-card-body {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 80%;
    padding: 8px;
    border-radius: 8px;
    font-size: 0.8em;
}
.theme-cyberpunk .char-profile-card .char-card-body {
    background: rgba(0,0,0,0.4);
    border: 1px solid var(--border-color);
}
.theme-fantasy .char-profile-card .char-card-body {
    background: rgba(255,255,255,0.2);
}
.char-profile-card .char-card-body p { margin: 0; }
.char-profile-card .char-card-body strong {
    display: block;
    margin-bottom: 5px;
    color: var(--text-muted);
}

/* 删除按钮和勾选框 */
.char-profile-card .delete-char-btn {
    position: absolute;
    top: 5px;
    right: 5px;
    opacity: 0.5;
    background: none; border: none; font-size: 1.5em; color: var(--text-muted); cursor: pointer;
    z-index: 10;
}
.char-profile-card:hover .delete-char-btn { opacity: 1; }
.char-profile-card .char-select-checkbox {
    position: absolute;
    top: 15px;
    right: 15px;
    transform: scale(1.5); 
    accent-color: var(--primary-color);
    z-index: 10;
}
/* 将勾选框移到另一个角落，避免和删除按钮重叠 */
.char-profile-card .char-card-header + .char-select-checkbox {
    top: 15px;
    right: 15px;
}
/* 扑克牌新布局不需要单独的header，把勾选框放回左上角 */
.char-profile-card .char-select-checkbox {
    top: 10px; left: auto; right: 15px; /* 调整到右上角 */
}
/* 为左上角的header腾出空间 */
.char-profile-card .char-card-header ~ .char-select-checkbox {
     top: 15px; right: 15px;
}
/* 最终决定：勾选框和删除按钮分别在右上角和右下角（旋转后）附近 */
.char-profile-card .delete-char-btn {
    top: auto;
    bottom: 5px;
    left: 10px;
    transform: rotate(180deg);
}

/* 卡牌选中状态 */
.char-profile-card.selected {
    border-width: 3px;
    border-color: var(--accent-color) !important;
    box-shadow: 0 0 20px var(--accent-color);
}
/* =================================================================
   创世纪引擎 V40.0 - 终极整合版 CSS (这个是重复的，但保留以维持文件完整性)
   ================================================================= */

/* --- 核心变量与全局样式 --- */
:root {
    --success-color: #28a745;
    --error-color: #dc3545;
    --info-color: #17a2b8;
}

body {
    --primary-color: #00f5d4;
    --secondary-color: #9b5de5;
    --accent-color: #f15bb5;
    --bg-color: #0d1117;
    --content-bg: #161b22;
    --border-color: #30363d;
    --text-color: #e6edf3;
    --text-muted: #8b949e;
    --font-display: 'Orbitron', sans-serif;
    --font-body: 'Noto Sans SC', sans-serif;
    --glow-color: rgba(0, 245, 212, 0.5);
    --bg-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.08) 1px, transparent 0);
    --bg-size: 25px 25px;
}

body.theme-fantasy {
    --primary-color: #e6a75a;
    --secondary-color: #8a0707;
    --accent-color: #4a2c0f;
    --bg-color: #2e261e;
    --content-bg: #f5eeda;
    --border-color: #8c785d;
    --text-color: #3d2b1f;
    --text-muted: #7a5c43;
    --font-display: 'Cinzel', serif;
    --glow-color: rgba(230, 167, 90, 0.4);
    --bg-image: url('https://www.transparenttextures.com/patterns/leather.png');
    --bg-size: auto;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { 
    font-family: var(--font-body); 
    background-color: var(--bg-color); 
    color: var(--text-color); 
    padding: 20px; 
    background-image: var(--bg-image);
    background-size: var(--bg-size);
    transition: background-color 0.5s ease, color 0.5s ease;
}
.hidden { display: none !important; }

/* --- 整体布局 --- */
.main-container { width: 100%; max-width: 1600px; margin: 0 auto; }
.main-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 25px; flex-wrap: wrap; gap: 20px; }
.main-header h1 { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.5rem); color: var(--primary-color); text-shadow: 0 0 10px var(--glow-color); }
.user-auth-section { display: flex; align-items: center; gap: 10px; }
#app-content.disabled { opacity: 0.4; pointer-events: none; filter: blur(3px); transition: all 0.5s ease; }

/* --- 【已修复】导航与标签页 --- */
.main-nav-tabs { display: flex; border-bottom: 2px solid var(--border-color); margin-bottom: 25px; overflow-x: auto; scrollbar-width: none; }
.main-nav-tabs::-webkit-scrollbar { display: none; }
.main-tab { padding: 15px 20px; cursor: pointer; border: none; background: none; color: var(--text-muted); font-size: 0.95em; font-weight: 500; transition: all 0.3s ease; white-space: nowrap; position: relative; }
/*
  【BUG修复点说明】
  原始代码中，多个不同的 .main-tab.active 规则相互冲突。
  截图显示，激活的标签页应该有一个实色背景填充。因此，我将最终生效的样式修改如下：
  1. `background-color` 设置为主题色。
  2. `color` 设置为背景色，确保文字清晰可见。
  3. `::after` 伪元素的下划线效果在有背景填充时是多余的，因此将其隐藏。
*/
.main-tab.active { 
    background-color: var(--primary-color);
    color: var(--bg-color) !important; /* 使用!important确保文字颜色被强制覆盖 */
}
.main-tab::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 100%; height: 2px; background-color: var(--primary-color); transform: scaleX(0); transition: transform 0.3s ease; }
.main-tab:hover { color: var(--text-color); }
.main-tab.active::after { 
    transform: scaleX(1); 
    display: none; /* 隐藏下划线，因为已经有背景填充 */
}
.main-tab .fas { margin-right: 8px; }
.tab-content { display: none; animation: fadeIn 0.5s ease; }
.tab-content.active { display: block; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.main-nav-tabs.database-panels-hidden .database-tab { display: none; }
#toggle-database-btn.active { color: var(--primary-color); border-color: var(--primary-color); box-shadow: 0 0 8px var(--glow-color); }

/* --- 通用组件 --- */
textarea, input, select { background-color: var(--bg-color); border: 1px solid var(--border-color); border-radius: 8px; padding: 10px; color: var(--text-color); font-family: var(--font-body); width: 100%; transition: all 0.3s ease; }
textarea:focus, input:focus, select:focus { border-color: var(--primary-color); box-shadow: 0 0 10px var(--glow-color); outline: none; }
.action-btn, .settings-btn { border: none; cursor: pointer; font-weight: 500; transition: all 0.3s ease; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 20px; border-radius: 8px; }
.action-btn { background: var(--primary-color); color: #000; border: 1px solid var(--primary-color); }
.settings-btn { background-color: var(--content-bg); color: var(--text-muted); border: 1px solid var(--border-color); }
.action-btn:disabled, .settings-btn:disabled { cursor: not-allowed; background: var(--border-color); color: var(--text-muted); opacity: 0.6; box-shadow: none; }
.modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.7); backdrop-filter: blur(5px); display: flex; justify-content: center; align-items: center; z-index: 2000; }
.modal-content { background: var(--content-bg); padding: 25px; border-radius: 12px; width: 90%; max-width: 500px; border: 1px solid var(--border-color); }
.modal-content.large { max-width: 900px; }
.modal-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border-color); padding-bottom: 15px; margin-bottom: 20px; }
.close-btn { background: none; border: none; color: var(--text-muted); font-size: 24px; cursor: pointer; }
.modal-footer { display: flex; justify-content: flex-end; align-items: center; gap: 10px; margin-top: 20px; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; margin-bottom: 10px; font-weight: 500; color: var(--text-muted); }

/* --- 灵感系统 & 世界观 (新增独立审核样式) --- */
.inspiration-panel-grid, .worldview-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(450px, 1fr)); gap: 25px; }
.inspiration-section, .worldview-section-container { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 25px; }
.inspiration-section h3, .panel-h3 { color: var(--primary-color); margin-top: 0; margin-bottom: 20px; border-bottom: 1px solid var(--border-color); padding-bottom: 10px; }
.tag-selector-container { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px; background-color: var(--bg-color); border-radius: 8px; border: 1px solid var(--border-color); max-height: 120px; overflow-y: auto; }
.tag { background-color: var(--content-bg); color: var(--text-muted); border: 1px solid var(--border-color); padding: 5px 12px; border-radius: 15px; font-size: 0.9em; cursor: pointer; }
.tag.selected { background-color: var(--accent-color); color: white; border-color: var(--accent-color); font-weight: bold; }
.template-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.choice-card { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 20px; cursor: pointer; transition: all 0.3s ease; }
.choice-card:hover { transform: translateY(-5px); box-shadow: 0 8px 25px var(--glow-color); border-color: var(--primary-color); }
.choice-card h4 { color: var(--primary-color); margin: 0 0 10px 0; }
.choice-card p { font-size: 0.95em; color: var(--text-muted); line-height: 1.6; }

.arc-section, .worldview-section { 
    margin-top: 15px; 
    padding: 15px; 
    border-radius: 8px;
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
}
.arc-section h5, .worldview-section label { color: var(--accent-color); margin-bottom: 8px; }

/* [新增] 独立审核UI样式 */
.individual-review-controls {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}
.individual-review-controls button {
    flex: 1;
    padding: 5px 10px;
    font-size: 0.8em;
}
.individual-review-feedback {
    margin-top: 8px;
    padding: 8px;
    font-size: 0.85em;
    border-radius: 4px;
    border-left: 3px solid;
    display: none; /* 默认隐藏 */
}
.individual-review-feedback.status-validating { display: block; border-color: var(--info-color); }
.individual-review-feedback.status-approved { display: block; border-color: var(--success-color); }
.individual-review-feedback.status-rejected { display: block; border-color: var(--error-color); }


/* --- 通用审核反馈样式 --- */
.status-validating { animation: pulse-border 1.5s infinite; }
.status-approved { border-color: var(--success-color); }
.status-rejected { border-color: var(--error-color); }
@keyframes pulse-border { 0% { box-shadow: 0 0 0 0 rgba(23, 162, 184, 0.7); } 70% { box-shadow: 0 0 0 10px rgba(23, 162, 184, 0); } 100% { box-shadow: 0 0 0 0 rgba(23, 162, 184, 0); } }

/* --- 其他模块简化样式 --- */
.mode-choice-container { margin-top: 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.mode-choice-card { border: 1px solid var(--border-color); border-radius: 12px; padding: 20px; cursor: pointer; transition: all 0.3s ease; background-color: var(--content-bg); }
.mode-choice-card:hover { border-color: var(--primary-color); transform: translateY(-5px); box-shadow: 0 8px 25px var(--glow-color); }
.mode-choice-card h4 { color: var(--primary-color); margin: 0 0 10px 0; }
.mode-choice-card p { font-size: 0.9em; color: var(--text-muted); line-height: 1.6; }
.document-panel { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 25px; }
#project-list-container { max-height: 60vh; overflow-y: auto; border: 1px solid var(--border-color); border-radius: 8px; padding: 10px; background: var(--bg-color); }
.project-item { display: flex; align-items: center; padding: 15px; border-bottom: 1px solid var(--border-color); transition: background-color 0.2s ease; }
.project-item:last-child { border-bottom: none; }
.project-item:hover { background-color: var(--border-color); }
.project-item.active { background-color: var(--border-color); border-left: 3px solid var(--primary-color); margin-left: -13px; padding-left: 25px; }
.project-info { flex-grow: 1; }
.project-info h4 { margin: 0 0 5px 0; color: var(--text-color); }
.project-info small { font-size: 0.8em; color: var(--text-muted); }
.project-actions { display: flex; gap: 8px; flex-shrink: 0; }
.project-actions .action-btn, .project-actions .settings-btn { padding: 6px 12px; font-size: 0.9em; }

/* --- AI助手 --- */
#assistant-widget { position: fixed; bottom: 30px; right: 30px; z-index: 1000; }
#assistant-toggle-btn { width: 60px; height: 60px; border-radius: 50%; background-color: var(--primary-color); color: var(--bg-color); border: none; font-size: 24px; cursor: pointer; display: flex; justify-content: center; align-items: center; box-shadow: 0 4px 15px var(--glow-color); }
#assistant-window { position: absolute; bottom: 80px; right: 0; width: 380px; height: 550px; background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; box-shadow: 0 8px 30px rgba(0,0,0,0.3); display: flex; flex-direction: column; overflow: hidden; }
.assistant-header { display: flex; justify-content: space-between; align-items: center; padding: 10px 15px; background-color: var(--bg-color); }
.assistant-header h3 { margin-right: auto; }
#assistant-status { font-size: 0.8em; padding: 3px 8px; border-radius: 10px; color: white; transition: background-color 0.3s ease; }
#assistant-messages { flex-grow: 1; padding: 15px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.ai-message, .user-message { padding: 10px 15px; border-radius: 18px; max-width: 90%; line-height: 1.5; word-wrap: break-word; }
.user-message { background-color: var(--secondary-color); color: var(--content-bg); align-self: flex-end; border-bottom-right-radius: 4px; }
.ai-message { background-color: var(--bg-color); color: var(--text-color); align-self: flex-start; border-bottom-left-radius: 4px; }
.ai-message strong { color: var(--primary-color); }

/* --- 通知 --- */
#notification-container { position: fixed; top: 20px; right: 20px; z-index: 3000; display: flex; flex-direction: column; gap: 10px; width: 320px; }
.notification { padding: 15px 20px; border-radius: 8px; color: var(--text-color); background-color: var(--content-bg); border-left: 4px solid var(--primary-color); box-shadow: 0 4px 12px rgba(0,0,0,0.25); animation: slideInAndOut 4s ease-out forwards; }
@keyframes slideInAndOut { 0%, 100% { opacity: 0; transform: translateX(100%); } 15%, 85% { opacity: 1; transform: translateX(0); } }


/* --- 蓝图骨架 & 执笔者 --- */
.blueprint-layout, .scribe-layout { display: grid; grid-template-columns: repeat(auto-fit, minmax(500px, 1fr)); gap: 25px; align-items: flex-start; }
.blueprint-section, .scribe-references, .scribe-workspace { background-color: var(--content-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 25px; height: calc(85vh - 50px); overflow-y: auto; }
.blueprint-section h3, .scribe-references h3, .scribe-workspace h3 { color: var(--primary-color); margin-top: 0; border-bottom: 1px solid var(--border-color); padding-bottom: 15px; position: sticky; top: -25px; background-color: var(--content-bg); z-index: 10;}
.scribe-references details { border: 1px solid var(--border-color); background-color: var(--bg-color); border-radius: 8px; padding: 15px; margin-bottom: 15px; }
.scribe-references summary { cursor: pointer; font-weight: bold; font-size: 1.1em; color: var(--accent-color); }
.reference-content { margin-top: 15px; padding-top: 15px; border-top: 1px solid var(--border-color); font-size: 0.9em; line-height: 1.8; color: var(--text-muted); white-space: pre-wrap; }
.editable-ai-content { background-color: var(--bg-color); border: 1px dashed var(--border-color); color: var(--text-muted); padding: 10px; border-radius: 5px; width: 100%; transition: all 0.3s ease; resize: vertical; }
.editable-ai-content:focus { color: var(--text-color); border-color: var(--primary-color); background-color: var(--bg-color); box-shadow: 0 0 10px var(--glow-color); }



/* [V1.1 新增] 自动化流程按钮样式 */
.automation-controls {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 20px;
    padding: 10px;
    background-color: rgba(0,0,0,0.2);
    border-radius: 8px;
}
.automation-controls button {
    flex-grow: 1;
}


/* --- 润色Pro模块样式 [V1.1 新增] --- */
.polishing-step {
    padding: 15px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    margin-bottom: 15px;
    background-color: var(--bg-color);
}
.polishing-step h4 {
    color: var(--accent-color);
    margin-top: 0;
    margin-bottom: 10px;
}
.polishing-step p {
    font-size: 0.9em;
    color: var(--text-muted);
    margin-bottom: 10px;
}
.polishing-step button {
    width: 100%;
}

/* =================================================================
   V40.3 - 梦想布局重构版 - 样式补丁
   ================================================================= */

.scribe-section {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 25px;
    margin-bottom: 25px; 
}

.scribe-section h3 {
    margin-top: 0;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 20px;
}

.scribe-references-accordion details {
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
    transition: all 0.3s ease;
}

.scribe-references-accordion details[open] {
    border-color: var(--primary-color);
}

.scribe-references-accordion summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.2em;
    color: var(--primary-color);
}

.scribe-references-accordion summary:hover {
    color: var(--text-color);
}

#scribe-style-examples {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 15px;
}
.style-example-card {
    display: flex;
    flex-direction: column;
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    max-height: 500px;
    overflow: hidden;
}
.style-example-card h4 {
    color: var(--accent-color);
    margin-top: 0;
    margin-bottom: 10px;
    flex-shrink: 0;
}
.style-example-card p {
    white-space: pre-wrap;
    word-break: break-word;
    overflow-y: auto;
    flex-grow: 1;
    margin-bottom: 0;
    padding-right: 10px;
}

#scribe-batch-prompt, #scribe-chapter-prompt {
    background: var(--bg-color);
    padding: 15px;
    border-radius: 8px;
    border-left: 3px solid var(--accent-color);
    max-height: 200px;
    overflow-y: auto;
    white-space: pre-wrap;
    color: var(--text-muted);
    font-size: 0.9em;
    margin-bottom: 15px;
}

#scribe-navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 15px;
    gap: 10px;
}

#scribe-full-outline-display pre {
    white-space: pre-wrap;
    word-wrap: break-word;
    max-height: 500px;
    overflow-y: auto;
    padding-right: 10px;
}
/* =================================================================
   V40.5 - 后期制作模块UI优化
   ================================================================= */

.workspace-tabs {
    display: flex;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 15px;
}

.workspace-tab {
    padding: 10px 20px;
    cursor: pointer;
    border: none;
    background: none;
    color: var(--text-muted);
    font-size: 1em;
    position: relative;
    border-bottom: 2px solid transparent; /* 为激活状态预留位置 */
    transition: all 0.3s ease;
}

.workspace-tab:hover {
    color: var(--primary-color);
}

.workspace-tab.active {
    color: var(--primary-color);
    font-weight: bold;
    border-bottom-color: var(--primary-color); /* 激活时显示下划线 */
}

.final-export-section {
    margin-top: 25px;
    padding-top: 20px;
    border-top: 1px dashed var(--border-color);
}

.final-export-section h4 {
    color: var(--primary-color);
    margin-bottom: 10px;
}

.final-export-section p {
    font-size: 0.9em;
    color: var(--text-muted);
    margin-bottom: 15px;
}