/* ============================================
   layout.css — 容器、屏幕级布局
   ============================================ */

/* === 背景动画层（隐藏） === */
.bg-animation {
    display: none;
}

/* === 主题选择器 === */
.theme-selector {
    position: fixed;
    top: var(--space-4);
    right: var(--space-4);
    z-index: 100;
}

/* === 音效控制（隐藏） === */
.sound-control {
    display: none;
}

/* === 主容器 === */
.game-container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
    width: 90%;
    max-width: var(--container-max);
    height: 90vh;
    max-height: 880px;
    padding: 0;
    position: relative;
    overflow: hidden;
    animation: fade-in 0.3s ease;
    display: flex;
    flex-direction: column;
}

/* === 主菜单 === */
.main-menu {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: var(--space-6);
    text-align: center;
    animation: fade-in 0.3s ease;
}

.game-title {
    font-family: var(--font-serif);
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: 0.15em;
    margin-bottom: var(--space-4);
}

.game-description {
    font-family: var(--font-sans);
    color: var(--color-text-secondary);
    font-size: var(--text-sm);
    line-height: 1.7;
    margin-bottom: var(--space-6);
    max-width: var(--reading-width);
}

.menu-buttons {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    width: 100%;
    max-width: 360px;
}

/* === 角色创建 === */
.character-creation {
    display: none;
    flex-direction: column;
    height: 100%;
    padding: var(--space-5);
    animation: fade-in 0.3s ease;
}

.creation-title {
    text-align: center;
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--color-text);
    margin-top: var(--space-6);
    margin-bottom: var(--space-6);
}

.gender-selection {
    display: flex;
    justify-content: center;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.name-input-container {
    text-align: center;
    margin: var(--space-5) 0;
}

/* === 开始界面（隐藏） === */
.start-screen {
    display: none;
}

.features {
    display: none;
}

.feature-item {
    display: none;
}

/* === 游戏界面 === */
.game-screen {
    display: none;
    flex-direction: column;
    height: 100%;
    animation: fade-in 0.3s ease;
    overflow: hidden;
}

/* 顶部信息条 */
.game-screen-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-5);
    border-bottom: 1px solid var(--color-border);
    min-height: 48px;
    flex-shrink: 0;
}

.game-screen-header .player-name {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text);
}

.game-screen-header .age-display {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-secondary);
}

/* 标签横向滚动 */
.header-tags {
    display: flex;
    gap: var(--space-1);
    overflow-x: auto;
    padding: var(--space-2) var(--space-5);
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
    -webkit-overflow-scrolling: touch;
}

.header-tags::-webkit-scrollbar { height: 0; }

.header-tags .tags-container {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-1);
}

/* 历史区域 */
.event-history-section {
    flex: 4;
    overflow-y: auto;
    padding: var(--space-4) var(--space-5);
    background: #FAFAF9;
    min-height: 0;
}

.event-history-title {
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: var(--space-3);
}

.event-history {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

/* 事件区 */
.current-event-section {
    flex: 6;
    overflow-y: auto;
    padding: var(--space-5);
    border-top: 1px solid var(--color-border);
    min-height: 0;
}

/* === 游戏结束界面 === */
.gameover-screen {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: var(--space-6);
    text-align: center;
    animation: fade-in 0.3s ease;
    overflow-y: auto;
}

/* === 标签盒（游戏结束/详情页公用） === */
.tags-box {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    justify-content: center;
    padding: var(--space-3) 0;
}

/* === 历史容器（游戏结束/详情页公用） === */
.history-container {
    text-align: left;
    padding: var(--space-4) 0;
    max-width: var(--reading-width);
    width: 100%;
}

/* === 游戏结束标签 === */
.final-tags {
    padding: var(--space-4) 0;
    margin: var(--space-3) 0;
    background: none;
    border-radius: 0;
}

#finalTags.tags-box {
    background: none;
    border: none;
    padding: var(--space-2) 0;
}

/* === 成就界面 === */
.achievements-screen {
    display: none;
    flex-direction: column;
    height: 100%;
    animation: fade-in 0.3s ease;
    overflow: hidden;
}

