
/* ═══════ Legend Tracker UI ═══════ */
.legend-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 85%;
    max-width: 700px;
    height: 75vh;
    background: rgba(10, 10, 14, 0.95);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.8), 0 0 10px var(--blood-glow);
    z-index: 10000;
    display: none;
    flex-direction: column;
    backdrop-filter: blur(10px);
}

.legend-panel.open {
    display: flex;
    animation: modalSlideIn 0.3s ease-out forwards;
}

.legend-header {
    padding: 16px;
    background: rgba(0, 0, 0, 0.5);
    border-bottom: 1px solid var(--glass-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--text);
}

.legend-title {
    font-family: 'Courier New', monospace;
    font-size: 18px;
    font-weight: bold;
    color: var(--blood);
    text-shadow: 0 0 5px var(--blood);
    letter-spacing: 1px;
}

.legend-close {
    background: none;
    border: none;
    color: var(--text-dim);
    font-size: 24px;
    cursor: pointer;
    transition: color 0.3s;
}

.legend-close:hover {
    color: var(--blood);
    text-shadow: 0 0 8px var(--blood);
}

.legend-tabs {
    display: flex;
    gap: 4px;
    padding: 8px 12px;
    background: rgba(0, 0, 0, 0.3);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.legend-tab {
    padding: 8px 16px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid transparent;
    border-radius: 2px;
    color: var(--text-dim);
    cursor: pointer;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    transition: all 0.3s;
}

.legend-tab:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--text);
    border-color: rgba(255, 255, 255, 0.1);
}

.legend-tab.active {
    background: rgba(196, 30, 58, 0.1);
    color: var(--blood);
    border-color: var(--blood);
    box-shadow: 0 0 10px rgba(196, 30, 58, 0.2);
}

.legend-content {
    flex: 1;
    padding: 16px;
    overflow-y: auto;
    color: var(--text);
}

/* Custom Scrollbar for Legend Content */
.legend-content::-webkit-scrollbar {
    width: 6px;
}
.legend-content::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.3);
}
.legend-content::-webkit-scrollbar-thumb {
    background: var(--blood-dark);
    border-radius: 3px;
}

.legend-card {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-left: 3px solid var(--blood); /* Default, overridden inline for specific types */
    border-radius: 2px;
    padding: 12px;
    margin-bottom: 10px;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.legend-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
}

.legend-card:hover {
    background: rgba(20, 20, 25, 0.6);
    transform: translateX(2px);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
}

.legend-card.undiscovered {
    opacity: 0.6;
    border-left-color: var(--text-dim);
    filter: grayscale(0.8);
}

.legend-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.legend-card-name {
    font-family: 'Courier New', monospace;
    font-weight: bold;
    color: var(--text);
    font-size: 14px;
    text-shadow: 0 0 2px rgba(0,0,0,0.8);
}

.legend-card-type {
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 2px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-family: 'Courier New', monospace;
}

.legend-card-desc {
    font-size: 12px;
    color: var(--text-dim);
    margin-bottom: 8px;
    line-height: 1.4;
}

.legend-progress-bar {
    height: 4px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 2px;
    overflow: hidden;
    margin-top: 4px;
}

.legend-progress-fill {
    height: 100%;
    background: var(--blood); /* Default */
    box-shadow: 0 0 5px var(--blood);
    transition: width 0.3s ease;
}

.legend-section-title {
    margin: 0 0 12px 0;
    font-family: 'Courier New', monospace;
    font-size: 14px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-bottom: 4px;
}

.legend-section-title.active-title { color: var(--blood); text-shadow: 0 0 5px var(--blood); }
.legend-section-title.dormant-title { color: var(--text-dim); }
.legend-section-title.echo-title { color: var(--accent-blue); text-shadow: 0 0 5px var(--accent-blue); }

.curse-echo-item {
    padding: 8px 12px;
    background: rgba(0, 240, 255, 0.05);
    border: 1px solid rgba(0, 240, 255, 0.2);
    border-radius: 2px;
    margin-bottom: 6px;
    font-size: 12px;
    color: var(--accent-blue);
    display: flex;
    justify-content: space-between;
}

.ending-card {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 16px;
    margin-bottom: 10px;
    text-align: center;
    transition: all 0.3s;
}

.ending-card:hover {
    border-color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

.ending-card.locked {
    opacity: 0.4;
    border-color: #333;
}

.ending-icon {
    font-size: 32px;
    margin-bottom: 8px;
    filter: drop-shadow(0 0 5px rgba(255,255,255,0.2));
}

.ending-name {
    font-family: 'Courier New', monospace;
    font-weight: bold;
    color: var(--text);
    margin-bottom: 4px;
}

.ending-desc {
    font-size: 12px;
    color: var(--text-dim);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.stat-box {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 16px;
    border-radius: 2px;
    text-align: center;
}

.stat-value {
    font-family: 'Courier New', monospace;
    font-size: 24px;
    font-weight: bold;
    color: var(--blood);
    text-shadow: 0 0 8px var(--blood);
}

.stat-label {
    font-size: 11px;
    color: var(--text-dim);
    margin-top: 4px;
    text-transform: uppercase;
}

.legend-toggle-btn {
    position: fixed;
    bottom: 80px;
    right: 20px;
    width: 50px;
    height: 50px;
    background: rgba(0, 0, 0, 0.8);
    border: 1px solid var(--blood);
    border-radius: 50%;
    color: var(--blood);
    font-size: 20px;
    cursor: pointer;
    box-shadow: 0 0 15px var(--blood-glow);
    z-index: 9999;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.legend-toggle-btn:hover {
    transform: scale(1.1);
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 25px var(--blood);
}

/* ═══════ Advancement / Sacrifice System ═══════ */

/* Modal Overlays for Advancement */
.advancement-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(3, 3, 4, 0.95);
    z-index: 20000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(5px);
    animation: fadeIn 0.5s ease-out;
}

.advancement-modal-content {
    background: linear-gradient(135deg, #0a0a0e 0%, #120000 100%);
    border: 1px solid var(--blood);
    border-radius: 4px;
    padding: 40px;
    max-width: 800px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    color: var(--text);
    box-shadow: 0 0 50px rgba(139, 0, 0, 0.3), inset 0 0 20px rgba(139, 0, 0, 0.1);
    position: relative;
}

.advancement-modal-content::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--blood), transparent);
    animation: scanline 2s linear infinite;
}

.advancement-title {
    text-align: center;
    color: var(--blood);
    margin-bottom: 10px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-shadow: 0 0 10px var(--blood);
    font-size: 24px;
}

.advancement-subtitle {
    text-align: center;
    color: var(--text-dim);
    margin-bottom: 30px;
    font-style: italic;
    font-size: 14px;
}

.sacrifice-options-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 15px;
}

.sacrifice-option {
    background: rgba(10, 10, 14, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    padding: 20px;
    cursor: pointer;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.sacrifice-option:hover {
    background: rgba(20, 10, 10, 0.8);
    border-color: var(--blood);
    transform: translateX(5px);
    box-shadow: -5px 0 15px rgba(255, 15, 57, 0.2);
}

.sacrifice-option h4 {
    color: var(--blood);
    margin-bottom: 10px;
    font-family: 'Courier New', monospace;
    font-size: 16px;
    display: flex;
    align-items: center;
}

.sacrifice-profession-tag {
    font-size: 10px;
    border: 1px solid var(--accent-blue);
    color: var(--accent-blue);
    padding: 2px 6px;
    border-radius: 2px;
    margin-left: 10px;
    text-transform: uppercase;
    box-shadow: 0 0 5px rgba(0, 240, 255, 0.3);
}

.sacrifice-option p {
    color: var(--text-dim);
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 1.5;
}

.sacrifice-cost {
    color: var(--blood);
    font-size: 13px;
    font-weight: bold;
    margin-top: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sacrifice-warning {
    text-align: center;
    color: var(--text-muted);
    font-size: 12px;
    margin-top: 20px;
    font-family: 'Courier New', monospace;
}

/* Route Selection for Lv4 */
.route-selection-container {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.route-option {
    flex: 1;
    min-width: 250px;
    padding: 30px;
    cursor: pointer;
    transition: all 0.3s;
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    text-align: center;
}

.route-option:hover {
    border-color: var(--blood);
    background: rgba(20, 5, 5, 0.8);
    transform: scale(1.02);
    box-shadow: 0 0 20px rgba(255, 15, 57, 0.2);
}

.route-icon {
    font-size: 48px;
    margin-bottom: 15px;
    filter: drop-shadow(0 0 10px rgba(255, 15, 57, 0.5));
}

.route-title {
    color: var(--blood);
    font-family: 'Courier New', monospace;
    font-size: 18px;
    margin-bottom: 15px;
    text-transform: uppercase;
}

/* Final Form Lv5 */
.final-form-container {
    text-align: center;
}

.final-form-icon {
    font-size: 72px;
    margin-bottom: 20px;
    animation: pulse 2s infinite;
}

.final-form-btn {
    margin-top: 30px;
    padding: 14px 40px;
    background: var(--blood-dark);
    border: 1px solid var(--blood);
    color: var(--text);
    font-family: 'Courier New', monospace;
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 2px;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 0 15px var(--blood-glow);
}

.final-form-btn:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 30px var(--blood);
}

/* Ineligible Modal */
.ineligible-modal {
    background: rgba(10, 10, 14, 0.95);
    border: 1px solid var(--text-muted);
    border-radius: 4px;
    padding: 30px;
    max-width: 500px;
    text-align: center;
    color: var(--text);
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
}

.ineligible-list {
    text-align: left;
    color: var(--text-dim);
    margin: 20px 0;
    line-height: 1.8;
    padding-left: 20px;
}

.ineligible-btn {
    padding: 10px 25px;
    background: transparent;
    border: 1px solid var(--text-dim);
    color: var(--text-dim);
    border-radius: 2px;
    cursor: pointer;
    font-family: 'Courier New', monospace;
    transition: all 0.3s;
}

.ineligible-btn:hover {
    border-color: var(--text);
    color: var(--text);
    background: rgba(255, 255, 255, 0.05);
}

/* Bad Ending Modal Specifics */
.bad-ending-modal {
    background: linear-gradient(135deg, #0a0a0a 0%, #1a0000 100%);
    border: 3px solid #8b0000;
    border-radius: 8px;
    padding: 40px;
    max-width: 800px;
    width: 90%;
    text-align: center;
    color: #cc6666;
    box-shadow: 0 0 100px #8b0000;
}

.bad-ending-title {
    font-size: 28px;
    margin-bottom: 30px;
    color: #ff0000;
    font-weight: normal;
    letter-spacing: 4px;
    font-family: 'Courier New', monospace;
    text-shadow: 0 0 10px #ff0000;
    animation: glitch-text 3s infinite;
}

.bad-ending-text {
    color: #aa5555;
    line-height: 2.2;
    margin-bottom: 30px;
    text-align: left;
    font-size: 15px;
    font-family: 'Courier New', monospace;
}

.bad-ending-btn {
    padding: 15px 50px;
    background: transparent;
    border: 2px solid #8b0000;
    border-radius: 4px;
    color: #aa5555;
    cursor: pointer;
    font-size: 16px;
    letter-spacing: 3px;
    transition: all 0.3s;
    text-transform: uppercase;
}

.bad-ending-btn:hover {
    background: #8b0000;
    color: #fff;
    box-shadow: 0 0 20px #ff0000;
}


@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;700&display=swap');

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
    --blood: #ff0f39; /* Brighter, neon red */
    --blood-dark: #8a001a;
    --blood-glow: rgba(255, 15, 57, 0.6);
    --void: #030304; /* Darker void */
    --surface: #0a0a0e;
    --surface-light: #121218;
    --surface-hover: #1a1a24;
    --text: #e0e0e0;
    --text-dim: #888899;
    --text-muted: #555566;
    --accent-blue: #00f0ff; /* Cyber-horror blue */
    --accent-green: #00ff9d; /* Toxic green */
    --glass: rgba(10, 10, 14, 0.7);
    --glass-border: rgba(255, 15, 57, 0.2);
    --radius: 4px; /* Sharper corners for tech-horror */
    --scanline-color: rgba(0, 0, 0, 0.5);
}

/* ═══════ 全局输入框/文本域 ═══════ */
input, textarea, select {
    font-family: 'Courier New', monospace; /* Tech feel */
    color: var(--text);
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 10px 14px;
    font-size: 14px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    letter-spacing: 0.5px;
}

input:focus, textarea:focus, select:focus {
    border-color: var(--blood);
    box-shadow: 0 0 15px var(--blood-glow), inset 0 0 10px rgba(255, 15, 57, 0.1);
    background: rgba(10, 5, 5, 0.8);
    text-shadow: 0 0 5px var(--blood);
}

textarea {
    resize: vertical;
    line-height: 1.6;
    min-height: 70px;
}

body {
    font-family: 'Noto Sans SC', sans-serif;
    background-color: var(--void);
    color: var(--text);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
}

/* 动态迷雾背景 */
body::after {
    content: '';
    position: fixed;
    inset: -50%;
    width: 200%;
    height: 200%;
    background: 
        radial-gradient(circle at 50% 50%, rgba(20, 0, 5, 0.2) 0%, transparent 60%),
        repeating-linear-gradient(transparent 0, transparent 2px, rgba(0, 0, 0, 0.1) 3px),
        url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.05'/%3E%3C/svg%3E");
    animation: fog-move 60s linear infinite;
    pointer-events: none;
    z-index: -1;
    opacity: 0.6;
}

@keyframes fog-move {
    0% { transform: rotate(0deg) translate(0, 0); }
    50% { transform: rotate(2deg) translate(-20px, 20px); }
    100% { transform: rotate(0deg) translate(0, 0); }
}

/* 全屏扫描线 & 晕影 */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    background: 
        linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.25) 50%), 
        linear-gradient(90deg, rgba(255, 0, 0, 0.06), rgba(0, 255, 0, 0.02), rgba(0, 0, 255, 0.06));
    background-size: 100% 3px, 3px 100%;
    pointer-events: none;
    z-index: 9998;
    box-shadow: inset 0 0 150px rgba(0,0,0,0.9);
}

