.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary)}.login-box{background:var(--card-bg);padding:2rem;border-radius:10px;border:1px solid var(--border-color);width:100%;max-width:400px}.login-box h1{text-align:center;color:var(--text-primary);margin-bottom:.5rem}.login-box h2{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.2rem;font-weight:400}.login-box form{display:flex;flex-direction:column;gap:1rem}.login-box input{padding:.75rem;border:1px solid var(--border-color);border-radius:5px;font-size:1rem;background:var(--bg-primary);color:var(--text-primary)}.login-box input:focus{outline:none;border-color:var(--accent)}.login-box button{padding:.75rem;background:var(--accent);color:#fff;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:background .3s}.login-box button:hover{background:var(--accent-hover)}.login-box .toggle{margin-top:1rem;background:transparent;color:var(--accent);text-decoration:underline;cursor:pointer;border:none;padding:.5rem}.login-box .toggle:hover{background:var(--bg-secondary)}.error{color:#e74c3c;font-size:.9rem;text-align:center}.success{color:#27ae60;background:#27ae601a;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center;border:1px solid rgba(39,174,96,.3)}.auth-options{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.reset-link{font-size:.9rem;color:var(--text-secondary)}.reset-info{margin-top:1rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px;font-size:.9rem}.reset-info p{margin:.5rem 0}.reset-info em{color:var(--text-secondary)}.invite-info{margin-bottom:1.5rem;padding:1rem;background:#3498db1a;border:1px solid rgba(52,152,219,.3);border-radius:5px;text-align:center}.invite-info p{margin:.5rem 0;color:var(--text-primary)}.invite-by{font-size:.9rem;color:var(--text-secondary)}.projects-list{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.projects-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.projects-header h1{font-size:1.5rem;font-weight:600}.username{color:var(--text-secondary)}.logout-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:5px;cursor:pointer;transition:background .3s}.logout-btn:hover{background:var(--bg-secondary)}.projects-content{padding:2rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.project-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:border-color .3s,transform .2s;width:fit-content}.project-card:hover{border-color:var(--accent);transform:translateY(-2px)}.project-card h2{font-size:1.2rem;margin-bottom:.5rem}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.project-card-header h2{margin:0;flex:1}.project-actions{display:flex;gap:.5rem}.export-btn,.delete-btn{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s;opacity:.8;z-index:10;position:relative}.export-btn:hover,.delete-btn:hover{opacity:1;background:var(--bg-secondary);transform:scale(1.1)}.delete-btn{color:#e74c3c;font-size:.9rem;display:flex;align-items:center;gap:.25rem;font-weight:500}.delete-btn:hover{background:#e74c3c33;color:#c0392b}.project-role{font-size:.9rem;color:var(--text-secondary)}.new-project{border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;min-height:120px}.new-project:hover{border-color:var(--accent)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:2rem;width:90%;max-width:400px}.modal-content h2{margin-bottom:1.5rem}.modal-content form{display:flex;flex-direction:column;gap:1rem}.modal-content input{padding:.75rem;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem}.modal-content input:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;gap:1rem;margin-top:1rem}.modal-actions button{flex:1;padding:.75rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.modal-actions button[type=submit]{background:var(--accent);color:#fff}.modal-actions button[type=submit]:hover{background:var(--accent-hover)}.modal-actions button[type=button]{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.modal-actions button[type=button]:hover{background:var(--bg-secondary)}.error{color:#e74c3c;font-size:.9rem}.project-card{display:flex;flex-direction:column;padding:0;overflow:hidden}.project-poster-section{width:350px;height:450px;background:var(--bg-secondary);position:relative;flex-shrink:0}.poster-container{width:100%;height:100%;position:relative}.project-poster-image{width:100%;height:100%;object-fit:cover;display:block}.remove-poster-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.poster-container:hover .remove-poster-btn{opacity:1}.poster-upload-label{width:100%;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;border-bottom:1px solid var(--border-color)}.poster-upload-label:hover{background:var(--bg-hover)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-secondary)}.upload-icon{font-size:48px;opacity:.4}.upload-text{font-size:13px;font-weight:400;opacity:.7;margin-bottom:8px}.poster-options{display:flex;gap:8px}.poster-option-btn{padding:8px 16px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s}.poster-option-btn:hover{background:var(--bg-secondary);border-color:var(--accent);transform:translateY(-1px)}.project-card-content{padding:1.25rem;width:350px;display:flex;flex-direction:column;gap:.75rem;background:var(--card-bg)}.project-title{font-size:1.1rem;margin:0;font-weight:600;color:var(--text-primary);cursor:pointer;transition:color .2s}.project-title:hover{color:var(--accent)}.project-role{font-size:.85rem;color:var(--text-secondary);margin:0;text-transform:capitalize}.project-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border-color)}.action-btn{flex:1;padding:.5rem 1rem;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.action-btn:hover{background:var(--bg-secondary);border-color:var(--accent)}.action-btn.delete-btn{color:#fff;background:#e74c3c;border-color:#e74c3c}.action-btn.delete-btn:hover{background:#c0392b;border-color:#c0392b;color:#fff}.projects-grid{grid-template-columns:repeat(auto-fill,350px);justify-content:center;max-width:none}.ai-input{display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px}.ai-input input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.ai-input input:focus{outline:none;border-color:var(--accent)}.ai-input button{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:.9rem;transition:background .3s;white-space:nowrap}.ai-input button:hover:not(:disabled){background:var(--accent-hover)}.ai-input button:disabled{opacity:.5;cursor:not-allowed}.character-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.character-detail-panel{background:var(--card-bg);border-radius:12px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}.detail-section{margin-bottom:32px}.detail-section h3{margin:0 0 16px;color:var(--text-primary);font-size:18px;display:flex;align-items:center;gap:8px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{color:var(--text-secondary);font-size:14px;font-weight:500}.form-field input,.detail-section textarea{padding:12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:14px}.detail-section textarea{width:100%;resize:vertical}.form-field input:focus,.detail-section textarea:focus{outline:none;border-color:var(--accent-color, #4a90e2)}.section-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header-row h3{margin:0}.add-btn-small{padding:6px 12px;background:var(--accent-color, #4a90e2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.add-btn-small:hover{opacity:.9;transform:translateY(-1px)}.relationship-form,.beat-form{background:var(--bg-secondary);padding:16px;border-radius:8px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.relationship-form input,.relationship-form select,.beat-form input,.beat-form textarea{padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-primary);font-family:inherit;font-size:14px}.save-btn{padding:10px 20px;background:var(--accent-color, #4a90e2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.save-btn:hover{opacity:.9}.hint{color:var(--text-secondary);font-size:13px;margin:0}.relationships-list,.beats-list{display:flex;flex-direction:column;gap:12px}.relationship-item,.beat-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.relationship-info,.beat-info{flex:1}.relationship-info strong,.beat-info strong{color:var(--text-primary);display:block;margin-bottom:4px}.relationship-type{display:inline-block;padding:2px 8px;background:var(--accent-color, #4a90e2);color:#fff;border-radius:4px;font-size:12px;margin-left:8px}.relationship-info p,.beat-info p{color:var(--text-secondary);font-size:14px;margin:4px 0 0}.delete-btn-small{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:all .2s}.delete-btn-small:hover{background:#ff00001a}.empty-text{color:var(--text-secondary);font-style:italic;text-align:center;padding:20px}.checkbox-label{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:14px;cursor:pointer}.checkbox-label input[type=checkbox]{cursor:pointer}.panel-footer{display:flex;gap:12px;padding:24px;border-top:1px solid var(--border-color)}.save-btn-large{flex:1;padding:14px 24px;background:var(--accent-color, #4a90e2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .2s}.save-btn-large:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.save-btn-large:disabled{opacity:.6;cursor:not-allowed}.cancel-btn-large{padding:14px 24px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:16px;transition:all .2s}.cancel-btn-large:hover{background:var(--bg-hover)}.character-short-desc{color:var(--text-secondary);font-size:14px;margin:8px 0 0;line-height:1.4}.pronouns-badge,.age-badge{display:inline-block;padding:2px 8px;background:var(--accent-color, #4a90e2);color:#fff;border-radius:4px;font-size:12px;margin-left:8px;font-weight:400}.age-badge{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.panel-footer{flex-direction:column}}.role-legend-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.role-legend-panel{background:var(--card-bg);border-radius:12px;max-width:700px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.panel-header h2{margin:0;color:var(--text-primary);font-size:24px}.panel-content{flex:1;overflow-y:auto;padding:24px}.empty-state{text-align:center;padding:40px 20px}.empty-state p{color:var(--text-secondary);margin-bottom:20px}.add-defaults-btn{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s}.add-defaults-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.roles-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.role-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;display:flex;justify-content:space-between;align-items:center}.role-info{display:flex;align-items:center;gap:12px;flex:1}.role-color-indicator{width:40px;height:40px;border-radius:8px;border:2px solid var(--border-color);flex-shrink:0}.role-info strong{display:block;color:var(--text-primary);font-size:16px;margin-bottom:4px}.role-info p{color:var(--text-secondary);font-size:14px;margin:0}.role-actions{display:flex;gap:8px}.edit-btn,.delete-btn,.save-btn,.cancel-btn{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.edit-btn{background:var(--accent);color:#fff}.edit-btn:hover{opacity:.9}.delete-btn{background:#f44;color:#fff}.delete-btn:hover{background:#c00}.save-btn{background:#4caf50;color:#fff}.save-btn:hover{background:#45a049}.cancel-btn:hover{background:var(--card-bg)}.role-edit-form,.role-add-form{display:flex;flex-direction:column;gap:12px;width:100%}.role-edit-form input,.role-add-form input{padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-primary);font-size:14px}.role-edit-form input[type=color],.role-add-form input[type=color]{height:40px;cursor:pointer}.add-role-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:all .3s}.add-role-btn:hover{opacity:.9;transform:translateY(-1px)}.role-add-form{background:var(--bg-secondary);padding:20px;border-radius:8px;border:1px solid var(--border-color)}.role-add-form h3{color:var(--text-primary);margin:0 0 16px;font-size:18px}.color-picker-row{display:flex;align-items:center;gap:12px}.color-picker-row label{color:var(--text-primary);font-weight:500}.color-preview{width:30px;height:30px;border-radius:4px;border:2px solid var(--border-color)}.form-actions{display:flex;gap:8px;margin-top:8px}@media (max-width: 768px){.role-legend-panel{max-width:100%;max-height:90vh}.role-item{flex-direction:column;align-items:flex-start;gap:12px}}.merge-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.merge-modal{background:var(--card-bg);border-radius:12px;max-width:800px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}.merge-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.merge-modal-header h2{margin:0;color:var(--text-primary);font-size:24px}.close-btn{background:none;border:none;font-size:32px;cursor:pointer;color:var(--text-secondary);padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.merge-modal-content{flex:1;overflow-y:auto;padding:24px}.merge-hint{color:var(--text-secondary);margin-bottom:20px;font-size:14px}.merge-items{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.merge-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--bg-secondary)}.merge-item:hover{border-color:var(--accent);background:var(--bg-hover)}.merge-item.selected{border-color:var(--accent);background:var(--card-bg);box-shadow:0 0 0 3px #667eea1a}.merge-item input[type=radio]{width:20px;height:20px;cursor:pointer;margin-top:2px;accent-color:var(--accent);flex-shrink:0}.merge-item-content{flex:1}.merge-item-content strong{display:block;color:var(--text-primary);font-size:16px;margin-bottom:8px}.item-preview{color:var(--text-secondary);font-size:13px;line-height:1.4;margin:0}.merge-preview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:24px}.merge-preview h3{color:var(--text-primary);font-size:16px;margin:0 0 12px}.preview-content{display:flex;flex-direction:column;gap:8px}.preview-content strong{color:var(--text-primary);font-size:18px;margin-bottom:8px}.preview-field{display:flex;gap:8px;font-size:14px}.field-name{color:var(--text-secondary);font-weight:600;text-transform:capitalize;min-width:100px}.field-value{color:var(--text-primary);flex:1}.merge-modal-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color)}.merge-btn,.cancel-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s}.merge-btn{background:var(--accent);color:#fff}.merge-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.merge-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.cancel-btn:hover:not(:disabled){background:var(--bg-hover)}@media (max-width: 768px){.merge-modal{max-width:100%;max-height:95vh}.merge-modal-header,.merge-modal-content{padding:16px}.merge-modal-actions{flex-direction:column;padding:16px}}.section{max-width:1200px;margin:0 auto}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h2{font-size:1.8rem;font-weight:600}.add-btn{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.add-btn:hover{background:var(--accent-hover)}.section-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.utility-btn{background-color:#6c757d;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .3s}.utility-btn:hover{background-color:#5a6268}.mention-count{color:#6c757d;font-weight:400;font-size:.85rem}.pronouns-badge{background:var(--accent);color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;margin-left:.5rem}.section-form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.section-form input,.section-form textarea,.section-form select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;margin-bottom:1rem}.section-form input:focus,.section-form textarea:focus,.section-form select:focus{outline:none;border-color:var(--accent)}.section-form textarea{resize:vertical;min-height:100px}.section-list{display:flex;flex-direction:column;gap:1rem;align-items:stretch}.section-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;width:100%;gap:1rem}.item-header h3{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.new-badge{background:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;margin-left:.5rem}.item-actions{display:flex;gap:.5rem;flex-shrink:0}.item-actions button{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:5px;cursor:pointer;font-size:.9rem;transition:background .3s}.item-actions button:hover{background:var(--bg-secondary)}.item-actions .delete-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.item-content{color:var(--text-secondary);line-height:1.6;margin-top:.5rem;word-wrap:break-word;overflow-wrap:break-word}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem;font-style:italic}.item-header-left{display:flex;align-items:flex-start;justify-content:flex-start;gap:16px;flex:1;min-width:0;overflow:hidden}.item-header-left>div{flex:1 1 auto;min-width:0;border-left:1px solid rgba(255,255,255,.15);padding-left:12px}.item-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--accent);margin-top:4px;flex:0 0 20px}.character-controls{display:flex;gap:20px;margin-bottom:20px;padding:16px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;flex-wrap:wrap;align-items:center}.selection-controls{display:flex;gap:8px;margin-left:auto}.select-all-btn{padding:6px 12px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.select-all-btn:hover{background:var(--card-bg);border-color:var(--accent)}.filter-controls,.sort-controls{display:flex;align-items:center;gap:10px}.character-controls label{color:var(--text-primary);font-weight:500;font-size:14px}.character-controls select{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s}.character-controls select:hover{border-color:var(--accent)}.character-controls select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #667eea1a}.legend-btn{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s;margin-right:.5rem}.legend-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.character-role-indicator{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:8px;border:2px solid var(--card-bg);vertical-align:middle}.role-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:500;margin-left:8px;color:#fff;vertical-align:middle}.pronouns-badge{display:inline-block;background:var(--accent);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500;margin-left:.5rem;font-weight:400}.age-badge{display:inline-block;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.2rem .6rem;border-radius:12px;font-size:.75rem;margin-left:.5rem;font-weight:400}.character-short-desc{color:var(--text-secondary);font-size:14px;margin:8px 0 0;line-height:1.4;word-wrap:break-word;max-width:100%}.character-item-clickable:hover{background:var(--bg-hover);transform:translate(4px);transition:all .2s}.section-item.selected{background:var(--bg-hover);border-color:var(--accent);box-shadow:0 0 0 2px #667eea1a}.item-header-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0;overflow:hidden}.item-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--accent);margin-top:4px;flex-shrink:0}.selection-count{color:var(--accent);font-weight:600;font-size:14px;padding:6px 12px;background:#667eea1a;border-radius:4px}.merge-btn,.bulk-delete-btn,.deselect-btn{padding:6px 14px;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.merge-btn{background:var(--accent);color:#fff;border-color:var(--accent)}.merge-btn:hover{opacity:.9;transform:translateY(-1px)}.bulk-delete-btn{background:#e74c3c;color:#fff;border-color:#e74c3c}.bulk-delete-btn:hover{background:#c0392b;transform:translateY(-1px)}.deselect-btn{background:var(--bg-secondary);color:var(--text-primary)}.deselect-btn:hover{background:var(--card-bg);border-color:var(--accent)}@media (max-width: 768px){.character-controls{flex-direction:column;gap:12px}.filter-controls,.sort-controls{width:100%;justify-content:space-between}}.brainstorm-section{max-width:1200px;margin:0 auto}.section-header{margin-bottom:1.5rem}.section-header h2{margin-bottom:.5rem}.section-hint{font-size:.9rem;color:var(--text-secondary);font-style:italic;margin:0}.brainstorm-form{margin-bottom:2rem}.ai-section{display:flex;gap:1rem;margin-bottom:1rem}.ai-section input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem}.ai-section input:focus{outline:none;border-color:var(--accent)}.ai-section button{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s;white-space:nowrap}.ai-section button:hover:not(:disabled){background:var(--accent-hover)}.ai-section button:disabled{opacity:.5;cursor:not-allowed}.brainstorm-form form{display:flex;flex-direction:column;gap:1rem}.brainstorm-form textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical}.brainstorm-form textarea:focus{outline:none;border-color:var(--accent)}.brainstorm-form button{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s;align-self:flex-start}.brainstorm-form button:hover{background:var(--accent-hover)}.brainstorm-list{display:flex;flex-direction:column;gap:1rem}.brainstorm-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.brainstorm-content{flex:1;color:var(--text-primary);line-height:1.6;-webkit-user-select:text;user-select:text}.brainstorm-meta{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color)}.brainstorm-timestamp{font-size:.85rem;color:var(--text-secondary)}.brainstorm-actions{display:flex;gap:.5rem;align-items:center;position:relative}.brainstorm-item .send-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:5px;cursor:pointer;font-size:.9rem;transition:background .3s;white-space:nowrap}.brainstorm-item .send-btn:hover{background:var(--bg-secondary);border-color:var(--accent)}.send-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px;padding:.5rem 0;z-index:100;box-shadow:0 4px 6px #0000001a;min-width:150px}.send-menu-item{display:block;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:background .3s;font-size:.9rem}.send-menu-item:hover{background:var(--bg-secondary)}.brainstorm-item .delete-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:5px;cursor:pointer;font-size:.9rem;transition:background .3s;white-space:nowrap}.brainstorm-item .delete-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.context-menu{position:fixed;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px;padding:.5rem 0;z-index:1000;box-shadow:0 4px 6px #0000001a}.context-menu-title{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);margin-bottom:.5rem}.context-menu-item{display:block;width:100%;padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:background .3s}.context-menu-item:hover{background:var(--bg-secondary)}.empty-state{text-align:center;color:var(--text-secondary);padding:2rem;font-style:italic}.todos-section{max-width:1000px;margin:0 auto}.todo-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px}.todo-filters button{flex:1;padding:.6rem 1rem;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.todo-filters button.active{background:var(--accent);color:#fff}.todo-filters button:hover:not(.active){background:var(--bg-secondary);color:var(--text-primary)}.todo-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.todo-form .form-field{display:flex;flex-direction:column;gap:.5rem}.todo-form label{color:var(--text-primary);font-size:.9rem;font-weight:500}.todo-form select,.todo-form input[type=date]{padding:.6rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem}.todos-list{display:flex;flex-direction:column;gap:.75rem}.todo-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.todo-item:hover{box-shadow:0 2px 8px #0000001a}.todo-item.completed{opacity:.7;background:var(--bg-secondary)}.todo-checkbox{flex-shrink:0;padding-top:.2rem}.todo-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}.todo-content{flex:1;min-width:0}.todo-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.todo-header h3{margin:0;color:var(--text-primary);font-size:1rem;font-weight:600}.todo-header h3.strikethrough{text-decoration:line-through;opacity:.6}.todo-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.priority-badge{display:inline-block;padding:.25rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase}.due-date{font-size:.85rem;color:var(--text-secondary)}.todo-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.todo-actions{display:flex;gap:.5rem;flex-shrink:0}.todo-actions button{padding:.4rem .8rem;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.todo-actions .edit-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.todo-actions .delete-btn{color:#e74c3c;border-color:#e74c3c}.todo-actions .delete-btn:hover{background:#e74c3c;color:#fff}@media (max-width: 768px){.todo-item{flex-direction:column}.todo-actions{width:100%;justify-content:flex-end}.todo-form .form-row{grid-template-columns:1fr}}.smart-import-section{max-width:1200px;margin:0 auto}.smart-import-intro{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.smart-import-intro p{color:var(--text-primary);margin-bottom:1rem}.smart-import-intro ul{list-style:none;padding:0;margin:1rem 0}.smart-import-intro li{padding:.5rem 0;color:var(--text-primary)}.smart-import-intro .note{font-size:.9rem;color:var(--text-secondary);font-style:italic;margin-top:1rem}.upload-zone{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:2rem;text-align:center;margin-bottom:2rem;transition:all .3s}.upload-zone:hover{border-color:var(--accent);background:var(--card-bg)}.file-input-hidden{display:none}.file-upload-label{display:inline-block;padding:1rem 2rem;background:var(--accent);color:#fff;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s;margin-bottom:1rem}.file-upload-label:hover{background:var(--accent-hover);transform:translateY(-2px)}.file-upload-label .file-size{display:block;font-size:.85rem;opacity:.9;margin-top:.25rem}.analyze-btn{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s;margin-top:1rem}.analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.analyze-btn:disabled{opacity:.6;cursor:not-allowed}.progress-message{text-align:center;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--accent);font-weight:500;margin-bottom:1rem;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.error-message{text-align:center;padding:1rem;background:#ffe5e5;border:1px solid #ff6b6b;border-radius:8px;color:#c92a2a;font-weight:500;margin-bottom:1rem}.extracted-data{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.data-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.data-header h3{color:var(--text-primary);font-size:1.5rem}.import-all-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s}.import-all-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.import-all-btn:disabled{opacity:.6;cursor:not-allowed}.data-category{margin-bottom:2rem;padding:1rem;background:var(--bg-secondary);border-radius:8px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.category-header h4{color:var(--text-primary);font-size:1.2rem;margin:0}.select-btn{padding:.4rem .8rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.select-btn:hover{background:var(--card-bg);border-color:var(--accent);color:var(--accent)}.category-header button{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s}.category-header button:hover:not(:disabled){background:var(--accent-hover)}.category-header button:disabled{opacity:.5;cursor:not-allowed}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.extracted-item{background:var(--card-bg);border:2px solid var(--border-color);border-radius:6px;padding:0;transition:all .3s;cursor:pointer}.extracted-item.selected{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 0 0 3px #667eea1a}.extracted-item:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.item-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;padding:1rem;width:100%}.item-checkbox input[type=checkbox]{flex-shrink:0;width:20px;height:20px;cursor:pointer;margin-top:.1rem;accent-color:var(--accent)}.item-content{flex:1}.extracted-item strong{display:block;color:var(--text-primary);font-size:1rem;margin-bottom:.5rem}.extracted-item p{color:var(--text-secondary);font-size:.9rem;line-height:1.4;margin:.5rem 0 0}.item-badge{display:inline-block;background:var(--accent);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500;margin-left:.5rem}@media (max-width: 768px){.items-grid{grid-template-columns:1fr}.data-header,.category-header{flex-direction:column;gap:1rem;align-items:flex-start}.upload-zone{padding:1rem}}.scene-builder{max-width:100%;margin:0 auto;padding:1rem}.scene-builder-header{margin-bottom:2rem}.scene-builder-header h2{font-size:1.8rem;font-weight:600;margin-bottom:1rem}.board-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.board-selector button{padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-primary);border-radius:5px;cursor:pointer;font-size:.9rem;transition:all .3s}.board-selector button:hover{background:var(--bg-secondary);border-color:var(--accent)}.board-selector button.active,.add-episode-btn,.export-scenes-btn{background:var(--accent);color:#fff;border-color:var(--accent)}.add-episode-btn:hover,.export-scenes-btn:hover{background:var(--accent-hover)}.scene-form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.scene-form input,.scene-form textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;margin-bottom:1rem}.scene-form input:focus,.scene-form textarea:focus{outline:none;border-color:var(--accent)}.scene-form textarea{resize:vertical;min-height:80px}.corkboard-container{width:100%;height:calc(100vh - 400px);min-height:600px;overflow:auto;position:relative;margin-bottom:2rem;border:2px solid var(--border-color);border-radius:8px;background:#d4a574;background-image:repeating-linear-gradient(0deg,transparent,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 21px),repeating-linear-gradient(90deg,transparent,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 21px);box-shadow:inset 0 0 20px #0000001a}.corkboard{position:relative;width:100%;height:100%;min-width:2000px;min-height:2000px}.scene-card-corkboard{position:absolute;width:250px;min-height:150px;background:#fff9c4;border:1px solid rgba(0,0,0,.2);border-radius:8px;cursor:grab;box-shadow:0 2px 4px #0003,0 0 0 1px #0000000d;transition:transform .2s,box-shadow .2s;transform-origin:top left;overflow:hidden;padding:0}.scene-card-stripes{position:absolute;top:0;left:0;right:0;width:100%;height:15px;display:block;border-radius:8px 8px 0 0;overflow:hidden;z-index:1}.scene-card-color-strip{height:100%;cursor:pointer;transition:height .2s;width:100%;display:block}.scene-card-color-strip.stripe-color{width:100%;height:100%;border:none;border-radius:8px 8px 0 0;box-shadow:inset 0 -1px #0000001a}.scene-card-color-strip.main-color{display:none}.scene-card-stripes:hover{height:18px}.scene-card-color-strip:hover{opacity:.8}.scene-card-corkboard:active{cursor:grabbing;transform:rotate(.5deg);box-shadow:0 4px 8px #0000004d,0 0 0 1px #0000001a}.scene-card-corkboard:hover{transform:rotate(-.5deg) scale(1.02);box-shadow:0 4px 8px #00000040,0 0 0 1px #0000001a;z-index:10}.scene-card-corkboard:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:16px;height:16px;background:radial-gradient(circle,silver,gray);border-radius:50%;box-shadow:0 2px 4px #0000004d}.scene-card-header{display:flex;justify-content:space-between;align-items:start;margin:20px 1rem .5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.1);pointer-events:auto;position:relative;z-index:2}.scene-number{font-weight:600;font-size:.85rem;color:#666;background:#0000000d;padding:.2rem .5rem;border-radius:3px}.scene-heading{font-size:1rem;font-weight:600;margin:.5rem 0;color:#333;line-height:1.3}.scene-card-drag-handle{cursor:grab;flex:1;padding:0 1rem 1rem;position:relative;z-index:2}.scene-card-drag-handle:active{cursor:grabbing}.scene-card-actions{display:flex;gap:.25rem;pointer-events:auto;z-index:10;position:relative}.scene-card-actions button{padding:.2rem .4rem;background:transparent;border:1px solid rgba(0,0,0,.2);color:#333;border-radius:3px;cursor:pointer;font-size:.7rem;transition:background .2s;pointer-events:auto}.scene-card-actions button:hover{background:#0000001a}.scene-card-actions .delete-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.scene-card-description{font-size:.85rem;color:#555;line-height:1.4;margin:.5rem 0 0;word-wrap:break-word}.add-scene-btn{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.add-scene-btn:hover{background:var(--accent-hover)}.form-actions{display:flex;gap:1rem}.form-actions button{padding:.75rem 1.5rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.form-actions button[type=button]{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.form-actions button[type=button]:hover{background:var(--bg-secondary)}.color-selector{margin-bottom:1rem}.color-selector label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.color-options{display:flex;gap:.5rem;flex-wrap:wrap}.color-option{width:40px;height:40px;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:border-color .2s,transform .2s}.color-option:hover{transform:scale(1.1);border-color:var(--accent)}.color-option.selected{border-color:var(--accent);border-width:3px}.stripe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.legend-btn{background:var(--accent);color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.legend-btn:hover{background:var(--accent-hover)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:#fff;border-radius:8px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 12px #0000004d;position:relative;z-index:10001;color:#333}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #eee}.modal-header h3{margin:0;color:#333!important;font-weight:700}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.modal-body{padding:1rem;color:#333!important}.legend-items{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.legend-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:4px;background:#f8f9fa;margin-bottom:.25rem;cursor:pointer;transition:background .3s}.legend-item:hover{background:#e9ecef}.legend-item span{color:#333!important;font-weight:500}.edit-icon{margin-left:auto;opacity:.6;font-size:.9rem}.legend-item:hover .edit-icon{opacity:1}.legend-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.add-legend-btn{background:var(--accent);color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.add-legend-btn:hover{background:var(--accent-hover)}.legend-edit-form{background:#f0f8ff;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #cce7ff}.legend-edit-form .form-actions{display:flex;gap:.5rem;margin-top:.75rem}.color-input{width:60px;height:40px;border:1px solid #ddd;border-radius:4px;cursor:pointer;margin-right:.75rem}.label-input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.save-btn{background:#28a745;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem}.save-btn:hover{background:#218838}.cancel-btn{background:#6c757d;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem}.cancel-btn:hover{background:#5a6268}.empty-legend{color:#6c757d;font-style:italic;text-align:center;padding:1rem;background:#f8f9fa;border-radius:4px}.legend-color{width:20px;height:20px;border-radius:3px;border:1px solid rgba(0,0,0,.2)}.legend-note{margin-top:1rem;padding:.75rem;background:#f8f9fa;border-radius:4px;font-size:.9rem;color:#666}.modal-footer{padding:1rem;border-top:1px solid #eee;display:flex;justify-content:flex-end}.modal-footer button{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.modal-footer button:hover{background:var(--accent-hover)}.color-picker{position:absolute;top:15px;right:10px;background:#fff;border:1px solid rgba(0,0,0,.2);border-radius:4px;padding:.5rem;box-shadow:0 2px 8px #0003;z-index:100;display:flex;gap:.25rem;flex-wrap:wrap;width:120px}.color-picker-option{width:20px;height:20px;border:1px solid rgba(0,0,0,.2);border-radius:2px;cursor:pointer;transition:transform .1s}.color-picker-option:hover{transform:scale(1.2)}@media (prefers-color-scheme: dark){.corkboard-container{background:#8b6f47;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.1) 2px,rgba(0,0,0,.1) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.1) 2px,rgba(0,0,0,.1) 4px)}.scene-card-corkboard{background:#fff9c4;border-color:#d4c68a}.scene-heading{color:#222}.scene-card-description{color:#444}}.rich-text-editor{border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);min-height:200px}.rich-text-toolbar{display:flex;gap:.25rem;padding:.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-wrap:wrap;align-items:center}.toolbar-btn{padding:.375rem .75rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:3px;cursor:pointer;font-size:.875rem;transition:background .2s;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover{background:var(--bg-hover)}.toolbar-btn:active{background:var(--accent);color:#fff}.toolbar-separator{width:1px;height:24px;background:var(--border-color);margin:0 .25rem}.rich-text-content{padding:1rem;min-height:150px;outline:none;color:var(--text-primary);line-height:1.6}.rich-text-content:empty:before{content:attr(data-placeholder);color:var(--text-secondary);opacity:.6}.rich-text-content ul,.rich-text-content ol{margin:.5rem 0;padding-left:2rem}.rich-text-content h3{margin:1rem 0 .5rem;font-size:1.25rem;font-weight:600}.rich-text-content p{margin:.5rem 0}.rich-text-content strong{font-weight:600}.rich-text-content em{font-style:italic}.rich-text-content u{text-decoration:underline}.bracket-tag{background:#4a90e233;border:1px solid rgba(74,144,226,.4);border-radius:3px;padding:2px 4px;font-family:monospace;font-size:.9em;cursor:help}.bracket-tag:hover{background:#4a90e24d;border-color:#4a90e299}.files-links-section{max-width:1200px;margin:0 auto}.tab-navigation{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid var(--border-color)}.tab-navigation button{background:none;border:none;padding:.75rem 1rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .3s;font-weight:500;color:var(--text-primary)}.tab-navigation button:hover{background:var(--bg-secondary)}.tab-navigation button.active{border-bottom-color:var(--accent);color:var(--accent);background:#667eea1a}.category-filter{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.category-filter button{background:var(--bg-secondary);border:1px solid var(--border-color);padding:.5rem .75rem;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .3s;color:var(--text-primary)}.category-filter button:hover{background:var(--border-color)}.category-filter button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.section-form{background:var(--bg-secondary);padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid var(--border-color)}.form-row{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.form-row input,.form-row textarea,.form-row select{flex:1;min-width:200px;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;background:var(--card-bg);color:var(--text-primary)}.form-row textarea{resize:vertical}.file-input{min-width:300px!important}.checkbox-label{display:flex;align-items:center;gap:.5rem;white-space:nowrap;flex:0 0 auto;color:var(--text-primary)}.checkbox-label input[type=checkbox]{flex:none!important;min-width:auto!important;width:auto!important}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.form-actions button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background .3s}.form-actions button[type=submit]{background:var(--accent);color:#fff}.form-actions button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}.form-actions button[type=submit]:disabled{background:#ccc;cursor:not-allowed}.form-actions button[type=button]{background:#6c757d;color:#fff}.form-actions button[type=button]:hover{background:#5a6268}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.file-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .3s;display:flex;flex-direction:column;box-shadow:0 2px 4px #0000001a}.file-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.file-icon{font-size:2rem;text-align:center;margin-bottom:.5rem}.file-info{flex:1}.file-info h4{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary);word-break:break-word}.file-size{color:var(--text-secondary);font-size:.85rem;margin:0 0 .5rem}.file-description{color:var(--text-secondary);font-size:.9rem;margin:0 0 .5rem;line-height:1.4}.file-meta{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-secondary);margin-bottom:1rem}.file-actions{display:flex;gap:.5rem;justify-content:flex-end}.file-actions button{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .3s}.download-btn:hover{background:#28a7451a}.delete-btn:hover{background:#dc35451a}.links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-top:1rem}.link-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .3s;display:flex;flex-direction:column;box-shadow:0 2px 4px #0000001a}.link-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.link-content{display:flex;gap:1rem;flex:1}.link-thumbnail{width:60px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}.link-info{flex:1}.link-title{margin:0 0 .5rem;font-size:1rem;color:var(--accent);cursor:pointer;text-decoration:none;transition:color .3s}.link-title:hover{color:var(--accent-hover);text-decoration:underline}.link-url{color:var(--text-secondary);font-size:.85rem;margin:0 0 .5rem;word-break:break-all}.link-description{color:var(--text-secondary);font-size:.9rem;margin:0 0 .5rem;line-height:1.4}.link-meta{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-secondary);margin-bottom:1rem}.link-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:auto}.link-actions button{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .3s}.edit-btn:hover{background:#ffc1071a}.categories-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.category-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center;transition:all .3s;box-shadow:0 2px 4px #0000001a}.category-item:hover{box-shadow:0 4px 8px #00000026}.category-info h4{margin:0 0 .5rem;color:var(--text-primary)}.category-info p{margin:0 0 .5rem;color:var(--text-secondary);font-size:.9rem}.category-stats{display:flex;gap:1rem;font-size:.85rem;color:var(--text-secondary)}.category-actions{display:flex;gap:.5rem}.category-actions button{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .3s}.category-tag{background:var(--accent);color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.empty-message{text-align:center;color:var(--text-secondary);font-style:italic;padding:2rem;background:var(--bg-secondary);border-radius:8px;margin-top:1rem}@media (max-width: 768px){.files-grid,.links-grid{grid-template-columns:1fr}.form-row{flex-direction:column;align-items:stretch}.form-row input,.form-row textarea,.form-row select{min-width:auto}.category-filter{justify-content:center}.category-item{flex-direction:column;align-items:flex-start;gap:1rem}.link-content{flex-direction:column;gap:.5rem}.link-thumbnail{align-self:center;width:80px;height:80px}}.fountain-preview{height:100%;overflow-y:auto;background-color:var(--bg-secondary);padding:20px}.preview-page{max-width:8.5in;min-height:11in;margin:0 auto;background-color:var(--bg-primary);padding:1in 1.5in;box-shadow:0 2px 8px #0000001a}.preview-content{font-family:Courier New,Courier,monospace;font-size:12pt;line-height:1.5;color:var(--text-primary)}.fountain-screenplay{color:var(--text-primary)}.fountain-screenplay .scene-heading{font-weight:700;text-transform:uppercase;margin:1.5em 0 1em;font-size:12pt}.fountain-screenplay .character{text-transform:uppercase;margin:1em 0 0 2.5in;font-size:12pt}.fountain-screenplay .dialogue{margin:0 0 0 1.5in;max-width:3.5in;font-size:12pt}.fountain-screenplay .parenthetical{margin:0 0 0 2in;max-width:2in;font-size:12pt}.fountain-screenplay .action{margin:1em 0;font-size:12pt;white-space:pre-wrap}.fountain-screenplay .transition{text-align:right;text-transform:uppercase;margin:1em 0;font-size:12pt}.empty-preview{text-align:center;color:var(--text-secondary);padding:2em;font-style:italic}.preview-error{text-align:center;color:var(--error);padding:2em}.fountain-screenplay strong{font-weight:700}.fountain-screenplay em{font-style:italic}.fountain-screenplay u{text-decoration:underline}[data-theme=dark] .preview-page{background-color:#1a1a1a;color:#fff}[data-theme=light] .preview-page{background-color:#fff;color:#000}.scene-list-container{display:flex;flex-direction:column;height:100%;background-color:var(--bg-secondary);border-left:1px solid var(--border)}.scene-list-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-bottom:1px solid var(--border);background-color:var(--bg-tertiary)}.scene-list-header h3{margin:0;font-size:14px;color:var(--text-primary)}.sync-btn{padding:6px 12px;background-color:var(--primary);color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:opacity .2s}.sync-btn:hover{opacity:.9}.scene-list{flex:1;overflow-y:auto;padding:8px}.scene-list-item{display:flex;gap:8px;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:6px;margin-bottom:8px;transition:all .2s}.scene-list-item:hover{box-shadow:0 2px 4px #0000001a}.scene-drag-handle{display:flex;align-items:center;padding:8px;cursor:grab;color:var(--text-secondary);-webkit-user-select:none;user-select:none;font-size:16px}.scene-drag-handle:active{cursor:grabbing}.scene-info{flex:1;padding:8px 12px 8px 0;cursor:pointer}.scene-number{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;margin-bottom:4px}.scene-heading{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;font-family:Courier New,Courier,monospace}.scene-preview{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-list-footer{padding:12px 15px;border-top:1px solid var(--border);background-color:var(--bg-tertiary)}.scene-list-footer .hint{margin:0;font-size:11px;color:var(--text-secondary);text-align:center}.scene-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:30px;text-align:center}.scene-list-empty p{margin:8px 0;color:var(--text-secondary);font-size:13px}.scene-list-empty .example{font-family:Courier New,Courier,monospace;font-weight:600;color:var(--text-primary);background-color:var(--bg-tertiary);padding:8px 16px;border-radius:4px;margin-top:12px}.fountain-editor-container{display:flex;flex-direction:column;height:100%;background-color:var(--bg-primary)}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border)}.toolbar-left button{padding:8px 16px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.toolbar-left button:hover{background-color:var(--bg-hover)}.toolbar-left button.active{background-color:var(--primary);color:#fff;border-color:var(--primary)}.toolbar-right{display:flex;align-items:center;gap:10px}.save-status{font-size:13px;color:var(--text-secondary);font-style:italic}.editor-content{display:flex;flex:1;overflow:hidden}.editor-content.split-view .editor-pane{width:50%;border-right:1px solid var(--border)}.editor-content.split-view .preview-pane{width:50%}.scene-list-pane{width:300px;min-width:250px;max-width:400px}.editor-pane{position:relative;width:100%;height:100%}.preview-pane{width:100%;height:100%;overflow:auto}.fountain-textarea{width:100%;height:100%;padding:20px;background-color:var(--bg-primary);color:var(--text-primary);border:none;resize:none;font-family:Courier New,Courier,monospace;font-size:12pt;line-height:1.5;outline:none}.fountain-textarea::placeholder{color:var(--text-secondary);opacity:.5}.autocomplete-dropdown{position:absolute;z-index:1000;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:400px;max-height:300px;overflow-y:auto}.autocomplete-header{padding:8px 12px;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.autocomplete-item{padding:10px 12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border);transition:background-color .1s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.selected{background-color:var(--bg-hover)}.autocomplete-item.selected{border-left:3px solid var(--primary)}.entity-name{font-weight:600;color:var(--text-primary);font-size:14px}.entity-meta{font-size:12px;color:var(--text-secondary)}.autocomplete-hint{padding:6px 12px;background-color:var(--bg-tertiary);border-top:1px solid var(--border);font-size:11px;color:var(--text-secondary);text-align:center}[data-theme=dark] .fountain-textarea{background-color:#000;color:#fff}[data-theme=light] .fountain-textarea{background-color:#fff;color:#000}.fountain-textarea::-webkit-scrollbar{width:12px}.fountain-textarea::-webkit-scrollbar-track{background:var(--bg-secondary)}.fountain-textarea::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:6px}.fountain-textarea::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.screenwriting-section{display:flex;height:100%;overflow:hidden}.screenwriting-sidebar{width:300px;background-color:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid var(--border);background-color:var(--bg-tertiary)}.sidebar-header h3{margin:0;font-size:16px;color:var(--text-primary)}.sidebar-actions{display:flex;gap:8px}.btn-icon{background:none;border:1px solid var(--border);padding:4px 8px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-icon:hover{background-color:var(--bg-hover)}.sidebar-form{padding:15px;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border)}.sidebar-form h4{margin:0 0 10px;font-size:14px;color:var(--text-primary)}.sidebar-form input,.sidebar-form select,.sidebar-form textarea{width:100%;padding:8px;margin-bottom:8px;background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;font-size:13px}.sidebar-form textarea{resize:vertical;font-family:inherit}.sidebar-form .form-actions{display:flex;gap:8px}.sidebar-form button{flex:1;padding:6px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.sidebar-form button[type=submit]{background-color:var(--primary);color:#fff;border:none}.sidebar-form button[type=button]{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border)}.seasons-tree{flex:1;overflow-y:auto;padding:10px}.season-item{margin-bottom:10px}.season-header{display:flex;align-items:center;gap:8px;padding:8px;background-color:var(--bg-tertiary);border-radius:4px;cursor:pointer;transition:background-color .2s}.season-header:hover{background-color:var(--bg-hover)}.expand-icon{font-size:16px}.season-name{flex:1;font-weight:600;font-size:14px;color:var(--text-primary)}.screenplay-count{font-size:12px;color:var(--text-secondary)}.season-screenplays{margin-left:20px;margin-top:5px}.screenplay-with-scenes{margin-bottom:4px}.screenplay-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;margin-bottom:2px;background-color:var(--bg-primary);border-radius:4px;transition:all .2s}.screenplay-item:hover{background-color:var(--bg-hover)}.screenplay-item.active{background-color:var(--primary);color:#fff}.screenplay-header{display:flex;align-items:center;gap:6px;flex:1;cursor:pointer}.expand-icon-small{font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.screenplay-title{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-count-badge{font-size:11px;color:var(--text-secondary);margin-left:4px}.screenplay-item.active .scene-count-badge{color:#ffffffb3}.btn-delete-small{background:none;border:none;padding:2px 4px;cursor:pointer;opacity:.6;transition:opacity .2s}.btn-delete-small:hover{opacity:1}.screenplay-item.active .btn-delete-small{opacity:.8}.scene-list-tree{margin-left:32px;margin-top:4px;margin-bottom:8px}.scene-tree-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background-color:var(--bg-tertiary);border-radius:4px;margin-bottom:2px;cursor:pointer;transition:all .2s}.scene-tree-item:hover{background-color:var(--bg-hover)}.scene-icon{font-size:12px}.scene-text{font-size:12px;font-family:Courier New,Courier,monospace;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-scenes-hint{margin-left:32px;padding:8px 10px;font-size:11px;color:var(--text-secondary);font-style:italic}.empty-state{text-align:center;padding:30px 20px;color:var(--text-secondary)}.empty-state p{margin:8px 0;font-size:13px}.screenwriting-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.screenplay-header{display:flex;align-items:center;gap:12px;padding:15px 20px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border)}.screenplay-header h2{margin:0;font-size:18px;color:var(--text-primary)}.season-badge{padding:4px 8px;background-color:var(--primary);color:#fff;border-radius:4px;font-size:12px;font-weight:600}.editor-actions{padding:10px 15px;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border)}.check-entities-btn{padding:8px 16px;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s}.check-entities-btn:hover{background-color:var(--bg-hover);border-color:var(--primary)}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px;color:var(--text-secondary)}.no-selection h2{margin:0 0 16px;color:var(--text-primary)}.no-selection p{margin:8px 0;font-size:14px}.no-selection .hint{margin-top:24px;font-style:italic;opacity:.7}.entity-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.entity-dialog{background-color:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:24px;max-width:500px;width:90%;box-shadow:0 4px 16px #0003}.entity-dialog h3{margin:0 0 16px;color:var(--text-primary);font-size:18px}.entity-dialog p{margin:8px 0;color:var(--text-secondary);line-height:1.5}.entity-dialog strong{color:var(--text-primary);font-weight:600}.dialog-actions{display:flex;gap:12px;margin-top:24px}.dialog-actions button{flex:1;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:var(--primary);color:#fff;border:none}.btn-primary:hover{opacity:.9}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--bg-hover)}.custom-section-manager-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.custom-section-manager{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;width:90%;max-width:600px;max-height:80vh;overflow:auto;box-shadow:0 4px 20px #0000004d}.manager-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.manager-header h2{margin:0;font-size:1.5rem}.manager-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.manager-header button:hover{color:var(--text-primary);background:var(--bg-hover);border-radius:4px}.manager-content{padding:1.5rem}.create-section-btn{width:100%;padding:1rem;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.create-section-btn:hover{background:var(--accent-hover)}.create-section-form{margin-bottom:2rem}.create-section-form input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;margin-bottom:1rem;background:var(--bg-primary);color:var(--text-primary)}.form-actions{display:flex;gap:.5rem}.form-actions button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.875rem}.form-actions button[type=submit]{background:var(--accent);color:#fff;border-color:var(--accent)}.form-actions button[type=submit]:hover{background:var(--accent-hover)}.form-actions button[type=button]{background:var(--bg-secondary);color:var(--text-primary)}.sections-list h3{margin:0 0 1rem;font-size:1.125rem}.sections-list ul{list-style:none;padding:0;margin:0}.sections-list li{padding:.75rem;border:1px solid var(--border-color);border-radius:4px;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.section-name{color:var(--text-secondary);font-size:.875rem;font-family:monospace}.no-sections{color:var(--text-secondary);font-style:italic;text-align:center;padding:2rem}.members-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.members-panel{background:var(--card-bg);border-radius:8px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.members-panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.members-panel-header h2{margin:0;font-size:1.5em}.close-btn{background:none;border:none;font-size:1.5em;cursor:pointer;color:var(--text-secondary);padding:5px 10px}.close-btn:hover{color:var(--accent)}.members-panel-content{padding:20px;overflow-y:auto;flex:1}.project-info{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.project-info h3{margin:0 0 5px;color:var(--accent)}.project-info p{margin:0;color:var(--text-secondary);font-size:.9em}.invite-section{margin-bottom:30px;padding:20px;background:var(--primary-bg);border-radius:8px}.invite-section h4{margin:0 0 15px}.invite-form{display:flex;gap:10px}.invite-form input{flex:1;padding:10px;border:1px solid var(--border-color);border-radius:4px;font-size:1em}.invite-form button{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1em;white-space:nowrap}.members-list-section h4{margin:0 0 15px}.members-list{display:flex;flex-direction:column;gap:10px}.member-card{display:flex;justify-content:space-between;align-items:center;padding:15px;background:var(--primary-bg);border-radius:8px;border:1px solid var(--border-color)}.member-info{display:flex;flex-direction:column;gap:5px}.member-name{font-weight:600;font-size:1.1em}.member-role{font-size:.9em;color:var(--text-secondary)}.member-actions{display:flex;gap:10px}.remove-btn{padding:6px 12px;background:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9em}.remove-btn:hover{background:#c0392b}.no-members{color:var(--text-secondary);font-style:italic;text-align:center;padding:20px}.workspace{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column}.workspace-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-size:1.5rem;font-weight:600}.active-users{font-size:.9rem;color:var(--text-secondary)}.header-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:5px;cursor:pointer;font-size:1.2rem;transition:background .3s}.theme-toggle:hover{background:var(--bg-secondary)}.file-menu{position:relative}.file-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:5px;cursor:pointer;transition:background .3s}.file-btn:hover{background:var(--bg-secondary)}.file-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px;min-width:150px;z-index:100;padding-top:.5rem;display:flex;flex-direction:column;box-shadow:0 4px 6px #0000001a}.file-dropdown button,.file-dropdown label{padding:.75rem 1rem;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:background .3s}.file-dropdown button:hover,.file-dropdown label:hover{background:var(--bg-secondary)}.file-import-btn{display:block}.share-menu-container{position:relative}.share-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:5px;cursor:pointer;transition:background .3s}.share-btn:hover{background:var(--bg-secondary)}.share-menu{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:5px;min-width:300px;max-width:400px;z-index:100;padding:1rem;box-shadow:0 4px 6px #0000001a}.share-menu-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.share-menu-section:last-child{border-bottom:none;margin-bottom:0}.share-menu-section h4{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.credentials-info{font-size:.9rem}.credentials-info p{margin:.5rem 0}.credentials-note{font-size:.85rem;color:var(--text-secondary);font-style:italic}.invite-form{display:flex;gap:.5rem}.invite-form input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.invite-form input:focus{outline:none;border-color:var(--accent)}.invite-form button{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:.9rem;transition:background .3s}.invite-form button:hover{background:var(--accent-hover)}.members-header{display:flex;justify-content:space-between;align-items:center}.toggle-btn{padding:.25rem .5rem;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:3px;cursor:pointer;font-size:.85rem;transition:background .3s}.toggle-btn:hover{background:var(--bg-secondary)}.members-list{margin-top:.5rem;max-height:200px;overflow-y:auto}.member-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.member-item:last-child{border-bottom:none}.member-actions{display:flex;align-items:center;gap:.5rem}.member-role{font-size:.85rem;color:var(--text-secondary);text-transform:capitalize}.remove-member-btn{padding:.25rem .5rem;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:3px;cursor:pointer;font-size:.8rem;transition:background .3s}.remove-member-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.workspace-body{display:flex;flex:1;overflow:hidden}.workspace-nav{width:200px;border-right:1px solid var(--border-color);padding:1rem 0;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.workspace-nav button{padding:.75rem 1rem;background:transparent;border:none;color:var(--text-secondary);text-align:left;cursor:pointer;transition:all .3s;border-left:3px solid transparent}.workspace-nav button:hover{color:var(--text-primary);background:var(--bg-secondary)}.workspace-nav button.active{color:var(--text-primary);border-left-color:var(--accent);background:var(--bg-secondary)}.workspace-nav button.add-section-btn{background:var(--accent);color:#fff;border:none;margin-top:auto;font-weight:500;border-left:none}.workspace-nav button.add-section-btn:hover{background:var(--accent-hover)}.workspace-main{flex:1;overflow-y:auto;padding:2rem}.project-info-panel{display:flex;gap:2rem;padding:2rem;background:var(--card-bg);border-bottom:1px solid var(--border-color);align-items:flex-start}.poster-section{flex-shrink:0}.poster-container{position:relative;width:200px;height:300px;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #00000026}.project-poster{width:100%;height:100%;object-fit:cover;display:block}.remove-poster-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-poster-btn:hover{background:#e74c3c;transform:scale(1.1)}.poster-upload-box{width:200px;height:300px;border:2px dashed var(--border-color);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;background:var(--bg-secondary)}.poster-upload-box:hover{border-color:var(--accent);background:var(--bg-hover)}.upload-content{text-align:center;padding:1rem}.upload-icon{font-size:48px;display:block;margin-bottom:12px}.upload-content p{color:var(--text-primary);margin:8px 0;font-weight:500}.upload-hint{color:var(--text-secondary);font-size:12px;display:block}.project-actions{flex:1;display:flex;flex-direction:column;gap:1.5rem}.project-actions h3{color:var(--text-primary);font-size:28px;font-weight:600;margin:0}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap}.action-btn{padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s;display:inline-flex;align-items:center;gap:8px}.export-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.export-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.delete-btn{background:#e74c3c;color:#fff}.delete-btn:hover{background:#c0392b;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c66}@media (max-width: 768px){.project-info-panel{flex-direction:column;align-items:center}.poster-section{width:100%;display:flex;justify-content:center}.project-actions{width:100%;align-items:center;text-align:center}.action-buttons{justify-content:center}}.main-layout{width:100%;min-height:100vh}.monitor-toggle{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:#007bff;color:#fff;border:none;cursor:pointer;font-size:20px;box-shadow:0 2px 10px #0003;z-index:1000;display:flex;align-items:center;justify-content:center;position:relative}.monitor-toggle:hover{background:#0056b3;transform:scale(1.1)}.monitor-badge{position:absolute;top:-5px;right:-5px;background:#f44;color:#fff;border-radius:50%;width:20px;height:20px;font-size:12px;display:flex;align-items:center;justify-content:center;font-weight:700}.monitor-panel{position:fixed;bottom:80px;right:20px;width:500px;max-height:600px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;z-index:1001;display:flex;flex-direction:column;overflow:hidden}.monitor-header{padding:15px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.monitor-header h3{margin:0;font-size:18px}.monitor-controls{display:flex;gap:10px;align-items:center}.monitor-controls label{display:flex;align-items:center;gap:5px;font-size:12px}.monitor-controls button{padding:5px 10px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:12px}.monitor-controls button:hover{background:#f0f0f0}.monitor-stats{padding:15px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;border-bottom:1px solid #eee}.stat-item{display:flex;justify-content:space-between;padding:8px;background:#f8f9fa;border-radius:4px}.stat-label{font-size:12px;color:#666}.stat-value{font-weight:700;font-size:14px}.monitor-section{padding:15px;border-bottom:1px solid #eee;overflow-y:auto}.monitor-section h4{margin:0 0 10px;font-size:14px}.request-list{display:flex;flex-direction:column;gap:10px}.request-item{padding:10px;border:1px solid #ddd;border-radius:4px;background:#f8f9fa}.request-item.stuck{border-color:#f44;background:#fff5f5}.request-item.warning{border-color:#fa0;background:#fffbf0}.request-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.request-status{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase}.request-age{font-size:12px;font-weight:700;color:#666}.request-details{font-size:12px;color:#555}.request-details div{margin:4px 0}.request-details strong{color:#333}.monitor-empty{padding:30px;text-align:center;color:#999;font-size:14px}.app{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root[data-theme=dark]{--bg-primary: #000000;--bg-secondary: #1a1a1a;--text-primary: #ffffff;--text-secondary: #cccccc;--border-color: #333333;--accent: #667eea;--accent-hover: #5568d3;--card-bg: #1a1a1a}:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--text-primary: #000000;--text-secondary: #333333;--border-color: #dddddd;--accent: #667eea;--accent-hover: #5568d3;--card-bg: #ffffff}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh}
