.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:16px 12px;z-index:100;overflow-y:auto;overflow-x:hidden}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:8px;border-radius:var(--radius-md);color:var(--text-accent);transition:all .2s}.sidebar-brand:hover{background:var(--bg-hover)}.sidebar-brand-text{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;letter-spacing:.02em}.sidebar-brand:after{content:"";display:none}.sidebar-tabs{display:flex;flex-direction:column;gap:2px;flex:1;padding-top:8px;border-top:1px solid var(--border-light)}.sidebar-tab{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-base);font-weight:500;transition:all .2s ease;position:relative;white-space:nowrap}.sidebar-tab svg{flex-shrink:0}.sidebar-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-tab--active{background:var(--accent-muted);color:var(--text-accent);font-weight:600}.sidebar-tab--active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.sidebar-tab--active:hover{background:var(--accent-muted);color:var(--text-accent)}.sidebar-tab-label{overflow:hidden;text-overflow:ellipsis}.sidebar-bottom{margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:2px}.sidebar-status{display:flex;align-items:center;gap:8px;padding:8px 12px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:background .3s;flex-shrink:0}.status-dot--active{background:var(--success);box-shadow:0 0 6px #27ae6066}.status-label{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:110;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-card);align-items:center;justify-content:center;color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .3s ease;width:240px}.sidebar--open{transform:translate(0)}.mobile-menu-btn{display:flex}.sidebar-brand-text{font-size:var(--text-base)}}.objectives-panel{position:absolute;top:0;right:0;bottom:0;width:320px;max-width:100%;background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:40;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease;pointer-events:none}.objectives-panel--open{transform:translate(0);pointer-events:auto}.objectives-header{display:flex;align-items:center;justify-content:space-between;padding:14px 88px 14px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.objectives-title{display:flex;align-items:center;gap:8px;font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.objectives-title svg{color:var(--text-accent)}.objectives-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;transition:all .15s}.objectives-close:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.objectives-body{flex:1;overflow-y:auto;padding:16px}.objectives-section{margin-bottom:20px}.objectives-section:last-child{margin-bottom:0}.objectives-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.objectives-section-title{font-family:var(--font-heading);font-size:var(--text-sm);font-weight:600;color:var(--text-accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:0}.objectives-add-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--text-muted);background:transparent;border:1px solid var(--border-light);cursor:pointer;transition:all .15s}.objectives-add-btn:hover{color:var(--text-accent);border-color:var(--accent);background:var(--accent-muted)}.objectives-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.objectives-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:var(--text-base);line-height:1.5;color:var(--text-primary);position:relative}.objectives-resolve-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-top:1px;padding:0;background:transparent;border:none;color:var(--text-accent);cursor:pointer;border-radius:50%;transition:all .15s}.objectives-resolve-btn:hover{background:var(--accent-muted)}.objectives-item--resolved .objectives-resolve-btn{color:var(--text-muted)}.objectives-item--resolved{opacity:.5}.objectives-item--resolved .objectives-item-text{text-decoration:line-through;color:var(--text-muted)}.objectives-item-actions{display:flex;gap:2px;margin-left:auto;flex-shrink:0;opacity:0;transition:opacity .15s}.objectives-item:hover .objectives-item-actions{opacity:1}.objectives-action-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-sm);color:var(--text-muted);background:transparent;border:none;cursor:pointer;transition:all .15s}.objectives-action-btn:hover{color:var(--text-accent);background:var(--bg-hover)}.objectives-action-btn--delete:hover{color:var(--danger, #c0392b);background:#c0392b1a}.objectives-action-btn--save{color:var(--success, #27ae60)}.objectives-action-btn--save:hover{background:#27ae601a}.objectives-edit-row{display:flex;flex-direction:column;gap:6px;width:100%}.objectives-add-row{flex-direction:column;gap:6px}.objectives-edit-input{width:100%;resize:vertical;min-height:40px;max-height:120px;font-family:var(--font-body, var(--font-sans));font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;box-sizing:border-box}.objectives-edit-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px var(--accent-muted)}.objectives-edit-input::placeholder{color:var(--text-muted);font-style:italic}.objectives-edit-actions{display:flex;gap:4px;justify-content:flex-end}.objectives-item--thread{flex-direction:column;gap:4px}.objectives-thread-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;color:var(--text-primary);letter-spacing:.01em}.objectives-thread-desc{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary)}.objectives-thread-npc{font-size:var(--text-xs);color:var(--text-muted);font-style:italic}.objectives-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:var(--text-base);font-style:italic}@media(max-width:768px){.objectives-panel{width:100%;z-index:120}.objectives-header{padding-left:60px}.objectives-item-actions{opacity:1}}.chat-panel{display:flex;flex-direction:column;height:100%;min-height:0;position:relative}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 280px 14px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}@media(max-width:768px){.chat-header{padding-left:56px;padding-right:250px}}.chat-header-left{display:flex;align-items:center;gap:16px}.chat-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.scene-bar{display:flex;align-items:center;gap:16px;padding:10px 24px;background:var(--bg-card-alt);border-bottom:1px solid var(--border-light);flex-shrink:0}.scene-bar-item{display:flex;align-items:center;gap:5px;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);text-transform:capitalize}.scene-bar-item svg{color:var(--text-accent)}.scene-bar-mood{margin-left:auto;font-style:italic;color:var(--text-muted);font-weight:400}.session-selector{position:relative}.session-selector-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);transition:all .2s}.session-selector-btn:hover{border-color:var(--accent);color:var(--text-primary)}.session-readonly-badge{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--warning);padding:1px 6px;background:#f39c121f;border-radius:8px}.session-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:50;padding:4px;max-height:260px;overflow-y:auto}.session-dropdown-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text-secondary);transition:all .15s}.session-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.session-dropdown-item--active{background:var(--accent-muted);color:var(--text-accent);font-weight:500}.session-current-tag{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;color:var(--success)}.session-dropdown-divider{height:1px;background:var(--border-light);margin:4px 8px}.session-dropdown-new{display:flex;align-items:center;gap:6px;color:var(--text-accent);font-weight:500}.chat-readonly-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 24px;background:#f39c1214;border-top:1px solid rgba(243,156,18,.2);font-size:var(--text-base);color:var(--warning);flex-shrink:0}.chat-stopped-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-secondary);margin-bottom:16px}.chat-messages{flex:1;overflow-y:auto;min-height:0;padding:24px}.chat-messages-inner{max-width:min(80%,900px);margin:0 auto;display:flex;flex-direction:column;gap:16px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 20px;text-align:center}.chat-empty-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-muted);color:var(--text-accent);margin-bottom:4px}.chat-empty-icon--pulse{animation:pulse 2s ease-in-out infinite}.chat-empty-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.chat-empty-text{font-size:var(--text-base);color:var(--text-muted);max-width:320px;line-height:1.6}.chat-empty-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:8px}.load-more-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 16px;margin-bottom:16px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:8px;color:var(--text-secondary);font-size:var(--text-sm);font-family:var(--font-body);cursor:pointer;transition:background .15s,color .15s}.load-more-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.load-more-count{opacity:.6;font-size:.85em}.chat-message{display:flex;gap:10px;animation:fadeIn .3s ease}.chat-message--gm{flex-direction:row;align-items:flex-start}.chat-message--player{flex-direction:row-reverse;align-items:flex-start}.message-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.message-avatar--gm{background:var(--accent-muted);color:var(--text-accent);border:1px solid var(--border-light)}.message-avatar--player{background:var(--accent);color:var(--text-on-accent)}.message-avatar--thinking{animation:pulse 2s ease-in-out infinite}.message-content{display:flex;flex-direction:column;min-width:0;max-width:calc(100% - 42px)}.chat-message--gm .message-content{align-items:flex-start}.chat-message--player .message-content{align-items:flex-end}.gm-bubble{max-width:85%;background:var(--bg-card);border:1px solid var(--border-light);border-left:3px solid var(--accent);border-radius:var(--radius-md);border-top-left-radius:2px;border-bottom-left-radius:2px;padding:16px 20px;font-size:var(--text-gm);line-height:var(--line-height-gm);color:var(--text-primary)}.gm-bubble p{margin-bottom:10px}.gm-bubble p:last-child{margin-bottom:0}.gm-bubble em{color:var(--text-secondary)}.gm-bubble strong{color:var(--text-accent);font-weight:600}.gm-bubble blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:12px 0;color:var(--text-secondary);font-style:italic;line-height:1.7}.gm-bubble h1,.gm-bubble h2,.gm-bubble h3{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;margin:14px 0 6px;color:var(--text-accent);letter-spacing:.02em}.gm-bubble h1:first-child,.gm-bubble h2:first-child,.gm-bubble h3:first-child{margin-top:0}.gm-bubble ul,.gm-bubble ol{padding-left:20px;margin:8px 0}.gm-bubble li{margin-bottom:4px}.gm-bubble hr{border:none;border-top:1px solid var(--border-light);margin:16px 0}.gm-bubble code{font-size:var(--text-base);padding:2px 6px;background:var(--bg-secondary);border-radius:3px}.player-bubble{max-width:75%;background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius-md);border-top-right-radius:4px;padding:10px 16px;font-size:var(--text-gm);line-height:var(--line-height-gm)}.player-bubble p{margin-bottom:10px}.player-bubble p:last-child{margin-bottom:0}.message-actions{display:flex;gap:4px;margin-top:4px}.message-actions--right{align-self:flex-end}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:var(--text-xs);font-weight:500;color:var(--text-muted);border-radius:var(--radius-sm);background:transparent;opacity:0;transition:all .15s}.chat-message:hover .action-btn{opacity:.5}.action-btn:hover{opacity:1!important;color:var(--text-accent);background:var(--bg-hover)}.action-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.action-confirm-text{font-size:var(--text-sm);color:var(--warning)}.edit-mode{padding:12px 16px}.edit-textarea{width:100%;min-height:100px;max-height:300px;resize:vertical;font-family:var(--font-sans);font-size:var(--text-gm);line-height:var(--line-height-gm);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 12px;box-sizing:border-box}.edit-textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-muted)}.edit-actions{display:flex;align-items:center;gap:8px;margin-top:10px}.edit-warning{font-size:var(--text-sm);color:var(--warning);margin-left:auto}.thinking-indicator{display:flex;gap:6px;padding:4px 0}.thinking-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dotBounce 1.4s infinite ease-in-out both}.thinking-dot:nth-child(1){animation-delay:-.32s}.thinking-dot:nth-child(2){animation-delay:-.16s}.scroll-to-bottom-btn{position:absolute;bottom:90px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);transition:all .2s;z-index:10}.scroll-to-bottom-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.scroll-to-bottom-dot{position:absolute;top:-2px;right:-2px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-card)}.chat-input-bar{padding:12px 24px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.chat-input-container{max-width:min(80%,900px);margin:0 auto;display:flex;align-items:flex-end;gap:8px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px 4px 4px 16px;transition:border-color .2s,box-shadow .2s}.chat-input-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.chat-input{flex:1;border:none;background:transparent;padding:8px 0;font-size:var(--text-input);line-height:1.5;resize:none;min-height:24px;max-height:160px;overflow-y:auto}.chat-input:focus{border-color:transparent;outline:none}.chat-send-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent);color:var(--text-on-accent);transition:all .2s;flex-shrink:0}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-sm)}.chat-send-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.chat-header{padding:12px 84px 12px 56px}.chat-messages{padding:10px}.chat-messages-inner{max-width:100%}.chat-input-bar{padding:8px 10px 12px}.chat-input-container{max-width:100%}.gm-bubble{max-width:95%;padding:10px 14px}.player-bubble{max-width:88%;padding:8px 14px}.scene-bar{padding:8px 12px;gap:10px;flex-wrap:wrap}.session-dropdown{right:0;left:auto}.chat-empty{padding:48px 12px}.chat-empty-title{font-size:var(--text-heading)}.message-avatar{width:26px;height:26px}.message-content{max-width:calc(100% - 34px)}.chat-message{gap:6px}.chat-message--gm .gm-bubble{border-left-width:2px}}.panel{height:100%;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 240px 14px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.panel-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.panel-header-actions{display:flex;gap:4px}.panel-body{flex:1;overflow-y:auto;padding:24px;min-height:0}.panel-body-inner{max-width:860px;margin:0 auto}.panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 20px;text-align:center}.panel-empty-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-muted);color:var(--text-accent);margin-bottom:4px;box-shadow:0 0 40px var(--accent-muted)}.panel-empty-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.panel-empty-text{font-size:var(--text-base);color:var(--text-muted);max-width:320px;line-height:1.6}.section-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}.char-card{display:flex;gap:20px;padding:20px;background:var(--bg-card);border:1px solid var(--border-light);border-top:3px solid var(--accent);border-radius:var(--radius-lg);margin-bottom:20px}.char-card-portrait{width:160px;min-height:200px;background:linear-gradient(160deg,var(--bg-image-placeholder),var(--accent-muted));border-radius:var(--radius-md);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--accent-light);flex-shrink:0;align-self:flex-start}.char-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.char-card-name{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em;margin-bottom:2px}.char-card-meta{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:4px}.char-card-aliases{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.char-card-alias{font-size:var(--text-sm);color:var(--text-accent);font-style:italic}.char-card-about-wrapper{position:relative;margin-bottom:12px}.char-card-about{font-size:var(--text-base);color:var(--text-primary);line-height:1.6;max-height:7.8em;overflow:hidden;margin:0}.char-card-about--expanded{max-height:none}.char-card-about:not(.char-card-about--expanded){-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%);mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.char-card-about-more{display:inline;background:none;border:none;padding:0;margin-top:4px;font-size:var(--text-sm);color:var(--text-accent);cursor:pointer;font-style:italic}.char-card-about-more:hover{text-decoration:underline}.char-card-actions{display:flex;gap:8px;margin-top:auto}.char-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}.char-section{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden}.char-section-header{display:flex;align-items:center;gap:4px;padding:10px 14px;background:var(--bg-card-alt)}.char-section-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;padding:0;cursor:pointer;font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent);flex:1;text-align:left}.char-section-toggle:hover{color:var(--text-primary)}.char-section-toggle--static{cursor:default}.char-section-toggle--static:hover{color:var(--text-accent)}.char-section-toggle svg{color:var(--text-muted);flex-shrink:0}.char-section-edit{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s}.char-section-edit:hover{color:var(--text-primary);background:var(--bg-secondary)}.char-section-edit--save{color:var(--text-accent)}.char-section-edit-actions{display:flex;gap:2px}.char-section-count{font-size:var(--text-sm);color:var(--text-muted);font-weight:400;margin-left:auto}.char-section-body{padding:14px}.char-backstory-text{font-size:var(--text-base);line-height:1.7;color:var(--text-primary);white-space:pre-wrap;margin:0}.char-backstory-editor{width:100%;min-height:200px;padding:10px;font-family:inherit;font-size:var(--text-base);line-height:1.7;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);resize:vertical}.char-inventory-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.char-inventory-item{padding:8px 10px;font-size:var(--text-base);color:var(--text-primary);line-height:1.4;border-bottom:1px solid var(--border-light)}.char-inventory-item:last-child{border-bottom:none}.char-muted{color:var(--text-muted);font-style:italic;font-size:var(--text-base)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.tag{display:inline-block;padding:4px 12px;background:var(--accent-muted);color:var(--text-accent);border-radius:20px;font-size:var(--text-base);font-weight:500}@media(max-width:900px){.char-grid{grid-template-columns:1fr}}@media(max-width:768px){.panel-header{padding-left:56px;padding-right:220px}.panel-body{padding:16px}.char-card{flex-direction:column;align-items:center;text-align:center}.char-card-portrait{width:120px;min-height:150px}.char-card-aliases,.char-card-actions{justify-content:center}}.npc-location-group{margin-bottom:20px}.npc-group-header{display:flex;align-items:center;gap:6px;width:100%;padding:6px 4px;margin-bottom:8px;background:none;border:none;cursor:pointer;font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent);transition:color .15s}.npc-group-header:hover{color:var(--text-primary)}.npc-group-chevron{color:var(--text-muted);flex-shrink:0}.npc-group-name{flex:1;text-align:left}.npc-group-count{font-size:var(--text-sm);color:var(--text-muted);font-weight:400;letter-spacing:normal;text-transform:none}.npc-list{display:flex;flex-direction:column;gap:6px}.npc-item{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 14px;text-align:left;background:var(--bg-card-alt);border:1px solid var(--border-light);border-left:3px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .15s}.npc-item:hover{background:var(--bg-hover)}.npc-item--friendly{border-left-color:#27ae60}.npc-item--hostile{border-left-color:#c0392b}.npc-item--wary,.npc-item--suspicious{border-left-color:#f39c12}.npc-item--fearful{border-left-color:#9b59b6}.npc-item--curious{border-left-color:#3498db}.npc-item--indifferent{border-left-color:var(--text-muted)}.npc-item--neutral{border-left-color:var(--accent)}.npc-item-header{display:flex;align-items:center;gap:8px}.npc-item-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary);flex:1}.npc-item-dead{font-size:10px;color:#c0392b;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.npc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.npc-dot--friendly{background:#27ae60}.npc-dot--hostile{background:#c0392b}.npc-dot--wary,.npc-dot--suspicious{background:#f39c12}.npc-dot--fearful{background:#9b59b6}.npc-dot--curious{background:#3498db}.npc-dot--indifferent{background:var(--text-muted)}.npc-dot--neutral{background:var(--accent)}.npc-item-role{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.editable-section{background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;transition:border-color .2s}.editable-section:hover{border-color:var(--border-color)}.editable-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.editable-section-title{font-family:var(--font-heading);font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent)}.editable-section-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);transition:all .2s}.editable-section-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.editable-section-btn--save{color:var(--success)}.editable-section-actions{display:flex;gap:2px}.editable-section-content{font-size:var(--text-gm);line-height:1.7;color:var(--text-primary);white-space:pre-wrap}.editable-section-placeholder{color:var(--text-muted);font-style:italic}.editable-section-input{width:100%;font-family:var(--font-sans);font-size:var(--text-gm);line-height:1.7;min-height:100px}.npc-detail-header-left{display:flex;align-items:center;gap:8px}.npc-meta-card{display:flex;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:24px}.npc-meta-avatar{width:80px;height:100px;background:linear-gradient(160deg,var(--bg-image-placeholder),var(--accent-muted));border-radius:var(--radius-md);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--accent-light);flex-shrink:0}.npc-meta-info{flex:1;min-width:0}.npc-meta-name{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);margin-bottom:2px}.npc-meta-role{font-size:var(--text-base);color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.npc-meta-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.npc-meta-location{display:flex;align-items:center;gap:4px;font-size:var(--text-sm);color:var(--text-muted)}.npc-meta-dead{font-size:10px;color:#c0392b;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.npc-meta-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.npc-disposition{display:inline-block;padding:2px 8px;border-radius:10px;font-size:var(--text-xs);font-weight:500;text-transform:capitalize}.npc-disposition--friendly{background:#27ae601a;color:#27ae60}.npc-disposition--neutral{background:var(--accent-muted);color:var(--text-accent)}.npc-disposition--hostile{background:#c0392b1a;color:#c0392b}.npc-disposition--wary,.npc-disposition--suspicious{background:#f39c121a;color:#f39c12}.npc-disposition--fearful{background:#9b59b61a;color:#9b59b6}.npc-disposition--curious{background:#3498db1a;color:#3498db}.npc-disposition--indifferent{background:var(--bg-secondary);color:var(--text-muted)}.npc-sections{display:flex;flex-direction:column;gap:16px}.npc-interaction{padding:8px 0;border-bottom:1px solid var(--border-light)}.npc-interaction:last-child{border-bottom:none;padding-bottom:0}.npc-interaction-session{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-accent);display:block;margin-bottom:4px}.npc-interaction p{font-size:var(--text-base);color:var(--text-primary);line-height:1.5}.spoiler-hidden{color:var(--text-muted);padding:4px 0}@media(max-width:768px){.npc-meta-card{flex-direction:column;align-items:center;text-align:center}.npc-meta-avatar{width:60px;height:75px}.npc-meta-actions{flex-direction:row;justify-content:center}.npc-meta-tags{justify-content:center}}.journal-scene-bar{display:flex;flex-wrap:wrap;align-items:center;gap:6px 16px;padding:10px 16px;margin-bottom:24px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.journal-scene-bar-item{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-primary);text-transform:capitalize;white-space:nowrap}.journal-scene-bar-item svg{color:var(--text-muted);flex-shrink:0}.journal-scene-sub{color:var(--text-secondary);font-weight:400}.journal-threads{margin-bottom:24px}.thread-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.thread-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:var(--text-base)}.thread-item svg{color:var(--text-accent);flex-shrink:0;margin-top:2px}.thread-item-content{display:flex;flex-direction:column;gap:3px}.thread-item-title{font-weight:500;color:var(--text-primary)}.thread-item-desc{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.journal-moments{margin-bottom:24px}.moments-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.moment-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.moment-item svg{color:var(--text-accent);flex-shrink:0;margin-top:2px}.moment-item-content{display:flex;flex-direction:column;gap:4px}.moment-item-text{font-size:var(--text-base);color:var(--text-primary);line-height:1.6}.moment-item-session{font-size:var(--text-sm);color:var(--text-muted)}.journal-events{margin-bottom:24px}.events-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.event-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.event-item svg{color:var(--text-accent);flex-shrink:0;margin-top:2px}.event-item-content{display:flex;flex-direction:column;gap:4px}.event-item-title{font-weight:500;color:var(--text-primary)}.event-item-desc{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.event-item-meta{font-size:var(--text-sm);color:var(--text-muted)}.event-status-resolved,.event-status-missed{opacity:.5}.journal-summary{margin-bottom:24px}.journal-summary-content{margin-top:10px;padding:16px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-gm);line-height:1.75;color:var(--text-primary)}.journal-summary-content h1,.journal-summary-content h2,.journal-summary-content h3{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent);margin:16px 0 8px}.journal-summary-content h1:first-child,.journal-summary-content h2:first-child,.journal-summary-content h3:first-child{margin-top:0}.journal-summary-content p{margin-bottom:12px}.journal-summary-content p:last-child{margin-bottom:0}.journal-meta{display:flex;gap:16px;padding-top:16px;border-top:1px solid var(--border-color)}.journal-meta-item{font-size:var(--text-sm);color:var(--text-muted);text-transform:capitalize}.world-overview{margin-bottom:24px;padding:16px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md)}.world-overview .section-title{display:flex;align-items:center;gap:8px}.world-meta{font-size:var(--text-base);color:var(--text-secondary);margin-top:4px;text-transform:capitalize}.world-meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.world-meta-tag{font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-secondary);padding:2px 10px;border-radius:12px;text-transform:capitalize}.world-description{font-size:var(--text-base);color:var(--text-primary);margin-top:8px;line-height:1.6}.world-section{margin-bottom:24px}.world-section .section-title{display:flex;align-items:center;gap:8px;margin-bottom:10px}.world-list{display:flex;flex-direction:column;gap:8px}.world-item{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden}.world-item-header{display:flex;align-items:center;gap:8px;width:100%;padding:12px 14px;text-align:left;background:var(--bg-card-alt);transition:background .2s}.world-item-header:hover{background:var(--bg-hover)}.world-item-name{flex:1;font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.world-item-meta{font-size:var(--text-sm);color:var(--text-muted);text-transform:capitalize}.world-chevron{color:var(--text-muted);transition:transform .2s;flex-shrink:0}.world-chevron--open{transform:rotate(90deg)}.world-item-body{padding:14px;border-top:1px solid var(--border-light);background:var(--bg-card);display:flex;flex-direction:column;gap:12px;font-size:var(--text-base);line-height:1.6;color:var(--text-primary);animation:fadeIn .2s ease}.world-item-field{display:flex;flex-direction:column;gap:4px}.world-item-field p{font-size:var(--text-base);color:var(--text-primary)}.place-tree{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-card-alt);position:relative}.place-tree:before{content:"";position:absolute;top:0;left:0;bottom:0;width:1px;background:transparent}.place-node{display:flex;align-items:center;gap:4px;padding-top:6px;padding-bottom:6px;padding-right:12px;border-bottom:1px solid var(--border-light);transition:background .15s ease;position:relative}.place-node:last-child{border-bottom:none}.place-node:hover{background:var(--bg-hover)}.place-node--current{background:color-mix(in srgb,var(--accent) 12%,transparent);border-left:3px solid var(--accent)}.place-node--current:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}.place-node:after{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:transparent}.place-node-toggle{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;border-radius:3px;transition:color .15s,background .15s}.place-node-toggle:hover{color:var(--text-primary);background:var(--bg-secondary)}.place-node-icon{display:flex;align-items:center;color:var(--text-muted);flex-shrink:0}.place-node-name{flex:1;text-align:left;font-size:var(--text-base);font-weight:500;color:var(--text-primary);background:none;border:none;padding:2px 4px;cursor:pointer;border-radius:3px;transition:color .15s,background .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.place-node-name:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.place-node--current .place-node-name{color:var(--accent);font-weight:600}.place-node-type{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:1px 6px;background:var(--bg-secondary);border-radius:8px;flex-shrink:0;font-weight:500}.place-node-visited{display:flex;align-items:center;color:var(--accent);flex-shrink:0}.place-node-count{font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0}.place-detail{padding:12px 14px;margin-right:12px;margin-top:2px;margin-bottom:6px;background:var(--bg-card);border:1px solid var(--border-light);border-left:3px solid color-mix(in srgb,var(--accent) 50%,transparent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;display:flex;flex-direction:column;gap:10px;font-size:var(--text-base);line-height:1.6;color:var(--text-primary);animation:placeDetailIn .2s ease}@keyframes placeDetailIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.place-detail-desc{color:var(--text-primary);line-height:1.6}.place-detail-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:4px}.place-detail-list li{color:var(--text-primary);line-height:1.5}.place-breadcrumb{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:2px;font-style:italic}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:200;animation:fadeInOverlay .15s ease}.settings-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(90vw,420px);max-height:90vh;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:210;animation:modalFadeIn .2s ease;overflow:hidden}@media(max-width:600px){.settings-modal{width:94vw;max-height:92vh}}@keyframes modalFadeIn{0%{opacity:0;transform:translate(-50%,-50%) translateY(8px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}.settings-modal-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.settings-modal-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.settings-modal-body{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;display:flex;flex-direction:column;gap:20px}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-label{font-size:var(--text-base);font-weight:500;color:var(--text-secondary);display:flex;align-items:center}.theme-picker{display:flex;gap:8px}.theme-option{display:flex;align-items:center;gap:8px;padding:10px 20px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;color:var(--text-secondary);transition:all .2s}.theme-option:hover{background:var(--bg-hover);color:var(--text-primary)}.theme-option--active{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.theme-option--active:hover{background:var(--accent-hover)}.text-size-picker{display:flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.text-size-option{flex:1;padding:8px 16px;font-size:var(--text-base);font-weight:500;color:var(--text-secondary);background:var(--bg-input);border-right:1px solid var(--border-color);transition:all .2s;text-align:center}.text-size-option:last-child{border-right:none}.text-size-option:hover{background:var(--bg-hover);color:var(--text-primary)}.text-size-option--active{background:var(--accent);color:var(--text-on-accent)}.text-size-option--active:hover{background:var(--accent-hover)}.status-text{font-weight:600;text-transform:capitalize}.status-text--running{color:var(--success)}.status-text--stopped{color:var(--text-muted)}.settings-textarea{width:100%;resize:vertical;min-height:88px;padding:10px 12px;font-family:inherit;font-size:var(--text-base);line-height:1.4;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s}.settings-textarea::placeholder{color:var(--text-muted)}.settings-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 20%,transparent)}.settings-style-actions{display:flex;gap:8px;margin-top:8px}.settings-hint code{font-family:var(--font-mono, ui-monospace, monospace);font-size:.92em;padding:0 3px;background:var(--bg-hover);border-radius:3px}.settings-hint{margin:6px 2px 0;font-size:var(--text-sm);color:var(--text-muted);line-height:1.4}.settings-about{font-size:var(--text-base);color:var(--text-muted);line-height:1.6}.settings-logout-btn{width:100%;justify-content:center}.backend-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px 6px;background:var(--bg-surface-2, rgba(0, 0, 0, .05));border:1px solid var(--border);border-radius:999px}[data-theme=dark] .backend-toggle{background:#ffffff0a}.backend-dot{width:12px;height:12px;padding:0;border-radius:50%;border:1.5px solid currentColor;background:transparent;cursor:pointer;opacity:.45;transition:opacity .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease}.backend-dot--claude{color:#c97a2a}.backend-dot--deepseek{color:#2a7ac9}.backend-dot:hover{opacity:.85}.backend-dot--active{opacity:1;background:currentColor;box-shadow:0 0 6px currentColor}.home-screen{height:100dvh;width:100%;overflow-y:auto;display:flex;justify-content:center;background:radial-gradient(ellipse at top center,var(--accent-muted) 0%,var(--bg-primary) 50%);padding:48px 24px}.home-top-actions{position:fixed;top:16px;right:16px;display:flex;align-items:center;gap:10px;z-index:10}.home-settings-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s}.home-settings-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.home-screen-inner{width:100%;max-width:520px;display:flex;flex-direction:column;gap:32px;animation:slideUp .5s ease}.home-brand{text-align:center;padding:32px 0 8px}.home-brand-ornament{display:flex;align-items:center;justify-content:center;gap:12px;margin:12px 0}.home-brand-line{height:1px;width:60px;background:linear-gradient(90deg,transparent,var(--accent-light),transparent)}.home-brand-diamond{width:6px;height:6px;background:var(--accent-light);transform:rotate(45deg);flex-shrink:0}.home-brand-title{font-family:var(--font-heading);font-size:36px;font-weight:600;color:var(--text-primary);letter-spacing:.08em;text-shadow:0 0 40px var(--accent-muted)}.home-brand-tagline{font-size:var(--text-gm);color:var(--text-muted);margin-top:4px;letter-spacing:.02em}.home-active-game{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--accent-muted);border:1px solid var(--accent);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s}.home-active-game:hover{box-shadow:var(--shadow-glow)}.home-active-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent)}.home-active-name{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);margin-top:2px}.home-active-meta{display:flex;align-items:center;gap:6px;font-size:var(--text-base);color:var(--text-secondary);margin-top:4px;text-transform:capitalize}.home-meta-sep{color:var(--text-muted)}.home-active-actions{flex-shrink:0}.home-section{display:flex;flex-direction:column;gap:12px}.home-section-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.home-new-game{display:flex;gap:8px}.home-new-input{flex:1;padding:10px 16px;font-size:var(--text-input);border-radius:var(--radius-md)}.home-games-list{display:flex;flex-direction:column;gap:8px}.home-game-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all .2s;cursor:pointer}.home-game-card:hover{border-color:var(--border-color);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.home-game-card--active{border-color:var(--accent);background:var(--accent-muted);box-shadow:var(--shadow-glow)}.home-game-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-image-placeholder);border-radius:var(--radius-sm);color:var(--accent-light);flex-shrink:0}.home-game-info{flex:1;min-width:0}.home-game-name{font-size:var(--text-gm);font-weight:600;color:var(--text-primary)}.home-game-meta{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-muted);margin-top:2px;text-transform:capitalize}.home-game-date{display:flex;align-items:center;gap:3px}.home-game-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.home-game-active-badge{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-accent);padding:4px 10px;background:var(--accent-muted);border-radius:10px}.home-game-loading{font-size:var(--text-sm);color:var(--text-muted);font-style:italic}@media(max-width:768px){.home-screen{padding:32px 16px}.home-brand-title{font-size:28px}.home-active-game{flex-direction:column;gap:12px;align-items:flex-start}.home-new-game{flex-direction:column}.home-game-card{flex-wrap:wrap}.home-game-actions{width:100%;justify-content:flex-end;margin-top:4px}}.wc-screen{display:flex;flex-direction:column;height:100dvh;width:100%;background:var(--bg-primary)}.wc-header{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.wc-back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s}.wc-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.wc-header-info{flex:1;min-width:0}.wc-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.wc-subtitle{font-size:var(--text-sm);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-accent)}.wc-header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.wc-enter-btn{flex-shrink:0}.wc-messages{flex:1;overflow-y:auto;min-height:0;padding:24px}.wc-messages-inner{max-width:740px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.wc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 20px;text-align:center}.wc-empty-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-muted);color:var(--text-accent);margin-bottom:4px}.wc-empty-icon--pulse{animation:pulse 2s ease-in-out infinite}.wc-empty-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.wc-empty-text{font-size:var(--text-base);color:var(--text-muted);max-width:380px;line-height:1.6}.wc-empty-actions{display:flex;gap:8px;margin-top:8px}.wc-stopped-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:var(--bg-card-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-secondary);margin-bottom:16px}.wc-message{display:flex;flex-direction:column;animation:fadeIn .3s ease}.wc-message--gm{align-items:flex-start}.wc-message--player{align-items:flex-end}.wc-gm-bubble{max-width:85%;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);border-top-left-radius:4px;padding:16px 20px;font-size:var(--text-gm);line-height:var(--line-height-gm);color:var(--text-primary)}.wc-gm-bubble p{margin-bottom:10px}.wc-gm-bubble p:last-child{margin-bottom:0}.wc-gm-bubble em{color:var(--text-secondary)}.wc-gm-bubble strong{color:var(--text-accent);font-weight:600}.wc-gm-bubble blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:12px 0;color:var(--text-secondary);font-style:italic}.wc-gm-bubble h1,.wc-gm-bubble h2,.wc-gm-bubble h3{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;margin:14px 0 6px;color:var(--text-accent);letter-spacing:.02em}.wc-gm-bubble h1:first-child,.wc-gm-bubble h2:first-child,.wc-gm-bubble h3:first-child{margin-top:0}.wc-gm-bubble ul,.wc-gm-bubble ol{padding-left:20px;margin:8px 0}.wc-gm-bubble li{margin-bottom:4px}.wc-gm-bubble hr{border:none;border-top:1px solid var(--border-light);margin:16px 0}.wc-player-bubble{max-width:75%;background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius-md);border-top-right-radius:4px;padding:10px 16px;font-size:var(--text-gm);line-height:var(--line-height-gm)}.wc-player-bubble p{margin:0}.wc-error-bubble{max-width:85%;background:#fef2f2;border:1px solid #fca5a5;border-radius:var(--radius-md);padding:12px 16px;font-size:var(--text-base);line-height:1.5;color:#991b1b}.wc-ready-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 24px;background:var(--accent-muted);border-top:1px solid var(--accent);font-size:var(--text-base);color:var(--text-accent);flex-shrink:0}.wc-input-bar{padding:12px 24px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.wc-input-container{max-width:740px;margin:0 auto;display:flex;align-items:flex-end;gap:8px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px 4px 4px 16px;transition:border-color .2s,box-shadow .2s}.wc-input-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.wc-input{flex:1;border:none;background:transparent;padding:8px 0;font-size:var(--text-input);line-height:1.5;resize:none;min-height:24px;max-height:160px;overflow-y:auto}.wc-input:focus{border-color:transparent;outline:none}.wc-send-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent);color:var(--text-on-accent);transition:all .2s;flex-shrink:0}.wc-send-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-sm)}.wc-send-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.wc-header{padding:12px 16px}.wc-messages{padding:16px}.wc-input-bar{padding:8px 12px 12px}.wc-gm-bubble{max-width:92%;padding:12px 16px}.wc-player-bubble{max-width:85%}.wc-empty{padding:48px 16px}.wc-empty-title{font-size:var(--text-heading)}.wc-ready-bar{flex-wrap:wrap;padding:10px 16px;text-align:center}}.login-screen{height:100dvh;width:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px}.login-loading{font-size:var(--text-base);color:var(--text-muted);font-style:italic}.login-card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:32px;animation:slideUp .5s ease}.login-brand{text-align:center}.login-brand-title{font-family:var(--font-heading);font-size:32px;font-weight:600;color:var(--text-primary);letter-spacing:.08em}.login-brand-ornament{display:flex;align-items:center;justify-content:center;gap:12px;margin:10px 0}.login-brand-line{height:1px;width:50px;background:linear-gradient(90deg,transparent,var(--accent-light),transparent)}.login-brand-diamond{width:5px;height:5px;background:var(--accent-light);transform:rotate(45deg);flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:12px}.login-input-group{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:14px;color:var(--text-muted);pointer-events:none}.login-input{width:100%;padding:12px 16px 12px 40px;font-size:var(--text-input);border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-input);transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.login-btn{width:100%;justify-content:center;padding:12px;font-size:var(--text-base);font-weight:600;border-radius:var(--radius-md)}.login-error{font-size:var(--text-base);color:var(--danger);text-align:center;padding:4px 0}.main-content{flex:1;height:100%;min-height:0;overflow:hidden;background:var(--bg-primary);margin-left:var(--sidebar-width);transition:margin-left .3s ease;position:relative}.panel-enter{height:100%}.main-header-actions{position:absolute;top:13px;right:20px;display:flex;align-items:center;gap:6px;z-index:10}.main-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s}.main-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.mobile-overlay{display:none}@media(max-width:768px){.main-content{margin-left:0}.main-header-actions{top:11px;right:12px;gap:4px}.main-action-btn{width:32px;height:32px}.mobile-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:90;animation:fadeInOverlay .2s ease}}:root,[data-theme=light]{--bg-primary: #FAF6F0;--bg-secondary: #F5F0E8;--bg-card: #F5EDE0;--bg-card-alt: #FDF8F0;--bg-sidebar: #F0EBE2;--bg-input: #FFFFFF;--bg-hover: #EDE6D8;--bg-active: #8B6914;--bg-image-placeholder: #EDE3D0;--bg-overlay: rgba(0, 0, 0, .4);--text-primary: #3D2B1F;--text-secondary: #6B5744;--text-muted: #9A8A78;--text-on-accent: #FFFFFF;--text-accent: #8B6914;--border-color: #E0D5C5;--border-light: #EDE5D8;--accent: #8B6914;--accent-hover: #7A5B10;--accent-light: #C9A84C;--accent-muted: rgba(139, 105, 20, .1);--danger: #C0392B;--success: #27AE60;--warning: #F39C12;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(139, 105, 20, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--sidebar-width: 200px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-heading: "Cinzel", "Georgia", serif}[data-theme=dark]{--bg-primary: #1C1510;--bg-secondary: #241A14;--bg-card: #2D2118;--bg-card-alt: #342619;--bg-sidebar: #18120D;--bg-input: #2D2118;--bg-hover: #3F2E1F;--bg-active: #D4B65E;--bg-image-placeholder: #3A2C1D;--bg-overlay: rgba(10, 6, 2, .7);--text-primary: #EAE0D0;--text-secondary: #BFA98E;--text-muted: #8A7560;--text-on-accent: #1A1510;--text-accent: #D4B65E;--border-color: #3F2E1F;--border-light: #342619;--accent: #D4B65E;--accent-hover: #E0C46E;--accent-light: #9A7520;--accent-muted: rgba(212, 182, 94, .12);--shadow-sm: 0 1px 3px rgba(10, 6, 2, .3);--shadow-md: 0 4px 12px rgba(10, 6, 2, .4);--shadow-lg: 0 8px 24px rgba(10, 6, 2, .5);--shadow-glow: 0 0 20px rgba(212, 182, 94, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100dvh;width:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 12px;outline:none;transition:border-color .2s}input:focus,textarea:focus{border-color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;transition:all .2s;white-space:nowrap}.btn--sm{padding:5px 12px;font-size:var(--text-sm)}.btn--primary{background:var(--accent);color:var(--text-on-accent)}.btn--primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-sm)}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:var(--bg-input);color:var(--text-accent);border:1px solid var(--border-color)}.btn--secondary:hover{background:var(--bg-hover)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover{opacity:.9}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn--danger:hover{color:var(--danger);background:#c0392b1a}.text-muted{color:var(--text-muted);font-style:italic;font-size:var(--text-base)}.app-layout{display:flex;height:100%;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes dotBounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.panel-enter{animation:slideUp .3s ease forwards}[data-text-size=small]{--text-xs: 10px;--text-sm: 11px;--text-base: 13px;--text-gm: 14px;--text-heading: 15px;--text-input: 13px;--line-height-gm: 1.7}[data-text-size=normal],:root{--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-gm: 15px;--text-heading: 18px;--text-input: 14px;--line-height-gm: 1.8}[data-text-size=large]{--text-xs: 12px;--text-sm: 13px;--text-base: 16px;--text-gm: 17px;--text-heading: 20px;--text-input: 16px;--line-height-gm: 1.85}@media(max-width:768px){:root,[data-theme=light],[data-theme=dark]{--sidebar-width: 72px}}