/* 滚动条 */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(196, 30, 58, 0.2); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: rgba(196, 30, 58, 0.4); }
::selection { background: rgba(196, 30, 58, 0.35); color: #fff; }

/* ═══════════════ HEADER ═══════════════ */
.header {
    background: rgba(10, 5, 5, 0.95);
    padding: 0 28px;
    height: 60px;
    border-bottom: 1px solid var(--blood-dark);
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 100;
    flex-shrink: 0;
    box-shadow: 0 5px 20px rgba(0,0,0,0.8);
    backdrop-filter: blur(5px);
}

.header::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: repeating-linear-gradient(90deg, transparent 0, transparent 2px, rgba(0,0,0,0.5) 3px);
    pointer-events: none;
    opacity: 0.3;
}

.header::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood), 0 0 20px var(--blood);
    animation: header-pulse 3s infinite;
}

@keyframes header-pulse {
    0%, 100% { opacity: 0.5; box-shadow: 0 0 5px var(--blood); }
    50% { opacity: 1; box-shadow: 0 0 15px var(--blood), 0 0 30px var(--blood); }
}

.title {
    font-size: 24px;
    color: var(--blood);
    text-shadow: 2px 0 var(--accent-blue), -2px 0 var(--blood-dark);
    letter-spacing: 4px;
    font-weight: 700;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    position: relative;
    animation: text-glitch 3s infinite alternate;
}

@keyframes text-glitch {
    0% { text-shadow: 2px 0 var(--accent-blue), -2px 0 var(--blood-dark); transform: skew(0deg); }
    20% { text-shadow: 2px 0 var(--accent-blue), -2px 0 var(--blood-dark); transform: skew(0deg); }
    21% { text-shadow: -2px 0 var(--accent-green), 2px 0 var(--blood); transform: skew(10deg); }
    22% { text-shadow: 2px 0 var(--accent-blue), -2px 0 var(--blood-dark); transform: skew(0deg); }
    100% { text-shadow: 2px 0 var(--accent-blue), -2px 0 var(--blood-dark); transform: skew(0deg); }
}

.settings-btn {
    background: rgba(0, 0, 0, 0.6);
    color: var(--blood);
    border: 1px solid var(--blood-dark);
    padding: 8px 16px;
    cursor: pointer;
    border-radius: 2px;
    transition: all 0.2s;
    font-size: 12px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    letter-spacing: 1px;
    position: relative;
    overflow: hidden;
}

.settings-btn:hover {
    background: var(--blood-dark);
    color: #fff;
    box-shadow: 0 0 15px var(--blood);
    border-color: var(--blood);
}

/* ═══════════════ LAYOUT ═══════════════ */
.container {
    flex: 1;
    display: flex;
    max-width: 1600px;
    width: 100%;
    margin: 0 auto;
    padding: 20px;
    gap: 20px;
    overflow: hidden;
    position: relative;
}

.game-area {
    flex: 1;
    padding: 0; /* Remove padding to let messages flow */
    overflow-y: auto;
    background: rgba(5, 5, 8, 0.85);
    border: 1px solid var(--surface-light);
    border-radius: 4px;
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.8), inset 0 0 50px rgba(0, 0, 0, 0.5);
    max-height: calc(100vh - 100px);
    position: relative;
    backdrop-filter: blur(5px);
    display: flex;
    flex-direction: column;
}

/* Inner container for padding if needed, or apply to message container */
#messageContainer {
    padding: 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Decoration corners for game area */
.game-area::before {
    content: '';
    position: absolute;
    top: -1px; left: -1px;
    width: 20px; height: 20px;
    border-top: 2px solid var(--blood);
    border-left: 2px solid var(--blood);
    z-index: 10;
}
.game-area::after {
    content: '';
    position: absolute;
    bottom: -1px; right: -1px;
    width: 20px; height: 20px;
    border-bottom: 2px solid var(--blood);
    border-right: 2px solid var(--blood);
    z-index: 10;
}

/* 里世界 */
.game-area.inner-world {
    background: linear-gradient(180deg, rgba(20, 0, 0, 0.9) 0%, rgba(10, 0, 0, 0.95) 100%);
    border: 1px solid var(--blood);
    box-shadow: 0 0 50px rgba(255, 0, 0, 0.1), inset 0 0 100px rgba(50, 0, 0, 0.5);
    animation: inner-world-pulse 4s infinite;
}

@keyframes inner-world-pulse {
    0%, 100% { border-color: var(--blood); box-shadow: 0 0 20px rgba(196, 30, 58, 0.2); }
    50% { border-color: #ff0000; box-shadow: 0 0 40px rgba(255, 0, 0, 0.4); }
}

/* ═══════════════ STATUS PANEL ═══════════════ */
.status-panel {
    width: 300px;
    background: rgba(5, 5, 8, 0.9);
    border: 1px solid var(--surface-light);
    border-radius: 4px;
    padding: 20px;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    flex-shrink: 0;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
    position: relative;
}

.status-panel::before {
    content: 'STATUS_MONITOR_V2.0';
    position: absolute;
    top: 5px; right: 10px;
    font-size: 8px;
    color: var(--text-muted);
    letter-spacing: 1px;
    font-family: monospace;
    opacity: 0.5;
}

.stat-item {
    margin-bottom: 15px;
    padding: 12px;
    background: rgba(0, 0, 0, 0.4);
    border-radius: 2px;
    border-left: 2px solid var(--text-muted);
    transition: all 0.3s;
}

.stat-item:hover {
    background: rgba(255, 255, 255, 0.02);
    border-left-color: var(--blood);
    box-shadow: 5px 0 10px -5px rgba(0,0,0,0.5);
}

.stat-label {
    color: var(--text-dim);
    font-size: 11px;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
    display: flex;
    justify-content: space-between;
}

.stat-value {
    color: var(--text);
    font-size: 18px;
    font-weight: 700;
    font-family: 'Courier New', monospace;
    text-shadow: 0 0 5px rgba(255,255,255,0.2);
}

.stat-bar {
    height: 6px;
    background: rgba(0, 0, 0, 0.6);
    margin-top: 8px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.stat-fill {
    height: 100%;
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood);
    position: relative;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.stat-fill::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.4) 50%, transparent 100%);
    opacity: 0.5;
    background-size: 200% 100%;
    animation: bar-shine 2s infinite linear;
}

@keyframes bar-shine {
    from { background-position: 200% 0; }
    to { background-position: -200% 0; }
}

.stat-fill.sanity {
    background: var(--accent-blue);
    box-shadow: 0 0 10px var(--accent-blue);
}

/* 属性状态显示 */
.attributes-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
    text-align: center;
}

.status-attr-item {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 4px;
    transition: all 0.3s;
}

.status-attr-item:hover {
    border-color: var(--text-dim);
    background: rgba(255, 255, 255, 0.05);
}

