:root{--bg-primary: #0a0a0b;--bg-secondary: #111113;--bg-tertiary: #1a1a1d;--bg-hover: #222226;--text-primary: #e8e6e3;--text-secondary: #9a9691;--text-muted: #5a5854;--accent-gold: #c9a227;--accent-gold-dim: #8a7019;--accent-amber: #d4a574;--border-subtle: #2a2a2e;--border-medium: #3a3a3e;--shadow-glow: 0 0 40px rgba(201, 162, 39, .08);--font-display: "Crimson Pro", Georgia, serif;--font-body: "Space Grotesk", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9999}.app-layout{display:grid;grid-template-rows:auto 1fr;height:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.app-logo{font-family:var(--font-display);font-size:1.4rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.app-logo span{color:var(--accent-gold)}.header-controls{display:flex;align-items:center;gap:1rem}.app-main{display:grid;grid-template-columns:260px 1fr;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle)}.sidebar-title{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.sidebar-content{flex:1;overflow-y:auto;padding:.75rem}.doc-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.doc-item:hover{background:var(--bg-hover)}.doc-item.active{background:var(--bg-tertiary)}.doc-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-secondary)}.doc-name{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border-subtle)}.sidebar-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem;background:transparent;border:1px dashed var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-body);font-size:.8rem;cursor:pointer;transition:all .15s}.sidebar-btn:hover{border-color:var(--accent-gold-dim);color:var(--accent-gold)}.main-content{display:flex;flex-direction:column;overflow:hidden}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-toolbar{display:flex;justify-content:flex-end;padding:.5rem 2rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary)}.reset-btn{padding:.4rem .75rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-body);font-size:.8rem;cursor:pointer;transition:all .15s}.reset-btn:hover{border-color:#c44;color:#c44}.chat-messages{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.message{max-width:720px;animation:messageIn .3s ease-out}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{padding:1rem 1.25rem;border-radius:var(--radius-md);font-size:.95rem;line-height:1.7}.message.user .message-content{background:var(--bg-tertiary);border:1px solid var(--border-subtle)}.message.assistant .message-content{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-subtle);box-shadow:var(--shadow-glow)}.message-content p{margin-bottom:.75rem}.message-content p:last-child{margin-bottom:0}.message.interrupted .message-content{border-color:var(--accent-gold-dim)}.interrupted-indicator{margin-top:.75rem;padding-top:.5rem;border-top:1px dashed var(--border-subtle);font-size:.8rem;color:var(--text-muted);font-style:italic}.message.streaming{position:relative}.generating-text{color:var(--text-muted);font-style:italic}.stop-btn{display:inline-flex;align-items:center;gap:.4rem;margin-top:.75rem;padding:.5rem 1rem;background:#dc354526;border:1px solid rgba(220,53,69,.4);border-radius:var(--radius-sm);color:#dc3545;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.stop-btn:hover{background:#dc354540;border-color:#dc354599;color:#ff4757}.stop-btn svg{opacity:1}.options-container{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle);max-width:720px}.message .options-container{margin-top:1rem}.option-btn{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-align:left;cursor:pointer;transition:all .15s}.option-btn:hover{border-color:var(--accent-gold-dim);background:var(--bg-hover)}.option-btn:active{transform:scale(.99)}.option-btn:disabled{opacity:.5;cursor:not-allowed}.option-btn:disabled:hover{border-color:var(--border-subtle);background:var(--bg-primary)}.option-key{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent-gold)}.option-content{flex:1}.option-text{font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.option-desc{font-size:.8rem;color:var(--text-secondary)}.chat-input-area{padding:1rem 2rem 1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.chat-input-wrapper{display:flex;align-items:flex-end;gap:.75rem;max-width:720px}.chat-input{flex:1;padding:1rem 1.25rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;line-height:1.5;resize:none;height:80px;overflow-y:auto;transition:border-color .15s,height .1s ease}.chat-input:focus{outline:none;border-color:var(--accent-gold-dim)}.chat-input::placeholder{color:var(--text-muted)}.send-btn{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-gold);border:none;border-radius:var(--radius-md);color:var(--bg-primary);cursor:pointer;transition:all .15s}.send-btn:hover{background:var(--accent-amber)}.send-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.select-wrapper{position:relative}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.5rem 2rem .5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:.85rem;cursor:pointer}.select:focus{outline:none;border-color:var(--accent-gold-dim)}.select-wrapper:after{content:"";position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-secondary);pointer-events:none}.project-list{padding:2rem;max-width:600px;margin:0 auto}.project-list h1{font-family:var(--font-display);font-size:2rem;font-weight:600;margin-bottom:2rem;color:var(--text-primary)}.project-card{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:.75rem;cursor:pointer;transition:all .15s}.project-card:hover{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-glow)}.project-name{font-weight:500;color:var(--text-primary)}.project-meta{font-size:.8rem;color:var(--text-muted)}.create-project-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:transparent;border:2px dashed var(--border-medium);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-body);font-size:.95rem;cursor:pointer;transition:all .15s;margin-top:1rem}.create-project-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;width:90%;max-width:400px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal h2{font-family:var(--font-display);font-size:1.3rem;margin-bottom:1rem}.modal-input{width:100%;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;margin-bottom:.75rem}.modal-input:focus{outline:none;border-color:var(--accent-gold-dim)}.modal-actions{display:flex;gap:.75rem;margin-top:1rem}.btn{flex:1;padding:.7rem 1rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:var(--accent-gold);border:none;color:var(--bg-primary)}.btn-primary:hover{background:var(--accent-amber)}.btn-secondary{background:transparent;border:1px solid var(--border-medium);color:var(--text-secondary)}.btn-secondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.roleplay-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.roleplay-messages{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1rem}.roleplay-message{padding:1rem 1.25rem;border-radius:var(--radius-md);animation:messageIn .3s ease-out}.roleplay-message.narrator{background:linear-gradient(135deg,rgba(201,162,39,.1) 0%,transparent 100%);border:1px solid var(--accent-gold-dim);font-style:italic;color:var(--accent-amber)}.roleplay-message.character{background:var(--bg-tertiary);border:1px solid var(--border-subtle)}.roleplay-speaker{font-family:var(--font-mono);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-gold);margin-bottom:.5rem}.roleplay-dialogue{font-size:.95rem;line-height:1.7}.streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--accent-gold);margin-left:2px;animation:blink .8s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--text-muted)}.empty-state h2{font-family:var(--font-display);font-size:1.5rem;color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{max-width:400px;font-size:.9rem}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);padding:0 2rem}.tab{padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:all .15s;margin-bottom:-1px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent-gold);border-bottom-color:var(--accent-gold)}.streaming-indicator{display:inline-flex;align-items:center;margin-left:.5rem}.streaming-dot{width:8px;height:8px;background:var(--accent-gold);border-radius:50%;animation:streaming-pulse 1.5s ease-in-out infinite}@keyframes streaming-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.workflow-progress{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.phase-step{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-muted);transition:all .2s}.phase-step .phase-indicator{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-tertiary);font-size:.7rem;font-weight:500}.phase-step.active{color:var(--accent-gold);background:#c9a2271a}.phase-step.active .phase-indicator{background:var(--accent-gold);color:var(--bg-primary)}.phase-step.completed{color:var(--text-secondary)}.phase-step.completed .phase-indicator{background:var(--accent-gold-dim);color:var(--bg-primary)}.phase-step:after{content:"";display:block;width:24px;height:1px;background:var(--border-subtle);margin-left:.5rem}.phase-step:last-child:after{display:none}.character-list{padding:2rem;overflow-y:auto}.character-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--text-muted)}.character-list-empty h2{font-family:var(--font-display);font-size:1.5rem;color:var(--text-secondary);margin-bottom:.5rem}.character-list-empty p{max-width:400px;font-size:.9rem}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.character-card{display:flex;gap:1rem;padding:1.25rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.character-card:hover{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-glow)}.character-avatar{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-gold) 0%,var(--accent-gold-dim) 100%);border-radius:50%;color:var(--bg-primary);font-family:var(--font-display);font-size:1.4rem;font-weight:600}.character-info{flex:1;min-width:0}.character-name{font-family:var(--font-display);font-size:1.1rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.character-description{font-size:.85rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.writing-tab{display:grid;grid-template-columns:320px 1fr 280px;flex:1;overflow:hidden}.writing-outline-panel,.writing-scripts-panel{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden}.writing-scripts-panel{border-right:none;border-left:1px solid var(--border-subtle)}.writing-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle)}.writing-panel-header h3{font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--text-primary)}.writing-select-actions{display:flex;gap:.5rem}.writing-select-btn{padding:.25rem .5rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-body);font-size:.7rem;cursor:pointer;transition:all .15s}.writing-select-btn:hover{border-color:var(--accent-gold-dim);color:var(--accent-gold)}.writing-outline-list,.writing-scripts-list{flex:1;overflow-y:auto;padding:.75rem}.writing-empty{padding:1.5rem 1rem;text-align:center;color:var(--text-muted);font-size:.85rem}.writing-outline-item{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .15s}.writing-outline-item:hover{background:var(--bg-hover)}.writing-outline-item.selected{background:#c9a22714;border-color:var(--accent-gold-dim)}.writing-outline-reorder{display:flex;flex-direction:column;gap:2px}.reorder-btn{width:20px;height:16px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:2px;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .15s}.reorder-btn:hover:not(:disabled){border-color:var(--accent-gold-dim);color:var(--accent-gold)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.writing-outline-checkbox{display:flex;align-items:center;padding-top:2px}.writing-outline-checkbox input{width:16px;height:16px;cursor:pointer;accent-color:var(--accent-gold)}.writing-outline-info{flex:1;min-width:0;cursor:pointer}.writing-outline-title{font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.writing-outline-preview{font-size:.8rem;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.writing-actions{padding:.75rem;border-top:1px solid var(--border-subtle)}.writing-actions .btn{width:100%}.writing-actions .btn:disabled{opacity:.5;cursor:not-allowed}.writing-content-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.writing-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--text-muted)}.writing-placeholder h2{font-family:var(--font-display);font-size:1.5rem;color:var(--text-secondary);margin-bottom:.75rem}.writing-placeholder p{max-width:400px;font-size:.9rem;margin-bottom:.5rem}.writing-hint{font-size:.85rem;color:var(--text-muted);opacity:.8}.writing-stream{flex:1;display:flex;flex-direction:column;overflow:hidden}.writing-stream-header{padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:.85rem;color:var(--accent-gold)}.writing-stream-content{flex:1;overflow-y:auto;padding:1.5rem}.writing-stream-content pre{font-family:var(--font-mono);font-size:.9rem;line-height:1.7;white-space:pre-wrap;word-wrap:break-word;color:var(--text-primary)}.writing-script-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.writing-script-item:hover{background:var(--bg-hover)}.writing-script-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.7rem;font-weight:500;color:var(--accent-gold)}.writing-script-info{flex:1;min-width:0}.writing-script-title{font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.writing-script-meta{font-size:.75rem;color:var(--text-muted)}.character-tab{display:grid;grid-template-columns:260px 1fr;height:100%;overflow:hidden}.character-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.character-sidebar h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--accent-gold);margin-bottom:.5rem}.character-grid-small{display:flex;flex-direction:column;gap:.5rem}.character-card-small{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;border:1px solid transparent}.character-card-small:hover{background:var(--bg-hover)}.character-card-small.focused{background:var(--bg-tertiary);border-color:var(--accent-gold)}.character-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-gold-dim),var(--accent-gold));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--bg-primary);flex-shrink:0}.character-name-small{font-size:.9rem;color:var(--text-primary);flex:1;word-break:break-word}.character-name-input{font-size:.85rem;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--accent-gold);border-radius:var(--radius-sm);padding:.2rem .4rem;flex:1;min-width:0}.character-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.character-card-small:hover .character-actions{opacity:1}.char-action-btn{background:transparent;border:none;padding:.25rem;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s}.char-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.char-action-btn.delete:hover{background:#dc354533;color:#dc3545}.focused-character-info{margin-top:auto;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--accent-gold-dim)}.focused-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem}.focused-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--accent-gold);margin-bottom:.5rem}.clear-focus-btn{width:100%;padding:.4rem .75rem;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s}.clear-focus-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.character-chat{display:flex;flex-direction:column;height:100%;overflow:hidden}.character-chat .chat-messages{flex:1;overflow-y:auto;padding:1.5rem}.character-chat .chat-toolbar{padding:.5rem 1.5rem;border-bottom:1px solid var(--border-subtle)}.character-chat .chat-input-area{padding:1rem 1.5rem;border-top:1px solid var(--border-subtle);background:var(--bg-secondary)}.character-chat .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:2rem}.character-chat .empty-state h2{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--accent-gold);margin-bottom:.75rem}.character-chat .empty-state p{color:var(--text-secondary);max-width:400px;margin-bottom:.5rem}.character-chat .empty-state .hint{font-size:.85rem;color:var(--text-muted);font-style:italic}.warnings-panel{padding:.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:.75rem}.warning-section{border-radius:var(--radius-md);overflow:hidden}.warning-section.conflicts{background:#dc35451a;border:1px solid rgba(220,53,69,.3)}.warning-section.suggestions{background:#c9a2271a;border:1px solid rgba(201,162,39,.3)}.warning-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.85rem;font-weight:600}.warning-section.conflicts .warning-header{color:#dc3545}.warning-section.suggestions .warning-header{color:var(--accent-gold)}.warning-header span{flex:1}.dismiss-btn{background:transparent;border:1px solid currentColor;color:inherit;opacity:.7;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:opacity .2s}.dismiss-btn:hover{opacity:1}.warning-items{padding:0 .75rem .75rem;display:flex;flex-direction:column;gap:.5rem}.conflict-item,.suggestion-item{background:#0003;border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.8rem}.conflict-doc,.suggestion-type{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.conflict-field{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.conflict-existing,.conflict-new{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.conflict-existing{text-decoration:line-through;opacity:.7}.conflict-new{color:var(--text-primary)}.suggestion-content{color:var(--text-secondary);line-height:1.4}.cd-container{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}.cd-container.cd-visible{opacity:1;transform:translateY(0)}.cd-header{position:relative;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:1.5rem 2rem 1rem;border-bottom:1px solid var(--border-subtle)}.cd-back{display:inline-flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:.5rem 1rem;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease;margin-bottom:1.5rem}.cd-back:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-gold-dim)}.cd-hero{display:flex;align-items:center;gap:1.5rem;position:relative;padding:1rem 0}.cd-spotlight{position:absolute;width:200px;height:200px;left:-40px;top:50%;transform:translateY(-50%);background:radial-gradient(ellipse at center,rgba(201,162,39,.15) 0%,rgba(201,162,39,.05) 40%,transparent 70%);pointer-events:none;filter:blur(20px)}.cd-avatar{position:relative;width:80px;height:80px;border-radius:50%;background:linear-gradient(145deg,#1a1a1d,#0a0a0b);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 2px var(--accent-gold-dim),0 0 30px #c9a22733,inset 0 -10px 30px #00000080}.cd-initial{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--accent-gold);text-shadow:0 2px 10px rgba(201,162,39,.3)}.cd-title-block{flex:1}.cd-name{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;margin:0 0 .25rem;line-height:1.2}.cd-tagline{font-size:.95rem;color:var(--text-secondary);margin:0;font-style:italic}.cd-tabs{display:flex;gap:.75rem;margin-top:1.5rem}.cd-tab{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cd-tab:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-medium)}.cd-tab-active{background:var(--accent-gold);border-color:var(--accent-gold);color:var(--bg-primary)}.cd-tab-active:hover{background:var(--accent-gold);color:var(--bg-primary)}.cd-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .4rem;background:#0003;border-radius:999px;font-size:.75rem;font-weight:700}.cd-tab-active .cd-tab-count{background:#0000004d}.cd-content{flex:1;overflow-y:auto;padding:2rem;background:linear-gradient(180deg,var(--bg-primary) 0%,rgba(17,17,19,.5) 100%),repeating-linear-gradient(0deg,transparent,transparent 50px,rgba(201,162,39,.02) 50px,rgba(201,162,39,.02) 51px)}.cd-grid{display:grid;gap:1rem}.cd-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem 1.25rem 1.25rem 1.5rem;transition:all .25s ease;animation:cd-card-in .4s ease backwards}@keyframes cd-card-in{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.cd-card:hover{border-color:var(--accent-gold-dim);box-shadow:0 4px 20px #0000004d,0 0 0 1px var(--accent-gold-dim);transform:translateY(-2px)}.cd-card-empty{opacity:.4;background:transparent;border-style:dashed}.cd-card-empty:hover{opacity:.6;border-color:var(--border-medium);box-shadow:none;transform:none}.cd-card-edge{position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent-gold) 0%,var(--accent-gold-dim) 100%);border-radius:var(--radius-md) 0 0 var(--radius-md);opacity:0;transition:opacity .25s ease}.cd-card:hover .cd-card-edge{opacity:1}.cd-card-empty .cd-card-edge{display:none}.cd-card-header{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.75rem}.cd-card-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-gold)}.cd-card-label-en{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);opacity:.6}.cd-card-body{line-height:1.7}.cd-card-value{color:var(--text-primary);white-space:pre-wrap}.cd-card-placeholder{color:var(--text-muted);font-style:italic;font-size:.9rem}.cd-relationships{display:flex;flex-direction:column;gap:.5rem}.cd-relationship{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border-subtle)}.cd-relationship:last-child{border-bottom:none;padding-bottom:0}.cd-rel-name{font-weight:600;color:var(--accent-amber)}.cd-rel-name:after{content:":"}.cd-rel-desc{color:var(--text-primary)}.cd-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.cd-empty-icon{width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);border:2px dashed var(--border-medium);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2.5rem;color:var(--text-muted);margin-bottom:1.5rem}.cd-empty p{margin:0;font-size:1.1rem}.cd-empty-hint{font-size:.9rem!important;color:var(--text-muted);margin-top:.5rem!important}.cd-footer{padding:.75rem 2rem;background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.cd-meta{font-size:.75rem;color:var(--text-muted);font-style:italic}.cd-footer{display:flex;justify-content:space-between;align-items:center}.cd-version{font-size:.7rem;color:var(--accent-gold);background:#c9a2271a;padding:.2rem .5rem;border-radius:var(--radius-sm);font-weight:600}.cd-loading{text-align:center;padding:3rem;color:var(--text-muted)}.cd-history-list{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem}.cd-history-current{display:flex;align-items:center;gap:1rem;padding:1rem;background:#c9a2271a;border:1px solid var(--accent-gold-dim);border-radius:var(--radius-md)}.cd-history-current .cd-history-version{font-size:1.1rem;font-weight:600;color:var(--accent-gold)}.cd-history-label{color:var(--accent-gold);font-size:.85rem;font-weight:500}.cd-history-item{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem}.cd-history-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.cd-history-version{font-weight:600;color:var(--text-primary)}.cd-history-time{flex:1;color:var(--text-muted);font-size:.8rem}.cd-restore-btn{background:transparent;border:1px solid var(--accent-gold-dim);color:var(--accent-gold);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s}.cd-restore-btn:hover{background:var(--accent-gold);color:var(--bg-primary)}.cd-history-changes{font-size:.8rem;color:var(--text-secondary)}.cd-edit-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;opacity:0;transition:all .2s}.cd-card:hover .cd-edit-btn{opacity:1}.cd-edit-btn:hover{color:var(--accent-gold)}.cd-card-header{position:relative}.cd-card-editing{border-color:var(--accent-gold)}.cd-edit-form{display:flex;flex-direction:column;gap:.75rem}.cd-edit-input{width:100%;min-height:80px;background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:.75rem;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;line-height:1.5;resize:vertical}.cd-edit-input:focus{outline:none;border-color:var(--accent-gold)}.cd-edit-actions{display:flex;justify-content:flex-end;gap:.5rem}.cd-edit-cancel,.cd-edit-save{padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s}.cd-edit-cancel{background:transparent;border:1px solid var(--border-medium);color:var(--text-secondary)}.cd-edit-cancel:hover{background:var(--bg-hover)}.cd-edit-save{background:var(--accent-gold);border:none;color:var(--bg-primary);font-weight:500}.cd-edit-save:hover{background:var(--accent-amber)}.cd-edit-save:disabled,.cd-edit-cancel:disabled{opacity:.5;cursor:not-allowed}.doc-editor{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.doc-editor-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.doc-title-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-display);font-size:1.1rem}.doc-title-input:focus{outline:none;border-color:var(--accent-gold)}.doc-context-toggle{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;white-space:nowrap}.btn-icon{background:var(--bg-tertiary);border:1px solid var(--border-subtle);color:var(--text-secondary);padding:.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.btn-icon:hover{color:var(--accent-gold);border-color:var(--accent-gold-dim)}.btn-icon.btn-active{background:#c9a2271a;color:var(--accent-gold);border-color:var(--accent-gold-dim)}.doc-editor-body{flex:1;display:flex;overflow:hidden}.doc-content-input{flex:1;background:var(--bg-primary);border:none;padding:1.5rem;color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;line-height:1.8;resize:none}.doc-content-input:focus{outline:none}.doc-history-panel{width:300px;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden}.doc-history-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-subtle)}.doc-history-header h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.doc-version-badge{font-size:.7rem;color:var(--accent-gold);background:#c9a2271a;padding:.2rem .5rem;border-radius:var(--radius-sm);font-weight:600}.doc-history-loading,.doc-history-empty{padding:2rem;text-align:center;color:var(--text-muted)}.doc-history-empty svg{margin-bottom:.75rem;opacity:.5}.doc-history-empty p{margin:.25rem 0}.doc-history-hint{font-size:.8rem;opacity:.7}.doc-history-list{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.doc-history-item{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.75rem}.doc-history-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.doc-history-version{font-weight:600;color:var(--text-primary);font-size:.85rem}.doc-history-time{flex:1;color:var(--text-muted);font-size:.75rem}.doc-restore-btn{background:transparent;border:1px solid var(--accent-gold-dim);color:var(--accent-gold);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.7rem;cursor:pointer;transition:all .2s}.doc-restore-btn:hover{background:var(--accent-gold);color:var(--bg-primary)}.doc-history-preview{font-size:.75rem;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.app-header{padding:.5rem 1rem;flex-wrap:wrap;gap:.5rem}.app-logo{font-size:1.1rem}.header-controls{gap:.5rem;font-size:.8rem}.header-controls .select{padding:.4rem .6rem;font-size:.8rem}.app-main{grid-template-columns:1fr;grid-template-rows:1fr auto}.sidebar{order:2;border-right:none;border-top:1px solid var(--border-subtle);max-height:35vh;overflow-y:auto}.sidebar-header{padding:.75rem 1rem}.sidebar-header h2{font-size:.9rem}.doc-list{padding:.5rem;gap:.25rem}.doc-item{padding:.5rem .75rem}.main-content{order:1;min-height:0}.tabs{padding:0 .5rem;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:.75rem;font-size:.8rem;white-space:nowrap;flex-shrink:0}.chat-container{display:flex;flex-direction:column;height:100%}.workflow-progress{padding:.75rem;gap:.25rem;overflow-x:auto;flex-wrap:nowrap}.phase-step{flex-shrink:0;gap:.25rem}.phase-indicator{width:20px;height:20px;font-size:.7rem}.phase-label{font-size:.7rem}.chat-toolbar{padding:.5rem 1rem}.chat-messages{padding:1rem}.message{max-width:95%}.message-content{padding:.75rem 1rem;font-size:.9rem}.options-container{gap:.5rem}.option-btn{padding:.6rem .75rem}.option-key{width:24px;height:24px;font-size:.7rem}.option-text{font-size:.85rem}.option-desc{font-size:.75rem}.chat-input-area{padding:.75rem 1rem}.chat-input{font-size:16px;padding:.6rem .75rem}.send-btn{width:40px;height:40px}.empty-state{padding:1.5rem}.empty-state h2{font-size:1.25rem}.empty-state p{font-size:.9rem}.character-tab{grid-template-columns:1fr;grid-template-rows:auto 1fr}.character-sidebar{border-right:none;border-bottom:1px solid var(--border-subtle);padding:.75rem;max-height:none;overflow:visible}.character-sidebar h3{font-size:.85rem;margin-bottom:.5rem}.character-grid-small{flex-direction:row;flex-wrap:wrap;gap:.5rem}.character-card-small{padding:.4rem .6rem;flex:0 0 auto}.character-avatar-small{width:28px;height:28px;font-size:.8rem}.character-name-small{font-size:.8rem}.focused-character-info{margin-top:.5rem;padding:.5rem}.focused-label{font-size:.65rem}.focused-name{font-size:.9rem}.character-chat .chat-messages{padding:1rem}.character-chat .chat-input-area{padding:.75rem 1rem}.writing-tab{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.writing-outline-panel,.writing-scripts-panel{border-right:none;border-bottom:1px solid var(--border-subtle);max-height:30vh;overflow-y:auto}.writing-outline-panel h3,.writing-scripts-panel h3{font-size:.9rem;padding:.75rem 1rem}.writing-outline-list{padding:.5rem}.writing-outline-item{padding:.6rem .75rem}.writing-content-panel{min-height:40vh}.doc-editor{padding:1rem}.doc-editor-header{flex-direction:column;align-items:flex-start;gap:.75rem}.doc-editor-title{font-size:1.1rem}.doc-editor-content{font-size:.9rem;padding:.75rem}.project-grid{grid-template-columns:1fr;gap:.75rem;padding:1rem}.project-card,.new-project-form{padding:1rem}.form-row{flex-direction:column;gap:.75rem}.roleplay-container{padding:1rem}.roleplay-message{max-width:95%}.modal-content{margin:1rem;max-height:90vh}}@media (max-width: 380px){.app-header{padding:.5rem .75rem}.app-logo{font-size:1rem}.tabs{padding:0 .25rem}.tab{padding:.6rem .5rem;font-size:.75rem}.phase-label{display:none}.phase-indicator{width:24px;height:24px}.message-content{padding:.6rem .75rem}.option-btn{padding:.5rem .6rem}.character-grid-small{gap:.35rem}.character-card-small{padding:.35rem .5rem}.character-avatar-small{width:24px;height:24px;font-size:.7rem}}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.75rem;z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:0 8px 32px #0006;animation:toastSlideIn .25s ease;pointer-events:auto;min-width:280px;max-width:400px}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.toast-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;flex-shrink:0}.toast-success .toast-icon{background:#10b98126;color:#10b981}.toast-error .toast-icon{background:#ef444426;color:#ef4444}.toast-warning .toast-icon{background:#f59e0b26;color:#f59e0b}.toast-info .toast-icon{background:#3b82f626;color:#3b82f6}.toast-success{border-color:#10b9814d}.toast-error{border-color:#ef44444d}.toast-warning{border-color:#f59e0b4d}.toast-info{border-color:#3b82f64d}.toast-message{flex:1;font-size:.9rem;color:var(--text-primary)}.toast-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .15s}.toast-dismiss:hover{color:var(--text-primary);background:var(--bg-hover)}.doc-delete-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:0;transition:all .15s}.doc-item:hover .doc-delete-btn{opacity:1}.doc-delete-btn:hover{color:#ef4444;background:#ef44441a}.dashboard{padding:2rem;overflow-y:auto;height:100%}.dashboard-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-subtle)}.dashboard-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.dashboard-project-name{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--text-primary);margin:0}.dashboard-format-badge{background:var(--accent-gold-dim);color:var(--accent-gold);font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em}.dashboard-phase-indicator{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.dashboard-phase-indicator .phase-label{color:var(--text-muted)}.dashboard-phase-indicator .phase-value{color:var(--accent-gold);font-weight:500}.dashboard-grid{display:flex;flex-direction:column;gap:2rem}.dashboard-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h2{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.section-link{background:none;border:none;color:var(--accent-gold);font-size:.85rem;cursor:pointer;padding:0;transition:opacity .15s}.section-link:hover{opacity:.8}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:0;background:transparent;border:none}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem;text-align:center}.stat-value{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--accent-gold);line-height:1;margin-bottom:.5rem}.stat-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.dashboard-characters{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.dashboard-char-card{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem;text-align:center;cursor:pointer;transition:all .2s}.dashboard-char-card:hover{border-color:var(--accent-gold-dim);transform:translateY(-2px)}.dashboard-char-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-gold-dim) 0%,var(--accent-gold) 100%);display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--bg-primary)}.dashboard-char-name{font-weight:500;font-size:.9rem;color:var(--text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-char-role{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-more-card{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px dashed var(--border-medium);border-radius:var(--radius-md);padding:1rem;color:var(--text-muted);font-size:.9rem}.dashboard-doc-groups{display:flex;flex-direction:column;gap:1.25rem}.dashboard-doc-group{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem}.doc-group-title{font-size:.8rem;font-weight:600;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.doc-group-list{display:flex;flex-direction:column;gap:.5rem}.dashboard-doc-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.dashboard-doc-item:hover{border-color:var(--accent-gold-dim);background:var(--bg-hover)}.doc-item-title{font-weight:500;color:var(--text-primary)}.doc-item-words{font-size:.8rem;color:var(--text-muted)}.dashboard-progress{background:var(--bg-secondary)}.progress-track{display:flex;align-items:flex-start;justify-content:space-between;position:relative;padding:0 1rem}.progress-track:before{content:"";position:absolute;top:16px;left:2rem;right:2rem;height:2px;background:var(--border-medium)}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1}.progress-dot{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border-medium);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--text-muted);transition:all .2s}.progress-step.completed .progress-dot{background:var(--accent-gold);border-color:var(--accent-gold);color:var(--bg-primary)}.progress-step.current .progress-dot{border-color:var(--accent-gold);color:var(--accent-gold);box-shadow:0 0 0 4px #c9a22733}.progress-label{font-size:.75rem;color:var(--text-muted);text-align:center;max-width:80px}.progress-step.current .progress-label{color:var(--accent-gold);font-weight:500}.dashboard-empty{text-align:center;padding:2rem;color:var(--text-muted)}.dashboard-empty p{margin-bottom:1rem}.dashboard-empty .btn{margin-top:.5rem}.sde-container{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}.sde-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.sde-header-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem}.sde-back{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.sde-back:hover{color:var(--text-primary);border-color:var(--border-medium)}.sde-title-row{flex:1;display:flex;align-items:center;gap:1rem}.sde-title-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-display);font-size:1.2rem;font-weight:600}.sde-title-input:focus{outline:none;border-color:var(--accent-gold)}.sde-type-badge{background:#c9a22726;color:var(--accent-gold);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;white-space:nowrap}.sde-context-toggle{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;white-space:nowrap;cursor:pointer}.sde-tabs{display:flex;padding:0 1.5rem;gap:.25rem;border-top:1px solid var(--border-subtle)}.sde-tab{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:var(--text-secondary);padding:.75rem 1rem;font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.sde-tab:hover{color:var(--text-primary)}.sde-tab-active{color:var(--accent-gold);border-bottom-color:var(--accent-gold)}.sde-tab-count{background:var(--bg-tertiary);padding:.1rem .4rem;border-radius:10px;font-size:.75rem;font-weight:600}.sde-tab-active .sde-tab-count{background:#c9a22733;color:var(--accent-gold)}.sde-content{flex:1;overflow-y:auto;padding:1.5rem}.sde-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.sde-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;animation:sde-card-in .3s ease-out forwards;opacity:0;transform:translateY(10px)}@keyframes sde-card-in{to{opacity:1;transform:translateY(0)}}.sde-card-empty{opacity:.6;background:var(--bg-tertiary);border-style:dashed}.sde-card-editing{border-color:var(--accent-gold);box-shadow:0 0 0 1px var(--accent-gold)}.sde-card-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(to right,rgba(201,162,39,.05),transparent);border-bottom:1px solid var(--border-subtle);position:relative}.sde-card-label{font-weight:600;color:var(--text-primary)}.sde-card-label-en{color:var(--text-muted);font-size:.8rem}.sde-edit-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;opacity:0;transition:all .2s}.sde-card:hover .sde-edit-btn{opacity:1}.sde-edit-btn:hover{color:var(--accent-gold)}.sde-card-body{padding:1rem;min-height:60px}.sde-card-placeholder{color:var(--text-muted);font-style:italic;font-size:.9rem}.sde-card-value{color:var(--text-primary);font-size:.95rem;line-height:1.6}.sde-text-value{white-space:pre-wrap}.sde-list{list-style:none;padding:0;margin:0}.sde-list-item{padding:.4rem 0;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.sde-list-item:last-child{border-bottom:none}.sde-list-item:before{content:"•";color:var(--accent-gold);margin-right:.5rem}.sde-dict{display:flex;flex-direction:column;gap:.5rem}.sde-dict-item{display:flex;gap:.5rem}.sde-dict-key{font-weight:600;color:var(--accent-amber)}.sde-dict-key:after{content:":"}.sde-dict-value{color:var(--text-primary)}.sde-scenes{display:flex;flex-direction:column;gap:.75rem}.sde-scene-item{padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);border-left:3px solid var(--accent-gold)}.sde-scene-header{font-weight:600;color:var(--accent-gold);margin-bottom:.25rem}.sde-scene-location{font-size:.85rem;color:var(--accent-amber);margin-bottom:.25rem}.sde-scene-desc{font-size:.9rem;color:var(--text-primary)}.sde-edit-form{display:flex;flex-direction:column;gap:.75rem}.sde-edit-input{width:100%;background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:.75rem;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;line-height:1.5;resize:vertical}.sde-edit-input:focus{outline:none;border-color:var(--accent-gold)}.sde-edit-actions{display:flex;justify-content:flex-end;gap:.5rem}.sde-edit-cancel,.sde-edit-save{padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s}.sde-edit-cancel{background:transparent;border:1px solid var(--border-medium);color:var(--text-secondary)}.sde-edit-cancel:hover{background:var(--bg-hover)}.sde-edit-save{background:var(--accent-gold);border:none;color:var(--bg-primary);font-weight:500}.sde-edit-save:hover{background:var(--accent-amber)}.sde-edit-save:disabled,.sde-edit-cancel:disabled{opacity:.5;cursor:not-allowed}.sde-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.sde-empty svg{margin-bottom:1.5rem;color:var(--text-muted)}.sde-empty p{margin:0;font-size:1.1rem}.sde-empty-hint{font-size:.9rem!important;color:var(--text-muted);margin-top:.5rem!important}.sde-empty-icon{width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);border:2px dashed var(--border-medium);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2.5rem;color:var(--text-muted);margin-bottom:1.5rem}.sde-footer{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.sde-meta{font-size:.75rem;color:var(--text-muted);font-style:italic}.sde-version{font-size:.7rem;color:var(--accent-gold);background:#c9a2271a;padding:.2rem .5rem;border-radius:var(--radius-sm);font-weight:600}.sde-loading{text-align:center;padding:3rem;color:var(--text-muted)}.sde-history-list{display:flex;flex-direction:column;gap:.75rem}.sde-history-current{display:flex;align-items:center;gap:1rem;padding:1rem;background:#c9a2271a;border:1px solid var(--accent-gold-dim);border-radius:var(--radius-md)}.sde-history-current .sde-history-version{font-size:1.1rem;font-weight:600;color:var(--accent-gold)}.sde-history-label{color:var(--accent-gold);font-size:.85rem;font-weight:500}.sde-history-item{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem}.sde-history-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.sde-history-version{font-weight:600;color:var(--text-primary)}.sde-history-time{flex:1;color:var(--text-muted);font-size:.8rem}.sde-restore-btn{background:transparent;border:1px solid var(--accent-gold-dim);color:var(--accent-gold);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s}.sde-restore-btn:hover{background:var(--accent-gold);color:var(--bg-primary)}.sde-history-changes{font-size:.8rem;color:var(--text-secondary)}.beat-sheet-editor{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.beat-sheet-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.beat-sheet-header h2{flex:1;margin:0;font-size:1.25rem;color:var(--text-primary)}.beat-sheet-content{flex:1;overflow-y:auto;padding:1.5rem}.beat-sheet-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.beat-sheet-section h3{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.act-description{margin:0 0 1rem;color:var(--text-secondary);font-size:.9rem}.story-dna-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.story-dna-field label,.action-idea-field label{display:block;margin-bottom:.25rem;color:var(--text-secondary);font-size:.85rem;font-weight:500}.story-dna-field input,.action-idea-field input{width:100%;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem}.story-dna-field input:focus,.action-idea-field input:focus{outline:none;border-color:var(--accent-gold)}.action-idea-field{margin-top:1rem}.beats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.beat-card{padding:1rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-left:4px solid var(--accent-gold);border-radius:var(--radius-sm)}.beat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.beat-label{font-weight:600;color:var(--text-primary)}.beat-label-nl{font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.beat-percentage{font-size:.75rem;color:var(--accent-gold);font-weight:600;padding:.15rem .4rem;background:#c9a22726;border-radius:var(--radius-sm)}.beat-description{font-size:.8rem;color:var(--text-secondary);margin:0 0 .75rem;line-height:1.4}.beat-textarea{width:100%;min-height:80px;padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;resize:vertical}.beat-textarea:focus{outline:none;border-color:var(--accent-gold)}.midpoint-type-field{margin-top:1rem;display:flex;align-items:center;gap:.75rem}.midpoint-type-field label{color:var(--text-secondary);font-size:.85rem}.midpoint-type-field select{padding:.4rem .75rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.whiff-of-death-field{margin-top:1rem}.whiff-of-death-field label{display:block;margin-bottom:.25rem;color:var(--text-secondary);font-size:.85rem}.whiff-of-death-field input{width:100%;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem}.finale-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.finale-section h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.finale-grid{display:grid;gap:.75rem}.finale-point label{display:block;margin-bottom:.25rem;color:var(--text-secondary);font-size:.85rem;font-weight:500}.finale-point textarea{width:100%;min-height:60px;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;resize:vertical}.finale-point textarea:focus{outline:none;border-color:var(--accent-gold)}.aristotle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.aristotle-field label{display:block;margin-bottom:.25rem;color:var(--text-secondary);font-size:.85rem;font-weight:500}.aristotle-field textarea{width:100%;min-height:80px;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;resize:vertical}.aristotle-field textarea:focus{outline:none;border-color:var(--accent-gold)}@media (max-width: 768px){.story-dna-grid,.aristotle-grid,.beats-grid{grid-template-columns:1fr}}