.screen-header {
    display: flex;
    align-items: center;
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.screen-header h2 {
    flex: 1;
    text-align: center;
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--color-text);
}

.achievements-container {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-4) var(--space-5);
    min-height: 0;
}

.achievements-grid {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    max-width: var(--reading-width);
    margin: 0 auto;
}

/* === 墓地界面 === */
.replay-screen {
    display: none;
    flex-direction: column;
    height: 100%;
    animation: fade-in 0.3s ease;
    overflow: hidden;
}

.saved-lives-list {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-4) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    max-width: var(--reading-width);
    margin: 0 auto;
    width: 100%;
    min-height: 0;
}

/* === 人生详情界面 === */
.life-details-screen {
    display: none;
    flex-direction: column;
    height: 100%;
    animation: fade-in 0.3s ease;
    overflow: hidden;
}

.life-details-content {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-5);
    max-width: var(--reading-width);
    margin: 0 auto;
    width: 100%;
    min-height: 0;
}

/* === 历史时间轴列表 === */
.history-list {
    position: relative;
    padding-left: var(--space-5);
}

.history-list::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--color-border);
}

#historyList {
    text-align: left;
    padding: var(--space-4) 0;
}

#historyList .history-item {
    border-bottom: 1px solid var(--color-divider);
}

/* === 历史条目（游戏内） === */
#eventHistory .history-item {
    font-family: var(--font-serif);
    font-size: var(--text-sm);
    line-height: 1.6;
    color: var(--color-text-secondary);
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-divider);
    background: none;
    border-left: none;
    border-radius: 0;
    margin: 0;
    display: flex;
    align-items: baseline;
    gap: var(--space-2);
}

.history-age-badge {
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--color-accent);
    background: #EEEDFF;
    padding: 1px 6px;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
    line-height: 1.4;
}

.history-item-text {
    flex: 1;
}

/* === 人生详情摘要 === */
#lifeDetailsSummary {
    background: none;
    border-radius: 0;
    padding: var(--space-4) 0;
    margin-bottom: var(--space-5);
    box-shadow: none;
    border-bottom: 1px solid var(--color-divider);
}

#lifeDetailsSummary p {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    margin: var(--space-2) 0;
    line-height: 1.6;
}

#lifeDetailsSummary strong {
    color: var(--color-text-secondary);
    font-weight: 500;
    margin-right: var(--space-2);
}

.replay-tags-container {
    margin-bottom: var(--space-5);
}

.replay-tags-container h3,
#lifeDetailsHistoryContainer h3 {
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: var(--space-3);
    text-align: left;
}

/* === 屏幕过渡 === */
.page-exit {
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.page-enter {
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.screen-enter {
    animation: fade-in 0.3s ease;
}

/* === 游戏结束动画 === */
.gameover-animation {
    animation: none;
}

.gameover-screen .final-age,
.gameover-screen .death-reason,
.gameover-screen .final-tags,
.gameover-screen .history-container {
    opacity: 1;
    transform: none;
    animation: fade-in 0.3s ease forwards;
}

/* === 游戏结束标签颜色 === */
#finalTags .tag {
    background: var(--color-tag-bg);
    color: var(--color-tag-text);
    backdrop-filter: none;
    animation: none;
}

#finalTags .tag.black  { background: var(--color-tag-black-bg);  color: var(--color-tag-black-text); }
#finalTags .tag.red    { background: var(--color-tag-red-bg);    color: var(--color-tag-red-text); }
#finalTags .tag.purple { background: var(--color-tag-purple-bg); color: var(--color-tag-purple-text); }
#finalTags .tag.pink   { background: var(--color-tag-pink-bg);   color: var(--color-tag-pink-text); }
#finalTags .tag.golden { background: var(--color-tag-gold-bg);   color: var(--color-tag-gold-text); }

.gameover-buttons {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    width: 100%;
    max-width: 360px;
    margin-top: var(--space-6);
}

/* === 事件容器 === */
#eventContainer {
    max-height: none;
    padding-right: 0;
}

/* === 背景显示 === */
.background-display {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
}