.status-attr-item.vit .attr-name { color: #ff4d4d; }
.status-attr-item.per .attr-name { color: #ffa64d; }
.status-attr-item.agi .attr-name { color: #4dff88; }
.status-attr-item.wil .attr-name { color: #b366ff; }
.status-attr-item.int .attr-name { color: #4da6ff; }

.attr-name {
    font-size: 10px;
    font-weight: 700;
    margin-bottom: 2px;
    text-shadow: 0 0 5px currentColor;
}

.attr-val {
    color: var(--text);
    font-size: 12px;
    font-family: 'Courier New', monospace;
    font-weight: 600;
}

/* Brain */
.brain-indicator {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 6px 0;
}

.brain-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    position: relative;
    transition: all 0.5s;
    background: #000;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.brain-circle.healthy {
    box-shadow: 0 0 15px var(--accent-green), inset 0 0 10px var(--accent-green);
    border-color: var(--accent-green);
    animation: pulse-green 3s infinite;
}

.brain-circle.uneasy {
    box-shadow: 0 0 15px #ffcc00, inset 0 0 10px #ffcc00;
    border-color: #ffcc00;
    animation: pulse-yellow 2s infinite;
}

.brain-circle.confused {
    box-shadow: 0 0 20px #ff5500, inset 0 0 15px #ff5500;
    border-color: #ff5500;
    animation: pulse-orange 1s infinite;
}

.brain-circle.collapsing {
    box-shadow: 0 0 30px var(--blood), inset 0 0 20px var(--blood);
    border-color: var(--blood);
    animation: pulse-red 0.2s infinite;
}

@keyframes pulse-green { 0%, 100% { opacity: 0.8; } 50% { opacity: 1; box-shadow: 0 0 25px var(--accent-green); } }
@keyframes pulse-yellow { 0%, 100% { opacity: 0.8; } 50% { opacity: 1; box-shadow: 0 0 25px #ffcc00; } }
@keyframes pulse-orange { 0%, 100% { opacity: 0.8; } 50% { opacity: 1; box-shadow: 0 0 30px #ff5500; } }
@keyframes pulse-red { 0%, 100% { opacity: 0.8; transform: scale(1); } 50% { opacity: 1; transform: scale(1.1); box-shadow: 0 0 40px var(--blood); } }

.brain-text {
    color: var(--text);
    font-size: 14px;
    font-weight: 700;
    font-family: 'Courier New', monospace;
    letter-spacing: 1px;
    text-transform: uppercase;
}

/* ═══════════════ MODAL ═══════════════ */
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 999;
}

.modal-overlay.show {
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal {
    background: rgba(10, 5, 8, 0.95);
    border: 1px solid var(--blood);
    border-radius: 4px;
    width: 90%;
    max-width: 650px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 0 50px rgba(196, 30, 58, 0.2), inset 0 0 100px rgba(0, 0, 0, 0.8);
    position: relative;
}

.modal::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.modal-header {
    background: rgba(20, 0, 5, 0.5);
    padding: 20px 24px;
    border-bottom: 1px solid var(--blood-dark);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-header h2 {
    color: var(--blood);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-shadow: 0 0 10px var(--blood-dark);
}

.close-btn {
    background: transparent;
    border: 1px solid var(--text-dim);
    color: var(--text-dim);
    font-size: 20px;
    cursor: pointer;
    width: 30px; height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.close-btn:hover {
    border-color: var(--blood);
    color: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.modal-body { padding: 24px; }

.form-group { margin-bottom: 20px; }

.form-group label {
    display: block;
    color: var(--text-dim);
    margin-bottom: 8px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ═══════════════ BUTTONS ═══════════════ */
.btn {
    padding: 12px 24px;
    border: 1px solid transparent;
    border-radius: 2px;
    cursor: pointer;
    font-family: 'Courier New', monospace;
    font-size: 14px;
    font-weight: 700;
    transition: all 0.2s;
    letter-spacing: 2px;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
}

.btn-primary {
    background: rgba(10, 0, 5, 0.8);
    color: var(--blood);
    border: 1px solid var(--blood);
    box-shadow: 0 0 10px rgba(196, 30, 58, 0.1);
}

.btn-primary:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 20px var(--blood), 0 0 40px var(--blood-dark);
    text-shadow: 0 0 5px rgba(255,255,255,0.5);
}

.btn-secondary {
    background: transparent;
    color: var(--text-dim);
    border: 1px solid var(--text-muted);
}

.btn-secondary:hover {
    border-color: var(--text);
    color: var(--text);
    background: rgba(255, 255, 255, 0.05);
}

.btn-success {
    background: rgba(0, 20, 10, 0.8);
    color: var(--accent-green);
    border: 1px solid var(--accent-green);
}
.btn-success:hover {
    background: var(--accent-green);
    color: #000;
    box-shadow: 0 0 20px var(--accent-green);
}

.btn-info {
    background: rgba(0, 10, 20, 0.8);
    color: var(--accent-blue);
    border: 1px solid var(--accent-blue);
}
.btn-info:hover {
    background: var(--accent-blue);
    color: #000;
    box-shadow: 0 0 20px var(--accent-blue);
}

.btn-danger {
    background: rgba(20, 0, 0, 0.8);
    color: #ff3333;
    border: 1px solid #ff3333;
}
.btn-danger:hover {
    background: #ff3333;
    color: #000;
    box-shadow: 0 0 20px #ff3333;
}

/* ═══════════════ MAIN MENU ═══════════════ */
.main-menu {
    text-align: center;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 80vh;
    position: relative;
    z-index: 200;
}

.main-menu h1 {
    font-size: 64px;
    color: var(--blood);
    margin-bottom: 20px;
    text-shadow: 4px 0 var(--blood-dark), -4px 0 rgba(0,0,0,0.8);
    letter-spacing: 12px;
    font-weight: 700;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    animation: title-glitch-hard 4s infinite alternate;
}

@keyframes title-glitch-hard {
    0% { transform: skew(0deg); opacity: 1; }
    5% { transform: skew(10deg); opacity: 0.8; }
    10% { transform: skew(-10deg); opacity: 1; }
    15% { transform: skew(0deg); opacity: 1; }
    60% { transform: skew(0deg); filter: hue-rotate(0deg); }
    65% { transform: skew(5deg) scale(1.05); filter: hue-rotate(90deg); color: var(--text); }
    70% { transform: skew(0deg); filter: hue-rotate(0deg); color: var(--blood); }
    100% { transform: skew(0deg); }
}

.main-menu p {
    color: var(--text-dim);
    font-size: 16px;
    margin-bottom: 60px;
    letter-spacing: 6px;
    text-transform: uppercase;
    font-family: monospace;
    border-bottom: 1px solid var(--blood-dark);
    padding-bottom: 10px;
}

.menu-buttons {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 300px;
}

.menu-btn {
    padding: 18px;
    font-size: 16px;
    background: rgba(0, 0, 0, 0.6);
    color: var(--text);
    border: 1px solid var(--glass-border);
    cursor: pointer;
    transition: all 0.2s;
    letter-spacing: 4px;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
}

.menu-btn::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, var(--blood), transparent);
    transition: left 0.4s;
    opacity: 0.2;
}

.menu-btn:hover {
    border-color: var(--blood);
    color: var(--blood);
    background: rgba(20, 0, 5, 0.8);
    box-shadow: 0 0 20px rgba(196, 30, 58, 0.3);
    text-shadow: 0 0 8px var(--blood);
    transform: scale(1.05);
}

.menu-btn:hover::before { left: 100%; }

/* ═══════════════ MESSAGES ═══════════════ */
.message {
    margin-bottom: 20px;
    padding: 15px 20px;
    border-radius: 2px;
    background: rgba(0, 0, 0, 0.4);
    border-left: 2px solid transparent;
    position: relative;
    transition: all 0.3s;
    line-height: 1.8;
    backdrop-filter: blur(2px);
    animation: msg-decode 0.4s ease-out both;
}

@keyframes msg-decode {
    from { opacity: 0; transform: translateX(-10px); clip-path: inset(0 100% 0 0); }
    to { opacity: 1; transform: translateX(0); clip-path: inset(0 0 0 0); }
}

.message:hover {
    background: rgba(20, 20, 30, 0.6);
    box-shadow: 0 0 20px rgba(0,0,0,0.5);
}

/* AI消息 */
.message.ai-message, .message.ai {
    border-left: 3px solid var(--blood);
    background: linear-gradient(90deg, rgba(20, 0, 5, 0.6) 0%, transparent 100%);
}

.message.ai-message::after {
    content: '⚠ ABYSS_SIGNAL_RECEIVED';
    position: absolute;
    bottom: 2px; right: 5px;
    font-size: 8px;
    color: var(--blood);
    opacity: 0.4;
    font-family: monospace;
    letter-spacing: 1px;
}

/* 玩家消息 */
.message.player-message, .message.player {
    border-left: 3px solid var(--accent-blue);
    background: linear-gradient(90deg, rgba(0, 10, 20, 0.6) 0%, transparent 100%);
    text-align: right; /* Player message right aligned for chat feel? No, standard is left but visually distinct */
}

/* 系统消息 */
.message.system-message, .message.system {
    border-left: 2px solid var(--text-muted);
    color: var(--text-dim);
    font-family: monospace;
    font-size: 12px;
    background: rgba(255, 255, 255, 0.02);
}

.message-content {
    font-size: 15px;
    line-height: 1.8;
    letter-spacing: 0.3px;
    white-space: pre-wrap;
    word-break: break-word;
    color: #ddd;
    text-shadow: 0 0 2px rgba(0,0,0,0.8);
}

.message-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    padding-bottom: 5px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    font-size: 10px;
    font-family: monospace;
}

.message-header span {
    letter-spacing: 1.5px;
    font-weight: 500;
    text-transform: uppercase;
}

.message-floor-indicator {
    font-size: 11px;
    color: var(--text-dim);
    background: rgba(255, 255, 255, 0.05);
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 8px;
    font-weight: normal;
    user-select: none;
    border: 1px solid var(--glass-border);
}

.ai-message .message-header span { color: var(--blood); text-shadow: 0 0 5px var(--blood-dark); }
.player-message .message-header span { color: var(--accent-blue); text-shadow: 0 0 5px rgba(0, 240, 255, 0.4); }

.message-actions button, .message-header-actions button {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.1);
    cursor: pointer;
    font-size: 12px;
    opacity: 0;
    transition: all 0.2s;
    padding: 2px 6px;
    color: var(--text-dim);
}

.message:hover .message-actions button,
.message:hover .message-header-actions button {
    opacity: 0.6;
}

.message-actions button:hover,
.message-header-actions button:hover {
    opacity: 1 !important;
    border-color: var(--text);
    color: var(--text);
    box-shadow: 0 0 10px rgba(255,255,255,0.2);
}

/* ═══════════════ AI THINKING ═══════════════ */
#ai-thinking,
.loading-message {
    background: transparent !important;
    border: none !important;
    padding: 30px !important;
    text-align: center;
    position: relative;
    overflow: hidden;
}

#ai-thinking .ai-thinking-content,
.loading-message .message-content {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    color: var(--blood);
    font-size: 14px;
    letter-spacing: 4px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    text-shadow: 0 0 8px var(--blood);
    animation: text-pulse 2s infinite;
}

/* New Eldritch Loading Animation */
.thinking-dots {
    width: 60px;
    height: 60px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.thinking-dots::before, .thinking-dots::after {
    content: '';
    position: absolute;
    border: 2px solid var(--blood);
    border-radius: 50%;
    animation: rune-spin 4s linear infinite;
    box-shadow: 0 0 15px var(--blood);
}

.thinking-dots::before { width: 40px; height: 40px; border-left-color: transparent; border-right-color: transparent; }
.thinking-dots::after { width: 25px; height: 25px; border-top-color: transparent; border-bottom-color: transparent; animation-direction: reverse; animation-duration: 2s; border-color: var(--accent-blue); box-shadow: 0 0 10px var(--accent-blue); }

.thinking-dots span {
    display: none; /* Hide old dots */
}

@keyframes rune-spin {
    0% { transform: rotate(0deg) scale(1); opacity: 0.8; }
    50% { transform: rotate(180deg) scale(1.1); opacity: 1; }
    100% { transform: rotate(360deg) scale(1); opacity: 0.8; }
}

@keyframes text-pulse {
    0%, 100% { opacity: 0.7; letter-spacing: 4px; }
    50% { opacity: 1; letter-spacing: 6px; }
}

/* ═══════════════ INPUT AREA ═══════════════ */
.input-area {
    margin-top: 10px;
    padding: 15px;
    background: rgba(0, 0, 0, 0.6);
    border-top: 2px solid var(--blood-dark);
    position: relative;
}

.input-area::before {
    content: 'USER_TERMINAL_ACCESS';
    position: absolute;
    top: -10px; left: 20px;
    background: var(--void);
    padding: 0 10px;
    color: var(--blood-dark);
    font-size: 10px;
    font-family: monospace;
    letter-spacing: 1px;
}

.input-area textarea {
    width: 100%;
    min-height: 80px;
    padding: 15px;
    background: rgba(10, 10, 15, 0.9);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    color: var(--text);
    font-family: 'Courier New', monospace;
    font-size: 15px;
    transition: all 0.3s;
    box-shadow: inset 0 0 20px rgba(0,0,0,0.8);
}

.input-area textarea:focus {
    border-color: var(--accent-blue);
    box-shadow: 0 0 20px rgba(0, 240, 255, 0.15), inset 0 0 20px rgba(0,0,0,0.8);
    text-shadow: 0 0 2px var(--accent-blue);
}

.input-buttons {
    margin-top: 12px;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

/* ═══════════════ CHARACTER CREATION ═══════════════ */
.char-creation {
    max-width: 1000px;
    margin: 0 auto;
}

.char-creation h2 {
    color: var(--blood);
    font-size: 28px;
    text-align: center;
    margin-bottom: 8px;
    font-weight: 300;
    letter-spacing: 4px;
    text-shadow: 0 0 20px rgba(196, 30, 58, 0.3);
}

.char-creation .subtitle {
    text-align: center;
    color: var(--text-muted);
    margin-bottom: 36px;
    font-weight: 300;
    letter-spacing: 1px;
}

.profession-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
    margin-bottom: 36px;
    max-height: 500px;
    overflow-y: auto;
    padding-right: 8px;
    scroll-behavior: smooth;
}

.profession-card {
    background: var(--surface-light);
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    padding: 18px;
    cursor: pointer;
    transition: all 0.35s;
    position: relative;
    overflow: hidden;
}

.profession-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(196, 30, 58, 0.05), transparent);
    opacity: 0;
    transition: opacity 0.35s;
}

.profession-card:hover {
    border-color: rgba(196, 30, 58, 0.25);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3), 0 0 15px rgba(196, 30, 58, 0.06);
}

.profession-card:hover::before { opacity: 1; }

.profession-card.selected {
    border-color: rgba(196, 30, 58, 0.5);
    box-shadow: 0 0 25px rgba(196, 30, 58, 0.12);
    background: linear-gradient(135deg, rgba(40, 5, 10, 0.5) 0%, var(--surface-light) 100%);
}

.profession-card.custom {
    border-style: dashed;
    border-color: var(--text-muted);
}
.profession-card.custom:hover { border-color: var(--text-dim); }

.profession-name {
    font-size: 17px;
    color: var(--blood);
    margin-bottom: 8px;
    font-weight: 500;
    position: relative;
    z-index: 1;
}

.profession-desc {
    color: var(--text-dim);
    font-size: 13px;
    margin-bottom: 12px;
    line-height: 1.6;
    position: relative;
    z-index: 1;
}

.profession-attrs {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
    position: relative;
    z-index: 1;
}

.attr-badge {
    background: rgba(196, 30, 58, 0.1);
    padding: 3px 8px;
    border-radius: 6px;
    font-size: 11px;
    color: rgba(196, 30, 58, 0.7);
    border: 1px solid rgba(196, 30, 58, 0.15);
}

.profession-items {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    position: relative;
    z-index: 1;
}

.item-tag {
    background: rgba(255, 255, 255, 0.04);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    color: var(--text-dim);
    border: 1px solid var(--glass-border);
}

/* 物品选择 */
.item-selection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 8px;
    padding: 12px;
    background: var(--void);
    border-radius: 10px;
    max-height: 220px;
    overflow-y: auto;
}

.item-option {
    padding: 10px;
    background: var(--surface-light);
    border: 1px solid var(--glass-border);
    border-radius: 8px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 12px;
    color: var(--text-dim);
}

.item-option:hover {
    background: var(--surface-hover);
    border-color: rgba(196, 30, 58, 0.2);
    color: var(--text);
    transform: translateY(-1px);
}

.item-option.selected {
    background: linear-gradient(135deg, rgba(140, 0, 30, 0.3), rgba(80, 0, 15, 0.4));
    border-color: rgba(196, 30, 58, 0.4);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 0 12px rgba(196, 30, 58, 0.15);
}

.item-input {
    padding: 10px 14px;
    background: var(--surface-light);
    border: 1px solid var(--glass-border);
    border-radius: 8px;
    color: var(--text);
    font-size: 13px;
    transition: all 0.3s;
    font-family: inherit;
}
.item-input:focus {
    outline: none;
    border-color: rgba(196, 30, 58, 0.3);
    background: var(--surface-hover);
}
.item-input::placeholder { color: var(--text-muted); }

/* 表单区域 */
.form-section {
    background: var(--surface-light);
    border: 1px solid rgba(196, 30, 58, 0.1);
    border-radius: var(--radius);
    padding: 24px;
    margin-bottom: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.form-section h3 {
    color: var(--blood);
    font-size: 20px;
    margin-bottom: 18px;
    border-bottom: 1px solid rgba(196, 30, 58, 0.1);
    padding-bottom: 10px;
    font-weight: 400;
    letter-spacing: 2px;
}

.form-row {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
}

.form-field { flex: 1; }

.form-field label {
    display: block;
    color: var(--text-dim);
    margin-bottom: 6px;
    font-size: 13px;
}

.form-field input[type="text"],
.form-field input[type="number"],
.form-field textarea {
    width: 100%;
    padding: 10px 14px;
    background: var(--void);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    color: var(--text);
    font-family: inherit;
    font-size: 13px;
    transition: border-color 0.3s;
}

.form-field input:focus,
.form-field textarea:focus {
    outline: none;
    border-color: rgba(196, 30, 58, 0.25);
}

.form-field textarea {
    min-height: 70px;
    resize: vertical;
    line-height: 1.6;
}

/* 性格标签 */
.personality-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.personality-tag {
    padding: 6px 14px;
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.25s;
    font-size: 12px;
    color: var(--text-dim);
}

.personality-tag:hover {
    background: rgba(196, 30, 58, 0.06);
    border-color: rgba(196, 30, 58, 0.15);
    color: var(--text);
}

.personality-tag.selected {
    background: rgba(196, 30, 58, 0.15);
    border-color: var(--blood);
    color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

/* 属性分配 */
.attr-allocation {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.five-attrs {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
    font-size: 11px;
    margin: 8px 0;
}

.five-attrs span {
    background: rgba(0, 0, 0, 0.3);
    padding: 4px;
    text-align: center;
    border-radius: 2px;
    color: var(--text-dim);
    border: 1px solid var(--glass-border);
    font-family: 'Courier New', monospace;
}

.attr-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--void);
    border-radius: 8px;
    border: 1px solid var(--glass-border);
}

.attr-label {
    flex: 0 0 90px;
    color: var(--text);
    font-size: 14px;
}

.attr-controls {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
}

.attr-btn {
    width: 32px;
    height: 32px;
    background: rgba(196, 30, 58, 0.1);
    border: 1px solid rgba(196, 30, 58, 0.2);
    color: var(--blood);
    border-radius: 8px;
    cursor: pointer;
    font-size: 16px;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.attr-btn:hover:not(:disabled) {
    background: rgba(196, 30, 58, 0.2);
    box-shadow: 0 0 10px rgba(196, 30, 58, 0.15);
}

.attr-btn:disabled { opacity: 0.2; cursor: not-allowed; }

.attr-display {
    flex: 1;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.attr-value {
    font-size: 22px;
    color: var(--blood);
    font-weight: 700;
    min-width: 50px;
}

.attr-derived {
    font-size: 12px;
    color: var(--text-muted);
}

.points-display {
    text-align: center;
    font-size: 20px;
    color: var(--blood);
    margin-bottom: 18px;
    padding: 12px;
    background: rgba(196, 30, 58, 0.05);
    border-radius: 8px;
    border: 1px solid rgba(196, 30, 58, 0.1);
    font-weight: 300;
    letter-spacing: 1px;
}

/* ═══════════════ CURSED ITEMS ═══════════════ */
.inventory-item.cursed-item {
    background: linear-gradient(135deg, rgba(20, 0, 25, 0.8), var(--surface-light));
    border: 1px solid rgba(100, 0, 100, 0.25);
    border-radius: 6px;
    padding: 8px 12px;
    margin-bottom: 4px;
    position: relative;
    transition: all 0.3s;
}

.inventory-item.cursed-item:hover {
    border-color: rgba(150, 0, 150, 0.4);
    box-shadow: 0 0 12px rgba(150, 0, 150, 0.15);
}

.inventory-item.cursed-item.tier-1 { border-left: 3px solid #555; }
.inventory-item.cursed-item.tier-2 { border-left: 3px solid #3366cc; }
.inventory-item.cursed-item.tier-3 {
    border-left: 3px solid #9933cc;
    background: linear-gradient(135deg, rgba(25, 0, 35, 0.8), var(--surface-light));
}
.inventory-item.cursed-item.tier-4 {
    border-left: 3px solid #cc3300;
    background: linear-gradient(135deg, rgba(35, 0, 10, 0.8), var(--surface-light));
    animation: pulse-cursed 3s infinite;
}
.inventory-item.cursed-item.tier-5 {
    border-left: 3px solid #ffcc00;
    background: linear-gradient(135deg, rgba(35, 25, 0, 0.8), var(--surface-light));
    animation: pulse-ancient 2s infinite;
    box-shadow: 0 0 12px rgba(255, 204, 0, 0.15);
}

@keyframes pulse-cursed {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.85; }
}

@keyframes pulse-ancient {
    0%, 100% { box-shadow: 0 0 12px rgba(255, 204, 0, 0.15); }
    50% { box-shadow: 0 0 22px rgba(255, 204, 0, 0.35); }
}

.empty-inventory {
    color: var(--text-muted);
    font-style: italic;
    padding: 8px;
    text-align: center;
    font-size: 12px;
}

/* ═══════════════ TIME SKIP ═══════════════ */
.time-skip-container {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--glass-border);
}

.time-skip-btn {
    padding: 7px 14px;
    background: var(--surface-light);
    border: 1px solid var(--glass-border);
    border-radius: 6px;
    color: var(--text-dim);
    cursor: pointer;
    font-size: 11px;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: inherit;
}

.time-skip-btn:hover {
    background: var(--surface-hover);
    border-color: rgba(255, 255, 255, 0.1);
    color: var(--text);
}

.time-skip-btn.danger {
    border-color: rgba(196, 30, 58, 0.2);
    color: var(--blood);
}

.time-skip-btn.danger:hover {
    background: rgba(196, 30, 58, 0.06);
    box-shadow: 0 0 12px rgba(196, 30, 58, 0.08);
}

.time-skip-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.time-skip-btn .icon { font-size: 13px; }

/* 日报 */
.daily-report {
    background: var(--surface-light);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    padding: 18px;
    margin: 16px 0;
}

.daily-report .report-header,
.daily-report .report-footer {
    color: var(--text-muted);
    text-align: center;
    font-size: 10px;
    letter-spacing: 3px;
    text-transform: uppercase;
}

.daily-report .report-time {
    color: var(--text-dim);
    margin: 12px 0;
    font-size: 13px;
}

.daily-report .report-events { margin: 12px 0; color: var(--text-dim); }
.daily-report .report-events ul { margin-left: 18px; margin-top: 6px; }
.daily-report .report-events li { margin: 4px 0; color: var(--text-dim); font-size: 13px; }

.daily-report .report-rumor {
    margin: 8px 0;
    padding: 10px 14px;
    background: rgba(42, 90, 138, 0.06);
    border-left: 3px solid rgba(42, 90, 138, 0.4);
    color: #8ab8d8;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
}

.daily-report .report-omen {
    margin: 8px 0;
    padding: 10px 14px;
    background: rgba(196, 30, 58, 0.06);
    border-left: 3px solid rgba(196, 30, 58, 0.4);
    color: #d88a8a;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
}

.daily-report .report-changes {
    margin-top: 12px;
    padding-top: 10px;
    border-top: 1px dashed var(--glass-border);
    color: var(--text-muted);
    font-size: 12px;
}

/* 时间跳过确认 */
.time-skip-confirm {
    background: var(--surface-light);
    border: 1px solid rgba(196, 30, 58, 0.2);
    border-radius: var(--radius);
    padding: 24px;
    max-width: 400px;
    text-align: center;
}

.time-skip-confirm .warning-icon { font-size: 40px; margin-bottom: 12px; }
.time-skip-confirm .warning-text { color: var(--blood); font-size: 15px; margin-bottom: 18px; }
.time-skip-confirm .confirm-buttons { display: flex; justify-content: center; gap: 12px; }

/* 时间显示 */
.current-time-display {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: var(--glass);
    border-radius: 8px;
    margin-bottom: 12px;
    border: 1px solid var(--glass-border);
}

.time-icon { font-size: 18px; }
.time-info { flex: 1; }
.time-day { color: var(--text-muted); font-size: 11px; }
.time-period { color: var(--text); font-size: 14px; font-weight: 500; }
.time-period.safe { color: #66cc88; }
.time-period.warning { color: #ccaa44; }
.time-period.danger { color: var(--blood); }

/* ═══════════════ SAVE/LOAD ═══════════════ */
.load-menu {
    max-width: 550px;
    margin: 40px auto;
    background: var(--surface-light);
    border: 1px solid rgba(196, 30, 58, 0.1);
    border-radius: 16px;
    padding: 28px;
}

.load-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--glass-border);
}

.load-header h2 { color: var(--blood); margin: 0; font-weight: 400; letter-spacing: 2px; font-size: 18px; }

.back-btn {
    background: var(--glass);
    color: var(--text-dim);
    border: 1px solid var(--glass-border);
    padding: 6px 14px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    font-family: inherit;
    transition: all 0.3s;
}
.back-btn:hover { background: var(--surface-hover); color: var(--text); }

.save-list { max-height: 350px; overflow-y: auto; }

.save-slot {
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    padding: 14px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.save-slot:hover {
    background: rgba(196, 30, 58, 0.04);
    border-color: rgba(196, 30, 58, 0.15);
    transform: translateX(4px);
}

.save-info { color: var(--text); }
.save-name { font-size: 14px; font-weight: 600; color: var(--blood); margin-bottom: 4px; }
.save-details { font-size: 12px; color: var(--text-dim); margin-bottom: 2px; }
.save-time { font-size: 11px; color: var(--text-muted); }

/* 物品使用按钮 */
.inventory-use-btn {
    background: linear-gradient(135deg, rgba(100, 30, 120, 0.4), rgba(70, 20, 90, 0.5));
    color: #c8a0d8;
    border: 1px solid rgba(100, 30, 120, 0.25);
    padding: 5px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 11px;
    margin-top: 4px;
    width: 100%;
    transition: all 0.3s;
    font-family: inherit;
}

.inventory-use-btn:hover {
    box-shadow: 0 0 12px rgba(100, 30, 120, 0.15);
    border-color: rgba(100, 30, 120, 0.4);
}

/* ═══════════════ SETTINGS MODAL ═══════════════ */
.settings-section {
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    padding: 18px;
    margin-bottom: 14px;
}

.settings-section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--blood);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(196, 30, 58, 0.1);
    letter-spacing: 1px;
}

.settings-section-icon {
    font-size: 16px;
}

/* 折叠面板 */
.settings-collapse {
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    margin-bottom: 10px;
    overflow: hidden;
    transition: border-color 0.3s;
}

.settings-collapse[open] {
    border-color: rgba(196, 30, 58, 0.15);
}

.settings-collapse-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 18px;
    cursor: pointer;
    background: var(--glass);
    transition: all 0.3s;
    list-style: none;
    user-select: none;
}

.settings-collapse-header::-webkit-details-marker {
    display: none;
}

.settings-collapse-header:hover {
    background: var(--surface-hover);
}

.settings-collapse-icon {
    font-size: 15px;
}

.settings-collapse-title {
    flex: 1;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-dim);
    letter-spacing: 1px;
}

.settings-collapse[open] .settings-collapse-title {
    color: var(--text);
}

.settings-collapse-arrow {
    color: var(--text-muted);
    font-size: 12px;
    transition: transform 0.3s;
}

.settings-collapse[open] .settings-collapse-arrow {
    transform: rotate(90deg);
    color: var(--blood);
}

.settings-collapse-body {
    padding: 16px 18px;
    border-top: 1px solid var(--glass-border);
    animation: collapse-open 0.3s ease;
}

@keyframes collapse-open {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

.settings-hint {
    font-size: 12px;
    color: var(--text-muted);
    margin-bottom: 12px;
    line-height: 1.6;
}

.settings-toggle-label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-dim);
}

.settings-toggle-label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--blood);
    cursor: pointer;
}

.settings-toggle-label span {
    transition: color 0.2s;
}

.settings-toggle-label:hover span {
    color: var(--text);
}

/* ═══════════════ ANIMATIONS ═══════════════ */
@keyframes fadeInOut {
    0% { opacity: 0; transform: translateY(-10px); }
    10% { opacity: 1; transform: translateY(0); }
    80% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(-10px); }
}

@keyframes worldPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

@keyframes worldLoadBar {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(200%); }
}

/* ═══════════════ CONTAINERS ═══════════════ */
#messageContainer {
    padding-bottom: 6px;
}

/* ═══════════════ LOADING OVERLAY ═══════════════ */
.loading-overlay {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    background: rgba(6, 6, 10, 0.95);
    backdrop-filter: blur(10px);
    z-index: 100;
    pointer-events: all;
    transition: opacity 0.5s ease;
}

.loading-card {
    text-align: center; padding: 48px 40px;
    border: 1px solid var(--blood);
    border-radius: 2px;
    background: rgba(10, 5, 8, 0.95);
    box-shadow: 0 0 60px rgba(196, 30, 58, 0.1), 0 25px 50px rgba(0,0,0,0.8);
    max-width: 380px;
    position: relative;
    overflow: hidden;
}

.loading-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: var(--blood);
    box-shadow: 0 0 15px var(--blood);
}

.loading-title {
    color: var(--blood);
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 8px;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-shadow: 0 0 10px var(--blood-dark);
}

.loading-subtitle {
    color: var(--text-dim);
    font-size: 12px;
    letter-spacing: 1px;
    font-family: monospace;
}

.loading-bar-container {
    margin-top: 24px;
    width: 180px;
    height: 2px;
    background: rgba(255,255,255,0.05);
    border-radius: 1px;
    overflow: hidden;
    margin-left: auto;
    margin-right: auto;
}

.loading-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, transparent, var(--blood), transparent);
    animation: worldLoadBar 2s ease-in-out infinite;
    width: 60%;
}

.loading-error-icon {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(196, 30, 58, 0.1);
    border: 1px solid var(--blood);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    font-size: 22px;
    color: var(--blood);
    box-shadow: 0 0 15px var(--blood-glow);
}

/* ═══════════════ TOAST NOTIFICATIONS ═══════════════ */
.toast-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    background: rgba(10, 5, 8, 0.95);
    color: var(--text);
    padding: 14px 20px;
    border-radius: 2px;
    border: 1px solid var(--glass-border);
    border-left-width: 4px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.8);
    backdrop-filter: blur(5px);
    z-index: 10000;
    font-size: 13px;
    font-family: 'Courier New', monospace;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 12px;
    opacity: 0;
    transform: translateX(50px);
    animation: toast-enter 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards,
               toast-exit 0.4s ease-in 4.6s forwards;
    max-width: 350px;
}

@keyframes toast-enter {
    to { opacity: 1; transform: translateX(0); }
}

@keyframes toast-exit {
    to { opacity: 0; transform: translateX(20px) scale(0.9); pointer-events: none; }
}

.toast-notification.success {
    border-left-color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.15);
}
.toast-notification.success::before {
    content: 'SUCCESS';
    position: absolute;
    top: -8px; left: 10px;
    font-size: 9px;
    background: var(--void);
    padding: 0 4px;
    color: var(--accent-green);
}

.toast-notification.error {
    border-left-color: var(--blood);
    box-shadow: 0 0 15px rgba(255, 15, 57, 0.15);
}
.toast-notification.error::before {
    content: 'ERROR';
    position: absolute;
    top: -8px; left: 10px;
    font-size: 9px;
    background: var(--void);
    padding: 0 4px;
    color: var(--blood);
}

.toast-notification.info {
    border-left-color: var(--accent-blue);
    box-shadow: 0 0 15px rgba(0, 240, 255, 0.15);
}
.toast-notification.info::before {
    content: 'SYSTEM';
    position: absolute;
    top: -8px; left: 10px;
    font-size: 9px;
    background: var(--void);
    padding: 0 4px;
    color: var(--accent-blue);
}
@media (max-width: 900px) {
    .container {
        flex-direction: column;
        padding: 8px;
    }

    .game-area {
        max-height: none;
    }

    .status-panel {
        width: 100%;
        max-height: none;
    }

    .main-menu h1 {
        font-size: 32px;
        letter-spacing: 6px;
    }

    .profession-grid {
        grid-template-columns: 1fr;
    }
}

/* ═══════════════ SAVE/LOAD UI (MODAL) ═══════════════ */
.save-load-ui {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    background: rgba(10, 5, 8, 0.95);
    border: 1px solid var(--blood);
    border-radius: 4px;
    box-shadow: 0 0 50px rgba(196, 30, 58, 0.2), inset 0 0 100px rgba(0, 0, 0, 0.8);
    z-index: 10001;
    display: none;
    flex-direction: column;
    font-family: 'Courier New', monospace;
    backdrop-filter: blur(10px);
}

.save-load-ui::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.save-load-ui.open {
    display: flex;
}

.sl-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    background: rgba(20, 0, 5, 0.5);
    border-bottom: 1px solid var(--blood-dark);
    color: var(--blood);
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-shadow: 0 0 10px var(--blood-dark);
}

.sl-close {
    background: transparent;
    border: 1px solid var(--text-dim);
    color: var(--text-dim);
    font-size: 24px;
    cursor: pointer;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 2px;
    transition: all 0.2s;
}

.sl-close:hover {
    border-color: var(--blood);
    color: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.sl-content {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
    color: var(--text);
}

.sl-section {
    margin-bottom: 24px;
    border-bottom: 1px dashed var(--glass-border);
    padding-bottom: 24px;
}

.sl-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.sl-section h3 {
    margin: 0 0 16px 0;
    font-size: 14px;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-weight: 600;
}

.sl-quick-actions {
    display: flex;
    gap: 12px;
}

.sl-btn {
    padding: 10px 16px;
    border: 1px solid transparent;
    border-radius: 2px;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.sl-btn-primary {
    background: rgba(10, 0, 5, 0.8);
    color: var(--blood);
    border: 1px solid var(--blood);
}

.sl-btn-primary:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 15px var(--blood);
}

.sl-btn-secondary {
    background: transparent;
    color: var(--text-dim);
    border: 1px solid var(--text-muted);
}

.sl-btn-secondary:hover {
    border-color: var(--text);
    color: var(--text);
    background: rgba(255, 255, 255, 0.05);
}

.sl-btn-danger {
    background: rgba(20, 0, 0, 0.8);
    color: #ff3333;
    border: 1px solid #ff3333;
}

.sl-btn-danger:hover {
    background: #ff3333;
    color: #000;
    box-shadow: 0 0 15px #ff3333;
}

.sl-save-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 300px;
    overflow-y: auto;
}

.sl-save-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    transition: all 0.2s;
}

.sl-save-item:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--blood-dark);
}

.sl-save-item.auto-save {
    border-left: 3px solid var(--accent-blue);
}

.sl-save-info {
    flex: 1;
}

.sl-save-name {
    font-weight: 700;
    color: var(--blood);
    margin-bottom: 4px;
    font-size: 14px;
}

.sl-save-meta {
    font-size: 11px;
    color: var(--text-dim);
}

.sl-save-actions {
    display: flex;
    gap: 8px;
}

.sl-btn-small {
    padding: 6px 10px;
    font-size: 11px;
}

.sl-new-save {
    display: flex;
    gap: 12px;
}

.sl-new-save input {
    flex: 1;
    padding: 10px 14px;
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    transition: all 0.3s;
}

.sl-new-save input:focus {
    outline: none;
    border-color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

.sl-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted);
    font-style: italic;
    font-family: 'Courier New', monospace;
}

/* ═══════════════ CHARACTER GRAPH UI ═══════════════ */
.graph-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--blood-dark);
    padding-bottom: 10px;
}

.graph-tab {
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-dim);
    padding: 8px 16px;
    cursor: pointer;
    font-size: 12px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    transition: all 0.2s;
    border-radius: 2px;
}

.graph-tab:hover {
    color: var(--text);
    border-color: var(--text-muted);
}

.graph-tab.active {
    color: var(--blood);
    border-color: var(--blood);
    background: rgba(196, 30, 58, 0.1);
    box-shadow: 0 0 10px rgba(196, 30, 58, 0.1);
}

.graph-container {
    min-height: 300px;
}

.entity-card {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 15px;
    margin-bottom: 15px;
    border-left: 3px solid var(--text-muted);
    transition: all 0.3s;
}

.entity-card:hover {
    transform: translateX(5px);
    background: rgba(255, 255, 255, 0.02);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
}

.entity-card.npc { border-left-color: var(--accent-green); }
.entity-card.threat { border-left-color: var(--blood); }
.entity-card.phenomenon { border-left-color: var(--accent-blue); }
.entity-card.promoted { border-left-color: #ffcc00; background: rgba(255, 204, 0, 0.05); }

.entity-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.entity-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.entity-badge {
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.1);
    text-transform: uppercase;
}

.entity-badge.promoted {
    background: rgba(255, 204, 0, 0.2);
    color: #ffcc00;
    border: 1px solid #ffcc00;
    box-shadow: 0 0 10px rgba(255, 204, 0, 0.2);
}

.entity-info {
    font-size: 12px;
    color: var(--text-dim);
    line-height: 1.6;
    font-family: 'Courier New', monospace;
}

.entity-traits {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 10px;
}

.trait-tag {
    font-size: 10px;
    padding: 2px 6px;
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    color: var(--text-dim);
}

.relation-item {
    display: flex;
    align-items: center;
    padding: 12px;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    margin-bottom: 10px;
}

.relation-nodes {
    display: flex;
    align-items: center;
    gap: 15px;
    flex: 1;
}

.relation-node {
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    font-size: 12px;
    color: var(--text);
}

.relation-line {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--text-muted);
    flex: 1;
}

.relation-type {
    font-size: 10px;
    color: var(--text-dim);
    text-transform: uppercase;
}

.relation-arrow {
    font-size: 12px;
    color: var(--blood);
}

.attitude-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-left: 10px;
    box-shadow: 0 0 5px currentColor;
}

.attitude-positive { background: var(--accent-green); color: var(--accent-green); }
.attitude-neutral { background: #ffcc00; color: #ffcc00; }
.attitude-negative { background: var(--blood); color: var(--blood); }

.notification-area {
    position: fixed;
    top: 80px;
    right: 20px;
    width: 300px;
    z-index: 9999;
    pointer-events: none;
}

.world-notification {
    background: rgba(10, 5, 8, 0.9);
    border-left: 3px solid var(--blood);
    padding: 12px 15px;
    margin-bottom: 10px;
    border-radius: 0 2px 2px 0;
    animation: slideIn 0.3s ease-out;
    box-shadow: 0 4px 15px rgba(0,0,0,0.5);
    backdrop-filter: blur(5px);
    border: 1px solid var(--glass-border);
    border-left-width: 3px;
}

@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

.notification-title {
    font-size: 12px;
    color: var(--blood);
    margin-bottom: 4px;
    font-weight: 700;
    text-transform: uppercase;
}

.notification-message {
    font-size: 12px;
    color: var(--text);
    font-family: 'Courier New', monospace;
}

.empty-state {
    text-align: center;
    padding: 40px;
    color: var(--text-muted);
}

.empty-state-icon {
    font-size: 48px;
    margin-bottom: 15px;
    opacity: 0.5;
    filter: grayscale(100%);
}

/* ═══════════════ CHARACTER GRAPH UI ═══════════════ */
.graph-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--blood-dark);
    padding-bottom: 10px;
}

.graph-tab {
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-dim);
    padding: 8px 16px;
    cursor: pointer;
    font-size: 12px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    transition: all 0.2s;
    border-radius: 2px;
}

.graph-tab:hover {
    color: var(--text);
    border-color: var(--text-muted);
}

.graph-tab.active {
    color: var(--blood);
    border-color: var(--blood);
    background: rgba(196, 30, 58, 0.1);
    box-shadow: 0 0 10px rgba(196, 30, 58, 0.1);
}

.graph-container {
    min-height: 300px;
}

.entity-card {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 15px;
    margin-bottom: 15px;
    border-left: 3px solid var(--text-muted);
    transition: all 0.3s;
}

.entity-card:hover {
    transform: translateX(5px);
    background: rgba(255, 255, 255, 0.02);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
}

.entity-card.npc { border-left-color: var(--accent-green); }
.entity-card.threat { border-left-color: var(--blood); }
.entity-card.phenomenon { border-left-color: var(--accent-blue); }
.entity-card.promoted { border-left-color: #ffcc00; background: rgba(255, 204, 0, 0.05); }

.entity-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.entity-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.entity-badge {
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.1);
    text-transform: uppercase;
}

.entity-badge.promoted {
    background: rgba(255, 204, 0, 0.2);
    color: #ffcc00;
    border: 1px solid #ffcc00;
    box-shadow: 0 0 10px rgba(255, 204, 0, 0.2);
}

.entity-info {
    font-size: 12px;
    color: var(--text-dim);
    line-height: 1.6;
    font-family: 'Courier New', monospace;
}

.entity-traits {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 10px;
}

.trait-tag {
    font-size: 10px;
    padding: 2px 6px;
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    color: var(--text-dim);
}

.relation-item {
    display: flex;
    align-items: center;
    padding: 12px;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    margin-bottom: 10px;
}

.relation-nodes {
    display: flex;
    align-items: center;
    gap: 15px;
    flex: 1;
}

.relation-node {
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    font-size: 12px;
    color: var(--text);
}

.relation-line {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--text-muted);
    flex: 1;
}

.relation-type {
    font-size: 10px;
    color: var(--text-dim);
    text-transform: uppercase;
}

.relation-arrow {
    font-size: 12px;
    color: var(--blood);
}

.attitude-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-left: 10px;
    box-shadow: 0 0 5px currentColor;
}

.attitude-positive { background: var(--accent-green); color: var(--accent-green); }
.attitude-neutral { background: #ffcc00; color: #ffcc00; }
.attitude-negative { background: var(--blood); color: var(--blood); }

.notification-area {
    position: fixed;
    top: 80px;
    right: 20px;
    width: 300px;
    z-index: 9999;
    pointer-events: none;
}

.world-notification {
    background: rgba(10, 5, 8, 0.9);
    border-left: 3px solid var(--blood);
    padding: 12px 15px;
    margin-bottom: 10px;
    border-radius: 0 2px 2px 0;
    animation: slideIn 0.3s ease-out;
    box-shadow: 0 4px 15px rgba(0,0,0,0.5);
    backdrop-filter: blur(5px);
    border: 1px solid var(--glass-border);
    border-left-width: 3px;
}

@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

.notification-title {
    font-size: 12px;
    color: var(--blood);
    margin-bottom: 4px;
    font-weight: 700;
    text-transform: uppercase;
}

.notification-message {
    font-size: 12px;
    color: var(--text);
    font-family: 'Courier New', monospace;
}

/* ══════?Start Menu ══════?*/
.start-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 20000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000; /* Fallback */
}

.start-menu-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle at center, rgba(20, 0, 0, 0.2) 0%, #000 100%),
                linear-gradient(180deg, rgba(0, 0, 0, 0.8) 0%, rgba(20, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0.9) 100%);
    opacity: 0.95;
    z-index: 0;
}

.start-menu::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.05'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 1;
}

.start-menu-content {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: 60px;
    max-width: 600px;
    width: 90%;
    background: rgba(10, 10, 14, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    backdrop-filter: blur(10px);
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.8), inset 0 0 30px rgba(0, 0, 0, 0.5);
    animation: fadeIn 1s ease-out;
}

.start-menu-header {
    margin-bottom: 60px;
}

.game-title {
    font-family: 'Courier New', monospace;
    font-size: 48px;
    color: var(--blood);
    margin: 0 0 15px 0;
    text-shadow: 0 0 15px var(--blood), 0 0 30px var(--blood-dark);
    letter-spacing: 4px;
    text-transform: uppercase;
    animation: glitch-text 4s infinite alternate-reverse;
}

.game-subtitle {
    font-family: 'Courier New', monospace;
    font-size: 14px;
    color: var(--text-dim);
    margin: 0;
    letter-spacing: 3px;
    text-transform: uppercase;
    border-top: 1px solid var(--blood-dark);
    border-bottom: 1px solid var(--blood-dark);
    display: inline-block;
    padding: 5px 20px;
}

.start-menu-buttons {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-bottom: 40px;
}

.start-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    padding: 18px 32px;
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    font-family: 'Courier New', monospace;
    font-size: 18px;
    cursor: pointer;
    transition: all 0.3s;
    min-width: 280px;
    margin: 0 auto;
    text-transform: uppercase;
    letter-spacing: 2px;
    background: rgba(0, 0, 0, 0.5);
    color: var(--text-dim);
    position: relative;
    overflow: hidden;
}

.start-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 15, 57, 0.2), transparent);
    transition: left 0.5s;
}

.start-btn:hover::before {
    left: 100%;
}

.start-btn:hover {
    border-color: var(--blood);
    color: var(--blood);
    text-shadow: 0 0 8px var(--blood);
    background: rgba(20, 5, 5, 0.8);
    box-shadow: 0 0 20px rgba(255, 15, 57, 0.2);
    transform: translateY(-2px);
}

.start-btn-primary {
    border-color: var(--blood);
    color: var(--text);
    background: rgba(139, 0, 0, 0.2);
    box-shadow: 0 0 15px rgba(139, 0, 0, 0.3);
}

.start-btn-primary:hover {
    background: var(--blood);
    color: #000;
    text-shadow: none;
    box-shadow: 0 0 30px var(--blood);
}

.btn-icon {
    font-size: 20px;
}

.start-menu-footer {
    color: var(--text-muted);
    font-size: 11px;
    font-family: 'Courier New', monospace;
    margin-top: 20px;
    opacity: 0.6;
}

/* Load Game Panel - Specifics override generic modal if needed */
.load-game-panel {
    position: absolute; /* Relative to start-menu container if needed, but likely fixed in center */
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    background: rgba(10, 10, 14, 0.95);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.9), 0 0 15px var(--blood-glow);
    z-index: 20001; /* Above start menu content */
    display: flex;
    flex-direction: column;
    backdrop-filter: blur(10px);
}

.load-game-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--glass-border);
    background: rgba(0, 0, 0, 0.5);
}

.load-game-header h2 {
    margin: 0;
    color: var(--blood);
    font-family: 'Courier New', monospace;
    font-size: 20px;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-shadow: 0 0 5px var(--blood);
}

.load-close {
    background: none;
    border: 1px solid transparent;
    color: var(--text-dim);
    font-size: 24px;
    cursor: pointer;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 2px;
    transition: all 0.3s;
}

.load-close:hover {
    color: var(--blood);
    border-color: var(--blood);
    text-shadow: 0 0 5px var(--blood);
}

.load-game-list {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
}

/* Scrollbar for load list */
.load-game-list::-webkit-scrollbar {
    width: 6px;
}
.load-game-list::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.3);
}
.load-game-list::-webkit-scrollbar-thumb {
    background: var(--blood-dark);
    border-radius: 3px;
}

.load-game-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: all 0.2s;
}

.load-game-item:hover {
    background: rgba(20, 5, 5, 0.6);
    border-color: var(--blood);
    transform: translateX(5px);
    box-shadow: -2px 0 10px rgba(255, 15, 57, 0.1);
}

.load-game-item.auto-save {
    border-left: 3px solid var(--accent-blue);
}

.load-game-info {
    flex: 1;
    text-align: left;
}

.load-game-name {
    font-weight: bold;
    color: var(--text);
    margin-bottom: 4px;
    font-family: 'Courier New', monospace;
    font-size: 14px;
}

.load-game-meta {
    font-size: 11px;
    color: var(--text-dim);
    font-family: 'Courier New', monospace;
}

.load-game-actions {
    padding: 20px;
    border-top: 1px solid var(--glass-border);
    text-align: center;
    background: rgba(0, 0, 0, 0.3);
}

.load-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-muted);
    font-style: italic;
    font-family: 'Courier New', monospace;
}


/* ══════?Settings Modal ══════?*/
.settings-header-buttons {
    display: flex;
    gap: 10px;
}

.settings-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 6px;
}

.settings-number-input {
    width: 80px;
    text-align: center;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    color: var(--text);
    border-radius: 2px;
    padding: 6px;
}

.settings-text-muted {
    color: var(--text-muted);
}

.settings-unit {
    color: var(--text-muted);
    font-size: 11px;
    font-family: 'Courier New', monospace;
}

.settings-hint {
    color: var(--text-dim);
    font-size: 12px;
    margin-top: 4px;
    font-style: italic;
}

.settings-btn-full {
    width: 100%;
    margin-top: 10px;
}

.settings-group-spacer {
    margin-top: 15px;
}

.settings-btn-row {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
}

.settings-btn-flex {
    flex: 1;
}

.save-management-container {
    display: none;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px dashed var(--glass-border);
}

.save-management-container.show {
    display: block;
}

/* Enhancements for existing elements */
.settings-collapse {
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    margin-top: 15px;
    overflow: hidden;
}

.settings-collapse-header {
    padding: 12px 15px;
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    color: var(--text);
    transition: all 0.2s;
}

.settings-collapse-header:hover {
    background: rgba(255, 255, 255, 0.08);
    color: var(--blood);
}

.settings-collapse-body {
    padding: 15px;
    border-top: 1px solid var(--glass-border);
}

.settings-toggle-label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    user-select: none;
}

.settings-toggle-label input[type="checkbox"] {
    appearance: none;
    width: 16px;
    height: 16px;
    border: 1px solid var(--text-muted);
    border-radius: 2px;
    background: transparent;
    position: relative;
    cursor: pointer;
}

.settings-toggle-label input[type="checkbox"]:checked {
    background: var(--blood);
    border-color: var(--blood);
    box-shadow: 0 0 5px var(--blood);
}

.settings-toggle-label input[type="checkbox"]:checked::after {
    content: '?;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 10px;
    color: #fff;
}


/* ══════?Item Use System ══════?*/
.item-use-modal {
    max-width: 700px;
    max-height: 80vh;
    overflow-y: auto;
}

.item-inventory {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
    margin-bottom: 20px;
    min-height: 150px;
    padding: 15px;
    background: rgba(0, 0, 0, 0.4);
    border-radius: 4px;
    border: 1px solid var(--glass-border);
}

.empty-inventory {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--text-dim);
    padding: 40px;
    font-style: italic;
    font-family: 'Courier New', monospace;
}

.item-slot {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    padding: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
    position: relative;
}

.item-slot:hover {
    background: rgba(196, 30, 58, 0.1);
    border-color: var(--blood);
    transform: translateY(-2px);
    box-shadow: 0 0 10px var(--blood-glow);
}

.item-slot.selected {
    background: rgba(196, 30, 58, 0.2);
    border-color: var(--blood);
    box-shadow: 0 0 15px var(--blood-glow);
}

.item-slot.corrupted {
    background: rgba(0, 240, 255, 0.1);
    border-color: var(--accent-blue);
}

.item-icon {
    font-size: 24px;
    margin-bottom: 5px;
    display: block;
    filter: drop-shadow(0 0 5px rgba(255,255,255,0.2));
}

.item-name {
    font-size: 12px;
    color: var(--text);
    margin-bottom: 3px;
    font-family: 'Courier New', monospace;
}

.item-quantity {
    font-size: 10px;
    color: var(--text);
    position: absolute;
    top: 5px;
    right: 5px;
    background: rgba(0, 0, 0, 0.8);
    padding: 2px 4px;
    border-radius: 2px;
    border: 1px solid var(--glass-border);
}

.item-description {
    background: rgba(0, 0, 0, 0.4);
    border-radius: 4px;
    padding: 15px;
    border: 1px solid var(--glass-border);
}

.description-placeholder {
    color: var(--text-dim);
    font-style: italic;
    text-align: center;
    padding: 20px;
    font-family: 'Courier New', monospace;
}

.description-content {
    color: var(--text);
}

.description-content h4 {
    color: var(--blood);
    margin-bottom: 10px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.effect-list {
    list-style: none;
    padding: 0;
    margin: 10px 0;
}

.effect-list li {
    padding: 5px 0;
    border-bottom: 1px solid var(--glass-border);
    font-size: 14px;
    font-family: 'Courier New', monospace;
}

.effect-list li:last-child {
    border-bottom: none;
}

.effect-positive {
    color: var(--accent-green);
}

.effect-negative {
    color: var(--blood);
}

.effect-neutral {
    color: var(--accent-blue);
}

.use-button {
    background: rgba(10, 5, 5, 0.8);
    color: var(--blood);
    border: 1px solid var(--blood);
    padding: 10px 20px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 14px;
    margin-top: 15px;
    width: 100%;
    transition: all 0.3s ease;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    letter-spacing: 2px;
}

.use-button:hover {
    background: var(--blood);
    color: #000;
    transform: translateY(-2px);
    box-shadow: 0 0 15px var(--blood-glow);
}

.use-button:disabled {
    background: #333;
    border-color: #555;
    color: #888;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.world-indicator {
    display: inline-block;
    padding: 2px 6px;
    border-radius: 2px;
    font-size: 11px;
    font-weight: bold;
    margin-left: 5px;
    text-transform: uppercase;
}

.world-outer {
    background: rgba(0, 240, 255, 0.2);
    color: var(--accent-blue);
    border: 1px solid var(--accent-blue);
}

.world-inner {
    background: rgba(255, 15, 57, 0.2);
    color: var(--blood);
    border: 1px solid var(--blood);
}


/* ══════?Dice UI ══════?*/
.dice-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(5px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10000;
}

.dice-panel {
    background: rgba(10, 5, 8, 0.95);
    border: 1px solid var(--blood);
    box-shadow: 0 0 30px rgba(196, 30, 58, 0.2), inset 0 0 50px rgba(0, 0, 0, 0.8);
    border-radius: 4px;
    padding: 30px;
    min-width: 320px;
    text-align: center;
    position: relative;
}

.dice-panel::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.dice-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    border-bottom: 1px solid var(--blood-dark);
    padding-bottom: 10px;
}

.dice-title { 
    font-size: 1.4em; 
    color: var(--blood); 
    font-family: 'Courier New', monospace;
    font-weight: 700;
    text-transform: uppercase;
    text-shadow: 0 0 5px var(--blood-dark);
}

.dice-close {
    background: none; border: 1px solid var(--text-dim);
    color: var(--text-dim); font-size: 1.2em; cursor: pointer;
    width: 24px; height: 24px; line-height: 1;
    transition: all 0.2s;
}
.dice-close:hover { 
    color: var(--blood); border-color: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

.dice-d100-display { margin: 30px 0; }

.dice-d100-roll {
    display: inline-flex;
    gap: 12px;
    font-family: 'Courier New', monospace;
}

.dice-d100-roll span {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 80px; height: 100px;
    background: linear-gradient(180deg, #1a1a20 0%, #0a0a0e 100%);
    border: 2px solid var(--glass-border);
    border-radius: 4px;
    font-size: 4em;
    font-weight: bold;
    color: var(--text);
    text-shadow: 0 0 10px rgba(255,255,255,0.1);
    box-shadow: inset 0 0 20px rgba(0,0,0,0.8);
}

.dice-d100-roll.rolling span {
    animation: digitRoll 0.08s linear infinite;
    border-color: var(--blood);
    color: var(--blood-dark);
}

@keyframes digitRoll {
    0%, 100% { transform: translateY(-2px); opacity: 0.7; }
    50% { transform: translateY(2px); opacity: 1; }
}

.dice-d100-roll.critical-success span {
    color: var(--accent-green);
    border-color: var(--accent-green);
    box-shadow: 0 0 30px rgba(0, 255, 157, 0.3);
    text-shadow: 0 0 10px var(--accent-green);
    animation: successGlow 0.5s ease infinite alternate;
}

.dice-d100-roll.critical-failure span {
    color: var(--blood);
    border-color: var(--blood);
    box-shadow: 0 0 30px rgba(255, 15, 57, 0.3);
    text-shadow: 0 0 10px var(--blood);
}

@keyframes successGlow {
    from { box-shadow: 0 0 20px rgba(0, 255, 157, 0.2); }
    to { box-shadow: 0 0 40px rgba(0, 255, 157, 0.5); }
}

.dice-special-result {
    font-size: 1.8em;
    font-weight: bold;
    margin: 20px 0;
    padding: 10px 24px;
    border-radius: 4px;
    display: inline-block;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    letter-spacing: 2px;
}

.dice-special-result.critical-success {
    color: #000;
    background: var(--accent-green);
    box-shadow: 0 0 20px var(--accent-green);
}

.dice-special-result.critical-failure {
    color: #000;
    background: var(--blood);
    box-shadow: 0 0 20px var(--blood);
}

.dice-footer { margin-top: 20px; border-top: 1px dashed var(--glass-border); padding-top: 15px; }
.dice-reason { color: var(--text-dim); font-style: italic; margin-bottom: 8px; font-size: 0.9em; }
.dice-hint { color: var(--text-muted); font-size: 0.8em; letter-spacing: 1px; text-transform: uppercase; }

/* 内联样式 */
.dice-inline-result {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    padding: 6px 12px;
    margin: 4px 0;
    font-size: 0.9em;
    font-family: 'Courier New', monospace;
}
.dice-inline-roll { color: var(--text); font-weight: 700; }
.dice-inline-special { font-weight: 700; text-transform: uppercase; font-size: 0.8em; padding: 2px 6px; border-radius: 2px; }
.dice-inline-special.success { background: rgba(0, 255, 157, 0.1); color: var(--accent-green); border: 1px solid var(--accent-green); }
.dice-inline-special.failure { background: rgba(255, 15, 57, 0.1); color: var(--blood); border: 1px solid var(--blood); }


/* ══════?Choice Options UI ══════?*/
.choice-options-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 16px;
    margin: 16px 0;
    background: rgba(10, 5, 8, 0.85);
    border: 1px solid var(--blood-dark);
    border-radius: 4px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.8), inset 0 0 30px rgba(0, 0, 0, 0.5);
    position: relative;
    overflow: hidden;
}

.choice-options-container::before {
    content: 'AVAILABLE_ACTIONS';
    position: absolute;
    top: 0; left: 0;
    font-size: 9px;
    color: var(--blood);
    padding: 2px 6px;
    background: rgba(0,0,0,0.8);
    border-bottom-right-radius: 4px;
    font-family: monospace;
    letter-spacing: 1px;
}

.choice-option-btn {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding: 14px 16px;
    background: rgba(20, 20, 25, 0.6);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    color: var(--text);
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: left;
    line-height: 1.5;
    min-height: 60px;
    font-family: 'Courier New', monospace;
    position: relative;
    overflow: hidden;
}

.choice-option-btn::before {
    content: '';
    position: absolute;
    top: 0; left: 0; width: 2px; height: 100%;
    background: var(--text-muted);
    transition: background 0.3s;
}

.choice-option-btn:hover {
    background: rgba(30, 30, 40, 0.8);
    border-color: var(--accent-blue);
    color: #fff;
    box-shadow: 0 0 15px rgba(0, 240, 255, 0.15);
    transform: translateX(2px);
}

.choice-option-btn:hover::before {
    background: var(--accent-blue);
    box-shadow: 0 0 10px var(--accent-blue);
}

.choice-option-btn:active {
    transform: translateX(1px) translateY(1px);
}

.choice-option-btn .option-icon {
    font-size: 18px;
    margin-right: 6px;
    text-shadow: 0 0 5px currentColor;
}

.choice-option-btn .option-text {
    flex: 1;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.choice-option-btn .option-requirement {
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 2px;
    margin-top: 6px;
    width: 100%;
    text-transform: uppercase;
    border: 1px solid transparent;
}

.choice-option-btn .requirement-met {
    background: rgba(0, 255, 157, 0.1);
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.3);
}

.choice-option-btn .requirement-not-met {
    background: rgba(255, 15, 57, 0.1);
    color: var(--blood);
    border-color: rgba(255, 15, 57, 0.3);
}

.choice-option-btn.option-risky {
    border-color: rgba(255, 15, 57, 0.3);
}

.choice-option-btn.option-risky:hover {
    border-color: var(--blood);
    box-shadow: 0 0 15px var(--blood-glow);
}

.choice-option-btn.option-risky:hover::before {
    background: var(--blood);
    box-shadow: 0 0 10px var(--blood);
}

/* 移动端适配 */
@media (max-width: 600px) {
    .choice-options-container {
        grid-template-columns: 1fr;
    }
}


/* ══════?Message Editor ══════?*/
.message-editor-textarea {
    width: 100%;
    min-height: 100px;
    margin-bottom: 10px;
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--glass-border);
    color: var(--text);
    padding: 10px;
    border-radius: 2px;
    font-family: inherit;
    resize: vertical;
}

.message-editor-textarea:focus {
    outline: none;
    border-color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

.message-editor-buttons {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}


/* ══════?Evolution / Breakthrough UI ══════?*/
.breakthrough-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 30px;
}

.breakthrough-option {
    border-radius: 12px;
    padding: 20px;
    cursor: pointer;
    transition: all 0.3s;
    border: 2px solid transparent;
}

.breakthrough-option:hover {
    transform: scale(1.02);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.breakthrough-option-sacrifice {
    background: rgba(233, 69, 96, 0.1);
    border-color: var(--blood);
}

.breakthrough-option-fusion {
    background: rgba(74, 158, 255, 0.1);
    border-color: var(--accent-blue);
}

.breakthrough-option h3 {
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: 700;
}

.breakthrough-option-sacrifice h3 {
    color: var(--blood);
}

.breakthrough-option-fusion h3 {
    color: var(--accent-blue);
}

.breakthrough-content p {
    font-size: 14px;
    color: var(--text-dim);
    line-height: 1.5;
    margin-bottom: 8px;
}

.breakthrough-content strong {
    color: var(--text);
    display: block;
    margin-bottom: 4px;
    font-size: 16px;
}

.breakthrough-cost {
    font-size: 12px;
    color: var(--blood);
    font-weight: bold;
    margin-top: 10px;
}

.breakthrough-risk {
    font-size: 12px;
    color: var(--blood);
    font-weight: bold;
    margin-top: 10px;
}

/* Lv5 Form Specifics */
.lv5-form-container {
    text-align: center;
}

.lv5-title {
    color: var(--blood);
    margin-bottom: 20px;
    font-size: 28px;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    text-shadow: 0 0 10px var(--blood);
}

.lv5-description {
    color: var(--text-dim);
    line-height: 1.8;
    white-space: pre-wrap;
    margin-bottom: 30px;
    font-size: 15px;
}

.lv5-btn {
    margin-top: 30px;
    padding: 12px 30px;
    background: var(--blood);
    border: none;
    border-radius: 6px;
    color: #000;
    cursor: pointer;
    font-size: 16px;
    font-weight: bold;
    font-family: 'Courier New', monospace;
    transition: all 0.3s;
}

.lv5-btn:hover {
    box-shadow: 0 0 20px var(--blood-glow);
    transform: scale(1.05);
}


/* ══════?Message Header Actions ══════?*/
.message-header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.regenerate-btn {
    background: transparent;
    border: none;
    color: var(--text-dim);
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s;
    opacity: 0.6;
    padding: 4px;
    border-radius: 2px;
}

.regenerate-btn:hover:not(:disabled) {
    color: var(--accent-blue);
    text-shadow: 0 0 5px var(--accent-blue);
    opacity: 1;
    background: rgba(0, 240, 255, 0.1);
}

.regenerate-btn:disabled {
    cursor: not-allowed;
    opacity: 0.3;
}

/* ══════?Status Display ══════?*/
.unknown-world {
    color: var(--text-muted);
    font-family: 'Courier New', monospace;
    letter-spacing: 2px;
    text-shadow: 0 0 2px rgba(0,0,0,0.5);
}

/* ══════?Message Editor ══════?*/
.edit-btn, .resend-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 14px;
    opacity: 0.5;
    transition: all 0.2s;
    padding: 2px;
}

.edit-btn:hover, .resend-btn:hover {
    opacity: 1;
    transform: scale(1.1);
    filter: drop-shadow(0 0 2px var(--text));
}

.message-actions {
    display: flex;
    gap: 8px;
    margin-left: 10px;
}


/* ══════?NAI Image Generator ══════?*/
.nai-generate-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 16px;
    opacity: 0.7;
    transition: all 0.3s;
}

.nai-generate-btn:hover {
    opacity: 1;
    transform: scale(1.1);
    text-shadow: 0 0 5px var(--accent-blue);
}

.nai-settings-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(10, 5, 8, 0.95);
    border: 1px solid var(--blood);
    border-radius: 4px;
    padding: 20px;
    z-index: 10001;
    min-width: 600px;
    color: var(--text);
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.8), inset 0 0 20px rgba(20, 0, 0, 0.5);
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    backdrop-filter: blur(10px);
}

.nai-panel-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--blood-dark);
}

.nai-panel-header h3 {
    margin: 0;
    color: var(--blood);
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
}

.nai-panel-header button {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    font-size: 18px;
}

.nai-panel-header button:hover {
    color: var(--blood);
}

.nai-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 15px;
}

.nai-tabs button {
    background: transparent;
    border: 1px solid var(--glass-border);
    color: var(--text-dim);
    padding: 6px 16px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 13px;
    font-family: 'Courier New', monospace;
    transition: all 0.3s;
}

.nai-tabs button.active {
    background: rgba(196, 30, 58, 0.2);
    color: var(--blood);
    border-color: var(--blood);
    font-weight: bold;
    box-shadow: 0 0 10px var(--blood-glow);
}

.nai-tabs button:hover:not(.active) {
    border-color: var(--text-muted);
    color: var(--text);
}

.nai-form-group {
    margin-bottom: 10px;
}

.nai-form-group label {
    display: block;
    font-size: 12px;
    color: var(--text-dim);
    margin-bottom: 4px;
    font-family: 'Courier New', monospace;
}

.nai-form-group input,
.nai-form-group textarea {
    width: 100%;
    padding: 8px;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid var(--glass-border);
    color: var(--text);
    border-radius: 2px;
    font-family: inherit;
    box-sizing: border-box;
}

.nai-form-group input:focus,
.nai-form-group textarea:focus {
    border-color: var(--blood);
    outline: none;
    box-shadow: 0 0 5px var(--blood-glow);
}

.nai-lib-area {
    background: rgba(0, 0, 0, 0.3);
    border-radius: 2px;
    padding: 10px;
    max-height: 200px;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--glass-border);
}

.nai-lib-area-footer {
    margin-top: 20px;
    border-top: 1px solid var(--glass-border);
    padding-top: 10px;
}

.nai-lib-scroll {
    overflow-y: auto;
    flex: 1;
    margin-top: 5px;
    padding-right: 5px;
}

.nai-lib-cat {
    margin-bottom: 10px;
}

.nai-lib-cat h4 {
    margin: 0 0 5px 0;
    font-size: 12px;
    color: var(--accent-green);
    font-family: 'Courier New', monospace;
}

.nai-lib-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.nai-tag-pill {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--glass-border);
    padding: 4px 8px;
    border-radius: 2px;
    color: var(--text-dim);
    font-size: 11px;
    cursor: pointer;
    transition: all 0.2s;
}

.nai-tag-pill:hover {
    background: rgba(0, 240, 255, 0.1);
    color: var(--accent-blue);
    border-color: var(--accent-blue);
    transform: translateY(-1px);
}

.nai-char-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(0, 0, 0, 0.4);
    padding: 8px 12px;
    border-radius: 2px;
    margin-bottom: 6px;
    border-left: 3px solid var(--accent-green);
    border: 1px solid var(--glass-border);
    border-left-width: 3px;
}

.nai-char-tags {
    font-size: 11px;
    color: var(--text-dim);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 400px;
}

.nai-save-btn {
    width: 100%;
    padding: 10px;
    background: rgba(10, 5, 5, 0.8);
    color: var(--blood);
    border: 1px solid var(--blood);
    border-radius: 2px;
    cursor: pointer;
    font-weight: bold;
    margin-top: 10px;
    transition: all 0.3s;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
}

.nai-save-btn:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 15px var(--blood-glow);
}

.nai-add-btn {
    background: rgba(0, 255, 157, 0.1) !important;
    color: var(--accent-green) !important;
    border-color: var(--accent-green) !important;
}

.nai-add-btn:hover {
    background: var(--accent-green) !important;
    color: #000 !important;
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.4) !important;
}

/* Modal */
.nai-image-modal {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nai-modal-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(5px);
}

.nai-modal-content {
    position: relative;
    padding: 10px;
    background: rgba(10, 10, 14, 0.8);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.8);
}

.nai-modal-content img {
    max-height: 85vh;
    border-radius: 2px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
    display: block;
}

.nai-modal-actions {
    position: absolute;
    bottom: 20px;
    right: 20px;
    display: flex;
    gap: 10px;
}

.nai-modal-actions button {
    background: rgba(0, 0, 0, 0.6);
    border: 1px solid var(--text-dim);
    color: var(--text);
    width: 32px;
    height: 32px;
    border-radius: 2px;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nai-modal-actions button:hover {
    background: var(--blood);
    border-color: var(--blood);
    color: #000;
}

/* Utility classes for inline replacements */
.nai-remove-char-btn {
    background: none;
    border: none;
    color: var(--blood) !important;
    cursor: pointer;
    font-size: 14px;
}

.nai-small-hint {
    color: var(--text-dim) !important;
    font-size: 12px;
}

.nai-char-input-row {
    display: flex;
    gap: 10px;
    margin-bottom: 5px;
}

.nai-char-list-container {
    margin-top: 15px;
    max-height: 200px;
    overflow-y: auto;
}

.nai-empty-char-list {
    text-align: center;
    color: var(--text-dim) !important;
    padding: 20px;
    font-style: italic;
}


/* ══════?Viewer Components UI ══════?*/
.viewer-modal-overlay {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 10000;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    backdrop-filter: blur(5px);
}

.viewer-modal-content {
    background: rgba(10, 5, 8, 0.95);
    padding: 30px;
    border-radius: 4px;
    max-width: 1000px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.8), inset 0 0 20px rgba(20, 0, 0, 0.5);
    border: 1px solid var(--glass-border);
    color: var(--text);
}

/* Scrollbar for modal content */
.viewer-modal-content::-webkit-scrollbar {
    width: 6px;
}
.viewer-modal-content::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.3);
}
.viewer-modal-content::-webkit-scrollbar-thumb {
    background: var(--blood-dark);
    border-radius: 3px;
}

.viewer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--blood-dark);
    padding-bottom: 10px;
}

.viewer-title {
    color: var(--accent-blue);
    margin: 0;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    text-shadow: 0 0 5px var(--accent-blue);
    font-size: 20px;
}

.viewer-title.matrix {
    color: var(--accent-green);
    text-shadow: 0 0 5px var(--accent-green);
}

.viewer-close-btn {
    padding: 6px 12px;
    background: transparent;
    color: var(--text-dim);
    border: 1px solid var(--text-dim);
    border-radius: 2px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s;
}

.viewer-close-btn:hover {
    border-color: var(--blood);
    color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

.viewer-stats-panel {
    background: rgba(0, 0, 0, 0.3);
    padding: 15px;
    border-radius: 4px;
    margin-bottom: 20px;
    border: 1px solid var(--glass-border);
}

.viewer-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
}

.viewer-stat-item {
    text-align: center;
}

.viewer-stat-value {
    font-size: 24px;
    font-weight: bold;
    font-family: 'Courier New', monospace;
}

.viewer-stat-label {
    font-size: 12px;
    color: var(--text-dim);
    margin-top: 4px;
}

/* Colors for specific stats */
.stat-color-blue { color: var(--accent-blue); text-shadow: 0 0 5px var(--accent-blue); }
.stat-color-purple { color: #bf00ff; text-shadow: 0 0 5px #bf00ff; }
.stat-color-green { color: var(--accent-green); text-shadow: 0 0 5px var(--accent-green); }
.stat-color-yellow { color: #ffcc00; text-shadow: 0 0 5px #ffcc00; }

.viewer-search-input {
    width: 100%;
    padding: 12px;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
    font-size: 14px;
    color: var(--text);
    margin-bottom: 15px;
    font-family: inherit;
}

.viewer-search-input:focus {
    outline: none;
    border-color: var(--accent-blue);
    box-shadow: 0 0 10px rgba(0, 240, 255, 0.3);
}

.viewer-list-container {
    max-height: 500px;
    overflow-y: auto;
    padding-right: 5px;
}

/* Scrollbar for list container */
.viewer-list-container::-webkit-scrollbar {
    width: 4px;
}
.viewer-list-container::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.2);
}
.viewer-list-container::-webkit-scrollbar-thumb {
    background: var(--text-dim);
    border-radius: 2px;
}

.vector-item {
    background: rgba(255, 255, 255, 0.02);
    padding: 15px;
    border-radius: 2px;
    margin-bottom: 10px;
    border: 1px solid var(--glass-border);
    cursor: pointer;
    transition: all 0.3s;
}

.vector-item:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--accent-blue);
    box-shadow: 0 0 15px rgba(0, 240, 255, 0.1);
}

.vector-item-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.vector-turn-info {
    font-weight: bold;
    color: var(--accent-blue);
    font-family: 'Courier New', monospace;
}

.vector-date {
    font-size: 11px;
    color: var(--text-dim);
}

.vector-content-box {
    padding: 10px;
    border-radius: 2px;
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 1.6;
}

.vector-user-box {
    background: rgba(0, 255, 157, 0.05);
    border-left: 2px solid var(--accent-green);
    color: var(--text);
}

.vector-user-label { font-size: 11px; color: var(--text-dim); margin-bottom: 3px; }

.vector-ai-box {
    background: rgba(0, 240, 255, 0.05);
    border-left: 2px solid var(--accent-blue);
    color: var(--text);
}

.vector-ai-label { font-size: 11px; color: var(--text-dim); margin-bottom: 3px; }

.vector-summary-box {
    background: rgba(255, 204, 0, 0.05);
    border: 1px solid rgba(255, 204, 0, 0.2);
    padding: 8px;
    border-radius: 2px;
    font-size: 11px;
    color: #ffcc00;
}

.vector-variables-info {
    margin-top: 8px;
    font-size: 11px;
    color: var(--text-dim);
    font-family: 'Courier New', monospace;
}

.viewer-actions {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--glass-border);
    display: flex;
    gap: 10px;
}

.viewer-action-btn {
    flex: 1;
    padding: 12px;
    border: 1px solid transparent;
    border-radius: 2px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    font-family: 'Courier New', monospace;
    text-transform: uppercase;
    transition: all 0.3s;
}

.btn-export {
    background: rgba(0, 255, 157, 0.1);
    color: var(--accent-green);
    border-color: var(--accent-green);
}

.btn-export:hover {
    background: var(--accent-green);
    color: #000;
    box-shadow: 0 0 15px var(--accent-green);
}

.btn-danger-outline {
    background: rgba(255, 15, 57, 0.1);
    color: var(--blood);
    border-color: var(--blood);
}

.btn-danger-outline:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 15px var(--blood-glow);
}

.btn-test {
    background: rgba(0, 240, 255, 0.1);
    color: var(--accent-blue);
    border-color: var(--accent-blue);
}

.btn-test:hover {
    background: var(--accent-blue);
    color: #000;
    box-shadow: 0 0 15px var(--accent-blue);
}

.btn-rebuild {
    background: rgba(255, 204, 0, 0.1);
    color: #ffcc00;
    border-color: #ffcc00;
}

.btn-rebuild:hover {
    background: #ffcc00;
    color: #000;
    box-shadow: 0 0 15px #ffcc00;
}

/* Detail Modal Specifics */
.detail-meta-box {
    background: rgba(255, 255, 255, 0.05);
    padding: 15px;
    border-radius: 2px;
    margin-bottom: 15px;
    border: 1px solid var(--glass-border);
}

.detail-section-title {
    font-weight: bold;
    color: var(--text-dim);
    margin-bottom: 8px;
    font-size: 12px;
    text-transform: uppercase;
}

/* Matrix Viewer Specifics */
.matrix-layer-item {
    background: rgba(255, 255, 255, 0.02);
    padding: 15px;
    border-radius: 2px;
    margin-bottom: 10px;
    border: 1px solid var(--glass-border);
    cursor: pointer;
    transition: all 0.3s;
}

.matrix-layer-item:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.1);
}

.matrix-empty-state {
    background: rgba(255, 204, 0, 0.05);
    padding: 20px;
    border-radius: 4px;
    text-align: center;
    color: #ffcc00;
    border: 1px dashed #ffcc00;
}

.matrix-empty-title {
    font-size: 18px;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-family: 'Courier New', monospace;
}

.matrix-debug-info {
    margin-top: 15px;
    padding: 15px;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 2px;
    border: 1px solid var(--glass-border);
}

.recent-history-section {
    margin-top: 20px;
}

.recent-history-title {
    color: #bf00ff;
    margin-bottom: 10px;
    font-family: 'Courier New', monospace;
    font-size: 16px;
    font-weight: bold;
}

.recent-history-item {
    background: rgba(191, 0, 255, 0.05);
    padding: 12px;
    border-radius: 2px;
    margin-bottom: 8px;
    border-left: 4px solid #bf00ff;
}


/* ══════?Debug Panel ══════?*/
.debug-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    max-width: 900px;
    height: 70vh;
    background: rgba(10, 5, 8, 0.95);
    border: 1px solid var(--blood);
    border-radius: 4px;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.8), inset 0 0 20px rgba(20, 0, 0, 0.5);
    z-index: 10000;
    display: none;
    flex-direction: column;
    font-family: 'Consolas', 'Monaco', monospace;
    backdrop-filter: blur(10px);
}

.debug-panel.open {
    display: flex;
}

.debug-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: rgba(0, 0, 0, 0.5);
    border-bottom: 1px solid var(--blood-dark);
    color: var(--blood);
    font-size: 14px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.debug-close {
    background: none;
    border: 1px solid transparent;
    color: var(--text-dim);
    font-size: 24px;
    cursor: pointer;
    padding: 0 8px;
    transition: all 0.2s;
}

.debug-close:hover {
    color: var(--blood);
    text-shadow: 0 0 5px var(--blood);
}

.debug-tabs {
    display: flex;
    gap: 4px;
    padding: 8px 12px;
    background: rgba(0, 0, 0, 0.3);
    border-bottom: 1px solid var(--glass-border);
}

.debug-tab {
    padding: 6px 12px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid transparent;
    border-radius: 2px;
    color: var(--text-dim);
    cursor: pointer;
    font-size: 12px;
    transition: all 0.2s;
    font-family: 'Courier New', monospace;
}

.debug-tab:hover {
    background: rgba(255, 255, 255, 0.1);
    color: var(--text);
    border-color: var(--text-muted);
}

.debug-tab.active {
    background: rgba(196, 30, 58, 0.2);
    color: var(--blood);
    border-color: var(--blood);
    box-shadow: 0 0 10px var(--blood-glow);
}

.debug-content {
    flex: 1;
    padding: 16px;
    overflow-y: auto;
    color: var(--text);
    font-size: 12px;
    line-height: 1.6;
}

/* Scrollbar for debug content */
.debug-content::-webkit-scrollbar {
    width: 6px;
}
.debug-content::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.3);
}
.debug-content::-webkit-scrollbar-thumb {
    background: var(--blood-dark);
    border-radius: 3px;
}

.debug-section {
    margin-bottom: 16px;
    padding: 12px;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 2px;
    border-left: 3px solid var(--accent-blue);
    border: 1px solid var(--glass-border);
    border-left-width: 3px;
}

.debug-section-title {
    font-weight: bold;
    color: var(--accent-blue);
    margin-bottom: 8px;
    font-size: 13px;
    text-transform: uppercase;
}

.debug-code {
    background: rgba(0, 0, 0, 0.5);
    padding: 10px;
    border-radius: 2px;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 200px;
    overflow-y: auto;
    font-size: 11px;
    border: 1px solid var(--glass-border);
    color: var(--text-dim);
}

.debug-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 11px;
}

.debug-table th, .debug-table td {
    padding: 8px;
    text-align: left;
    border-bottom: 1px solid var(--glass-border);
}

.debug-table th {
    color: var(--blood);
    font-weight: bold;
    text-transform: uppercase;
}

.debug-stat {
    display: inline-block;
    padding: 4px 10px;
    margin: 4px;
    background: rgba(0, 240, 255, 0.1);
    border: 1px solid var(--accent-blue);
    border-radius: 2px;
    color: var(--accent-blue);
}

.debug-stat-value {
    font-weight: bold;
    color: var(--text);
    margin-left: 5px;
}

.debug-btn {
    padding: 6px 12px;
    background: rgba(10, 5, 5, 0.8);
    border: 1px solid var(--blood);
    border-radius: 2px;
    color: var(--blood);
    cursor: pointer;
    font-size: 11px;
    margin: 4px;
    transition: all 0.2s;
    text-transform: uppercase;
}

.debug-btn:hover {
    background: var(--blood);
    color: #000;
    box-shadow: 0 0 10px var(--blood-glow);
}

.debug-loading {
    text-align: center;
    padding: 40px;
    color: var(--text-dim);
    font-style: italic;
}

/* 调试按钮（右下角?*/
.debug-toggle-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.8);
    border: 1px solid var(--text-dim);
    border-radius: 50%;
    color: var(--text-dim);
    font-size: 18px;
    cursor: pointer;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    z-index: 9999;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.5;
}

.debug-toggle-btn:hover {
    transform: scale(1.1);
    border-color: var(--blood);
    color: var(--blood);
    box-shadow: 0 0 15px var(--blood-glow);
    opacity: 1;
}

.debug-save-btn {
    background: rgba(0, 255, 157, 0.1) !important;
    color: var(--accent-green) !important;
    border: 1px solid var(--accent-green) !important;
    padding: 6px 12px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    margin-right: 10px;
    transition: all 0.2s;
}

.debug-save-btn:hover {
    background: var(--accent-green) !important;
    color: #000 !important;
    box-shadow: 0 0 10px var(--accent-green) !important;
}

.debug-message-item {
    margin: 4px 0;
    padding: 6px;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 2px;
    border: 1px solid var(--glass-border);
}

.debug-message-role {
    font-weight: bold;
    margin-right: 5px;
}

.debug-message-role.user { color: var(--accent-blue); }
.debug-message-role.ai { color: var(--accent-green); }

.debug-time-desc {
    margin-top: 8px;
    padding: 8px;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 2px;
    border: 1px solid var(--glass-border);
}

.debug-light-bar-container {
    margin-top: 8px;
    height: 20px;
    background: #111;
    border-radius: 2px;
    overflow: hidden;
    border: 1px solid var(--glass-border);
}

.debug-light-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #333, #888);
}

.status-ok { color: #4caf50; } .status-error { color: #f44336; }
.modal { display: none; } .modal.show { display: flex; }

/* ══════?Visibility Control ══════?*/
.start-menu {
    display: none !important;
}
.start-menu.active {
    display: flex !important;
}

.load-game-panel {
    display: none !important;
}
.load-game-panel.active {
    display: flex !important;
}

/* Dice UI Visibility */
.dice-overlay {
    display: none !important;
}
.dice-overlay.active {
    display: flex !important;
}

.dice-special-result {
    display: none;
}
.dice-special-result.active {
    display: inline-block !important;
}


/* Viewer Components Refactor */
.viewer-search-container { margin-bottom: 15px; }
.vector-detail-content.scrollable { max-height: 300px; overflow-y: auto; }
.matrix-empty-state-title { font-size: 18px; margin-bottom: 10px; }
.matrix-empty-state-subtitle { font-size: 14px; margin-bottom: 10px; }
.matrix-empty-state-hint { font-size: 13px; margin-bottom: 15px; }
.matrix-empty-state-debug { 
    font-size: 12px; 
    background: rgba(0,0,0,0.2); 
    padding: 10px; 
    border-radius: 4px; 
    margin-top: 10px; 
    text-align: left; 
}
.matrix-action-btn.inline-btn { 
    margin-top: 15px; 
    flex: none; 
    width: auto; 
    display: inline-block; 
}
.hidden { display: none !important; }


/* Character Creation Utilities */
.form-field-margin-top-10 { margin-top: 10px; }
.grid-3-col-gap-5 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; }
.margin-top-15 { margin-top: 15px; }
.points-remaining-text { color: #c41e3a; letter-spacing: 1px; }
.flex-gap-10-margin-top-20 { display: flex; gap: 10px; margin-top: 20px; }
.flex-gap-10-margin-top-30 { display: flex; gap: 10px; margin-top: 30px; }

/* Legend Tracker Utilities */
.legend-card-info-text { font-size: 12px; color: #aaa; margin-bottom: 8px; }
.legend-card-curse-text { margin-bottom: 4px; font-size: 11px; color: #888; }
.legend-card-dormant-info { font-size: 12px; color: #888; }
.legend-card-dormant-warning { color: #e74c3c; font-size: 11px; }
.hiding { animation: fadeOut 0.3s forwards; }

/* Legend Tracker Dynamic Classes */
.legend-card.curse-high { border-left-color: #e74c3c; }
.legend-card.curse-medium { border-left-color: #f39c12; }
.legend-card.curse-low { border-left-color: #9b59b6; }

.legend-badge.curse-high { background: rgba(231, 76, 60, 0.2); color: #e74c3c; }
.legend-badge.curse-medium { background: rgba(243, 156, 18, 0.2); color: #f39c12; }
.legend-badge.curse-low { background: rgba(155, 89, 182, 0.2); color: #9b59b6; }

.legend-fill.curse-high { background: #e74c3c; }
.legend-fill.curse-medium { background: #f39c12; }
.legend-fill.curse-low { background: #9b59b6; }

.legend-badge.urban { background: rgba(155, 89, 182, 0.2); color: #9b59b6; }
.legend-badge.entity { background: rgba(231, 76, 60, 0.2); color: #e74c3c; }
.legend-badge.location { background: rgba(52, 152, 219, 0.2); color: #3498db; }
.legend-badge.rule { background: rgba(241, 196, 15, 0.2); color: #f1c40f; }
.legend-badge.item { background: rgba(26, 188, 156, 0.2); color: #1abc9c; }

.legend-fill.urban { background: #9b59b6; }
.legend-fill.entity { background: #e74c3c; }
.legend-fill.location { background: #3498db; }
.legend-fill.rule { background: #f1c40f; }
.legend-fill.item { background: #1abc9c; }

/* Character Graph UI */
.notification-slide-animation {
    animation: slideIn 0.3s ease-out reverse;
}
@keyframes slideIn {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
@keyframes fadeOut {
    to { opacity: 0; }
}

