:root,[data-theme=brand]{--bg-base: #1A1714;--bg-elevated: #3F3830;--bg-surface: #958870;--bg-surface-elevated: #BFB09C;--bg-input: #E8DFD0;--text-primary: #E8DFD0;--text-secondary: #BFB09C;--text-disabled: #78716C;--text-inverse: #1F1C1A;--accent-primary: #A89880;--accent-hover: #BFB09C;--accent-active: #D4C8B8;--border-default: #504840;--border-subtle: #403830;--border-strong: #605848;--success: #4ADE80;--warning: #FBBF24;--error: #F87171;--info: #60A5FA;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--diff-added-bg: rgba(74, 222, 128, .3);--diff-added-border: #22c55e;--diff-removed-bg: rgba(248, 113, 113, .3);--diff-removed-border: #ef4444}[data-theme=light]{--bg-base: #FFFFFF;--bg-elevated: #FFFFFF;--bg-surface: #F5F5F5;--bg-surface-elevated: #EBEBEB;--bg-input: #FFFFFF;--text-primary: #000000;--text-secondary: #666666;--text-disabled: #999999;--text-inverse: #FFFFFF;--accent-primary: #333333;--accent-hover: #555555;--accent-active: #111111;--border-default: #E0E0E0;--border-subtle: #F0F0F0;--border-strong: #CCCCCC;--success: #22C55E;--warning: #F59E0B;--error: #EF4444;--info: #3B82F6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .15);--diff-added-bg: rgba(34, 197, 94, .25);--diff-added-border: #16a34a;--diff-removed-bg: rgba(239, 68, 68, .25);--diff-removed-border: #dc2626}[data-theme=dark]{--bg-base: #0A0A0A;--bg-elevated: #2A2A2A;--bg-surface: #787878;--bg-surface-elevated: #A0A0A0;--bg-input: #C8C8C8;--text-primary: #FFFFFF;--text-secondary: #AAAAAA;--text-disabled: #666666;--text-inverse: #000000;--accent-primary: #666666;--accent-hover: #888888;--accent-active: #AAAAAA;--border-default: #333333;--border-subtle: #262626;--border-strong: #444444;--success: #4ADE80;--warning: #FBBF24;--error: #F87171;--info: #60A5FA;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px rgba(0, 0, 0, .6);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .7);--diff-added-bg: rgba(74, 222, 128, .2);--diff-added-border: #4ade80;--diff-removed-bg: rgba(248, 113, 113, .2);--diff-removed-border: #f87171}body{transition:background-color .3s ease,color .3s ease}html,body{background:var(--bg-base);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.custom-scrollbar::-webkit-scrollbar{height:6px;width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:3px}.dark .custom-scrollbar::-webkit-scrollbar-thumb{background-color:#475569}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.dark .custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#64748b}.tcy{text-combine-upright:all;-webkit-text-combine:horizontal;display:inline-block}.vertical-scroll-container::-webkit-scrollbar{height:6px;width:6px}.vertical-scroll-container::-webkit-scrollbar-track{background:transparent}.vertical-scroll-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dark .vertical-scroll-container::-webkit-scrollbar-thumb{background:#4b5563}body.dragging,body.dragging *{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;cursor:grabbing!important}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-title{font-size:32px;font-weight:700;color:#1a1a2e;margin:0 0 8px}.login-subtitle{font-size:14px;color:#666;margin:0}.login-loading{color:#fff;font-size:18px}.login-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.login-google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.login-google-button:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 4px 12px #0000001a}.login-google-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.login-divider{display:flex;align-items:center;margin:24px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.login-divider span{padding:0 16px;color:#9ca3af;font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:#374151}.form-group input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:16px;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f9fafb;cursor:not-allowed}.login-submit-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;font-size:16px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-submit-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-links{display:flex;justify-content:space-between;margin-top:24px}.link-button{background:none;border:none;color:#667eea;font-size:14px;cursor:pointer;padding:0}.link-button:hover{text-decoration:underline}.signup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.signup-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px}.signup-header{text-align:center;margin-bottom:32px}.signup-title{font-size:28px;font-weight:700;color:#1a1a2e;margin:0 0 8px}.signup-subtitle{font-size:14px;color:#666;margin:0}.signup-loading{color:#fff;font-size:18px}.signup-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.signup-success{text-align:center;padding:20px 0}.signup-success h2{color:#059669;margin:0 0 16px}.signup-success p{color:#666;line-height:1.6;margin:0 0 24px}.signup-back-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.signup-google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.signup-google-button:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 4px 12px #0000001a}.signup-google-button:disabled{opacity:.6;cursor:not-allowed}.signup-divider{display:flex;align-items:center;margin:24px 0}.signup-divider:before,.signup-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.signup-divider span{padding:0 16px;color:#9ca3af;font-size:14px}.signup-form{display:flex;flex-direction:column;gap:16px}.signup-form .form-group{display:flex;flex-direction:column;gap:6px}.signup-form .form-group label{font-size:14px;font-weight:500;color:#374151}.signup-form .form-group input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:16px;transition:border-color .2s ease}.signup-form .form-group input:focus{outline:none;border-color:#667eea}.signup-form .form-group input:disabled{background:#f9fafb;cursor:not-allowed}.signup-submit-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;font-size:16px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;margin-top:8px}.signup-submit-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.signup-submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.signup-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:24px}.signup-links span{color:#666;font-size:14px}.signup-links .link-button{background:none;border:none;color:#667eea;font-size:14px;font-weight:500;cursor:pointer;padding:0}.signup-links .link-button:hover{text-decoration:underline}.entrance-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.entrance-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px}.entrance-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;border-bottom:1px solid rgba(255,255,255,.1)}.entrance-title{font-size:28px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.entrance-logout{padding:8px 16px;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease}.entrance-logout:hover{background:#ffffff1a;border-color:#ffffff80}.entrance-main{max-width:800px;margin:0 auto;padding:40px 20px}.entrance-error{background:#dc262633;border:1px solid rgba(220,38,38,.5);color:#fca5a5;padding:12px 16px;border-radius:8px;margin-bottom:20px}.entrance-create{display:flex;gap:12px;margin-bottom:32px}.entrance-create input{flex:1;padding:14px 18px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:16px;transition:border-color .2s ease}.entrance-create input::placeholder{color:#ffffff80}.entrance-create input:focus{outline:none;border-color:#667eea}.entrance-create button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.entrance-create button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.entrance-create button:disabled{opacity:.5;cursor:not-allowed}.entrance-empty{text-align:center;padding:60px 20px;color:#ffffff80}.entrance-empty p{margin:8px 0}.entrance-stories{display:grid;gap:16px}.story-card{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:16px;cursor:pointer;transition:all .2s ease}.story-card:hover{background:#ffffff1f;border-color:#667eea80;transform:translate(4px)}.story-card-content{flex:1}.story-title{font-size:18px;font-weight:600;margin:0 0 4px}.story-theme{font-size:14px;color:#fff9;margin:0 0 8px}.story-date{font-size:12px;color:#fff6;margin:0}.story-delete{width:32px;height:32px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#ffffff80;font-size:18px;cursor:pointer;transition:all .2s ease;opacity:0}.story-card:hover .story-delete{opacity:1}.story-delete:hover{background:#dc26264d;border-color:#dc262680;color:#fca5a5}.scrivener-layout{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--bg-base)}.scrivener-body{display:flex;flex:1;overflow:hidden;position:relative}.floating-sidebar-toggle{position:absolute;top:12px;left:12px;width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:8px;cursor:pointer;font-size:18px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;z-index:200;box-shadow:var(--shadow-md);transition:all .15s ease}.floating-sidebar-toggle:hover{background:var(--bg-surface-elevated);color:var(--text-primary)}.scrivener-binder{width:240px;min-width:200px;max-width:320px;background:var(--bg-elevated);border-right:1px solid var(--border-default);display:flex;flex-direction:column;flex-shrink:0}.binder-header{display:flex;align-items:center;padding:12px;gap:8px;border-bottom:1px solid var(--border-default);background:var(--bg-elevated)}.binder-back-btn{background:var(--bg-surface-elevated);border:none;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background .2s}.binder-back-btn:hover{background:var(--accent-primary);color:var(--text-inverse)}.binder-toggle-btn{background:none;border:none;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease}.binder-toggle-btn:hover{background:var(--bg-surface-elevated);color:var(--text-primary)}.binder-title{flex:1;font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.binder-tree{flex:1;overflow-y:auto;padding:8px}.tree-section{margin-bottom:16px}.tree-section-header{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.tree-section-header.clickable{cursor:pointer;transition:background .2s}.tree-section-header.clickable:hover{background:var(--bg-surface-elevated);border-radius:6px}.tree-toggle{width:16px;font-size:10px;color:var(--text-disabled);flex-shrink:0;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.tree-toggle:hover{color:var(--text-primary)}.section-icon{font-size:12px}.section-name{flex:1}.section-add-btn{background:var(--bg-surface-elevated);border:none;width:18px;height:18px;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);opacity:0;transition:opacity .2s,background .2s}.tree-section-header:hover .section-add-btn{opacity:1}.section-add-btn:hover{background:var(--accent-primary);color:var(--text-inverse)}.tree-children{padding-left:4px}.tree-volume{margin-bottom:4px}.tree-volume-header{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background .2s;color:var(--text-primary)}.tree-volume-header:hover{background:var(--bg-surface-elevated)}.tree-volume-header.active{background:var(--accent-primary);color:var(--text-inverse)}.tree-volume-header.editing{background:var(--bg-surface)}.tree-rename-input{flex:1;min-width:0;padding:2px 6px;font-size:13px;border:1px solid var(--accent-primary);border-radius:4px;outline:none;background:var(--bg-elevated);color:var(--text-primary)}.tree-rename-input:focus{box-shadow:0 0 0 2px #a898804d}.tree-volume-children{padding-left:20px;margin-top:2px}.tree-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:5px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .2s}.tree-item:hover{background:var(--bg-surface-elevated)}.tree-item.active{background:var(--accent-primary);color:var(--text-inverse)}.tree-icon{font-size:13px;flex-shrink:0}.tree-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.tree-delete-btn{background:none;border:none;color:var(--text-disabled);cursor:pointer;font-size:14px;padding:2px 4px;opacity:0;transition:opacity .2s,color .2s}.tree-volume-header:hover .tree-delete-btn{opacity:1}.tree-delete-btn:hover{color:var(--error)}.binder-footer{padding:8px;border-top:1px solid var(--border-default);display:flex;flex-direction:column;gap:6px}.binder-footer .save-status-indicator{margin-bottom:4px;padding:6px 10px;border-radius:6px;justify-content:center}.binder-footer-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px;background:none;border:none;border-radius:6px;font-size:12px;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background .2s}.binder-footer-btn:hover{background:var(--bg-surface-elevated);color:var(--text-primary)}.binder-footer-btn.logout:hover{background:#f871711a;color:var(--error)}.scrivener-editor{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base)}.scrivener-inspector{width:280px;min-width:200px;background:var(--bg-elevated);border-left:1px solid var(--border-default);display:flex;flex-direction:column;flex-shrink:0}.inspector-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--border-default);font-size:13px;font-weight:600;color:var(--text-primary)}.inspector-close{background:none;border:none;color:var(--text-disabled);cursor:pointer;font-size:16px;padding:4px;line-height:1}.inspector-close:hover{color:var(--text-primary)}.inspector-content{flex:1;overflow-y:auto;padding:12px}.inspector-placeholder{font-size:12px;color:var(--text-disabled);text-align:center;padding:24px 12px}.global-header{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border-default);flex-shrink:0;z-index:100}.gh-left{display:flex;align-items:center;gap:4px}.gh-logo{font-size:18px;font-weight:700;color:var(--text-primary);margin-right:12px;-webkit-user-select:none;user-select:none}.gh-center{display:flex;align-items:center;gap:8px}.gh-center .save-status-indicator{padding:4px 10px;font-size:12px}.gh-right{display:flex;align-items:center;gap:4px}.gh-toolbar-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:none;border:none;border-radius:6px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.gh-toolbar-btn:hover:not(:disabled){background:var(--bg-surface-elevated);color:var(--text-primary)}.gh-toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.gh-btn-text{display:none}@media(min-width:768px){.gh-btn-text{display:inline}}.gh-zoom-text{min-width:40px;text-align:center;font-size:12px;font-weight:500}.gh-divider{width:1px;height:20px;background:var(--border-default);margin:0 4px}.gh-nav-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:none;border:none;border-radius:6px;font-size:13px;font-weight:500;color:var(--accent-primary);cursor:pointer;transition:all .15s ease}.gh-nav-btn:hover{background:var(--bg-surface-elevated);color:var(--accent-hover)}.gh-icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;border-radius:6px;font-size:16px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.gh-icon-btn:hover:not(:disabled){background:var(--bg-surface-elevated);color:var(--text-primary)}.gh-icon-btn:disabled{opacity:.4;cursor:not-allowed}.save-status-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.save-status-indicator.saved{color:#10b981;background:#10b9811a}.save-status-indicator.saving{color:#6b7280;background:#6b72801a}.save-status-indicator.unsaved{color:#f59e0b;background:#f59e0b1a}.save-status-indicator.unsaved:hover{background:#f59e0b33}.save-status-icon{font-size:14px}.save-status-icon.unsaved{font-size:10px;animation:pulse 1.5s ease-in-out infinite}.save-status-text{font-weight:500}.save-status-time{color:#9ca3af;font-size:11px}.save-status-spinner{width:12px;height:12px;border:2px solid #e5e7eb;border-top-color:#6b7280;border-radius:50%;animation:spin .8s linear infinite}.save-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:#1f2937;color:#fff;border-radius:8px;font-size:14px;box-shadow:0 4px 20px #0000004d;animation:slideUp .3s ease-out;z-index:10000}.save-toast-icon{color:#10b981;font-size:16px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(prefers-color-scheme:dark){.save-status-indicator.saved{color:#34d399}.save-status-indicator.saving{color:#9ca3af}.save-status-indicator.unsaved{color:#fbbf24}}.stamp-save-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stamp-save-dialog{background:var(--bg-primary, #fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;animation:slideUp .2s ease-out;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stamp-save-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color, #e0e0e0)}.stamp-save-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-primary, #333)}.stamp-save-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:var(--text-secondary, #666);transition:background .15s,color .15s}.stamp-save-close:hover{background:var(--bg-secondary, #f0f0f0);color:var(--text-primary, #333)}.stamp-save-content{padding:20px}.stamp-save-description{font-size:13px;color:var(--text-secondary, #666);line-height:1.5;margin-bottom:20px;padding:12px;background:var(--bg-secondary, #f8f8f8);border-radius:8px}.stamp-save-field{margin-bottom:16px}.stamp-save-field:last-child{margin-bottom:0}.stamp-save-field label{display:block;font-size:13px;font-weight:500;color:var(--text-primary, #333);margin-bottom:6px}.stamp-save-field input,.stamp-save-field textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color, #e0e0e0);border-radius:8px;font-size:14px;font-family:inherit;background:var(--bg-primary, #fff);color:var(--text-primary, #333);transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.stamp-save-field input:focus,.stamp-save-field textarea:focus{outline:none;border-color:var(--accent-color, #007aff);box-shadow:0 0 0 3px #007aff26}.stamp-save-field textarea{resize:vertical;min-height:80px}.stamp-save-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color, #e0e0e0);background:var(--bg-secondary, #f8f8f8)}.stamp-save-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.stamp-save-btn.cancel{background:var(--bg-primary, #fff);color:var(--text-secondary, #666);border:1px solid var(--border-color, #e0e0e0)}.stamp-save-btn.cancel:hover{background:var(--bg-secondary, #f0f0f0)}.stamp-save-btn.save{background:var(--accent-color, #007aff);color:#fff}.stamp-save-btn.save:hover:not(:disabled){background:var(--accent-color-hover, #0066d6)}.stamp-save-btn.save:disabled{opacity:.5;cursor:not-allowed}@media(prefers-color-scheme:dark){.stamp-save-dialog{--bg-primary: #1e1e1e;--bg-secondary: #2a2a2a;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--border-color: #3a3a3a}}.compare-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:compareFadeIn .15s ease-out}.compare-dialog{background:var(--bg-elevated);border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;animation:compareSlideUp .2s ease-out}.compare-fullscreen{position:fixed;top:48px;left:0;right:0;bottom:0;background:var(--bg-base);z-index:1100;display:flex;flex-direction:column}.compare-header,.compare-fullscreen-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-default);background:var(--bg-elevated);flex-shrink:0;gap:16px}.compare-controls-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);flex-shrink:0;gap:16px}.compare-controls-left{display:flex;align-items:center;gap:16px}.compare-controls-right{display:flex;align-items:center;gap:12px}.compare-header-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.change-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;background:var(--accent-primary);color:var(--text-inverse);border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.compare-header-center{display:flex;align-items:center;flex:1;justify-content:center}.compare-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.compare-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-primary)}.compare-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;color:var(--text-secondary);transition:background .15s,color .15s}.compare-close:hover{background:var(--bg-surface);color:var(--text-primary)}.compare-content{flex:1;overflow-y:auto;padding:16px}.compare-item{padding:12px 16px;border:1px solid var(--border-default);border-radius:8px;margin-bottom:10px;cursor:pointer;transition:all .15s}.compare-item:hover{border-color:var(--accent-primary);background:var(--bg-surface)}.compare-item.selected{border-color:var(--accent-primary);background:var(--bg-surface-elevated);box-shadow:0 0 0 2px #3b82f633}.compare-item-title{font-weight:600;color:var(--text-primary);margin-bottom:4px}.compare-item-date{font-size:12px;color:var(--text-secondary)}.compare-item-memo{font-size:12px;color:var(--text-secondary);margin-top:6px;padding:6px 8px;background:var(--bg-surface);border-radius:4px}.compare-row-select{margin-bottom:16px}.compare-label{display:block;font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.compare-select{width:100%;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .15s}.compare-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f633}.stamp-save-selector{padding:4px 8px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:4px;color:var(--text-primary);font-size:13px;cursor:pointer;margin-left:4px;max-width:200px}.stamp-save-selector:focus{border-color:var(--accent-primary);outline:none}.panel-label{margin-left:4px;font-weight:500}.panel-no-changes{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px;color:var(--text-secondary);gap:8px}.no-changes-icon{font-size:32px;color:var(--success-color, #22c55e)}.compare-footer,.compare-fullscreen-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-default);background:var(--bg-surface);flex-shrink:0}.compare-fullscreen-footer{justify-content:space-between}.compare-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.compare-btn.cancel{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default)}.compare-btn.cancel:hover{background:var(--bg-surface)}.compare-btn.primary{background:var(--accent-primary);color:var(--text-inverse)}.compare-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.compare-btn.primary:disabled{opacity:.5;cursor:not-allowed}.compare-main{flex:1;display:flex;flex-direction:column;padding:16px;gap:12px;overflow:hidden;min-height:0}.diff-scene-info{display:flex;align-items:center;gap:16px;padding:10px 16px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:8px;font-size:13px;color:var(--text-primary);flex-shrink:0}.diff-scene-info .scene-label{font-weight:600;display:flex;align-items:center;gap:6px}.diff-scene-info .item-label{color:var(--text-secondary);display:flex;align-items:center;gap:6px}.diff-scene-info .change-counter{margin-left:auto;padding:4px 12px;background:var(--accent-primary);color:var(--text-inverse);border-radius:12px;font-size:12px;font-weight:600}.diff-panels{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:16px;min-height:0}.diff-panel{display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:8px;overflow:hidden;min-height:0}.diff-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;flex-shrink:0}.diff-panel-header.old{background:#f8717126;color:#dc2626;border-bottom:2px solid #dc2626}.diff-panel-header.new{background:#4ade8026;color:#16a34a;border-bottom:2px solid #16a34a}.diff-panel-header .panel-icon{font-size:16px}.diff-panel-content{flex:1;padding:16px;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;line-height:1.8;white-space:pre-wrap;overflow:auto}.diff-added{background-color:#4ade8066;color:#166534;padding:1px 4px;border-radius:3px;border-bottom:2px solid #16a34a}.diff-removed{background-color:#f8717166;color:#991b1b;padding:1px 4px;border-radius:3px;text-decoration:line-through;text-decoration-thickness:2px}[data-theme=dark] .diff-added{background-color:#4ade8040;color:#86efac}[data-theme=dark] .diff-removed{background-color:#f8717140;color:#fca5a5}[data-theme=dark] .diff-panel-header.old{background:#f871711a;color:#f87171;border-bottom-color:#f87171}[data-theme=dark] .diff-panel-header.new{background:#4ade801a;color:#4ade80;border-bottom-color:#4ade80}.compare-nav{display:flex;gap:8px}.compare-nav button{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border-default);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;transition:all .15s;font-size:13px}.compare-nav button:hover:not(:disabled){background:var(--bg-surface);border-color:var(--accent-primary)}.compare-nav button:disabled{opacity:.5;cursor:not-allowed}.nav-counter{display:flex;align-items:center;justify-content:center;min-width:70px;padding:6px 14px;background:var(--accent-primary);color:var(--text-inverse);border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap}.compare-fullscreen-header .compare-info{display:flex;align-items:center;gap:16px}.compare-fullscreen-header .compare-title-text{font-size:14px;font-weight:500;color:var(--text-primary)}@keyframes compareFadeIn{0%{opacity:0}to{opacity:1}}@keyframes compareSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.compare-content .compare-empty,.compare-content .compare-error{text-align:center;padding:40px 20px;color:var(--text-secondary)}.compare-content .compare-error{color:var(--error)}.compare-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary)}.compare-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-secondary);font-size:16px}.compare-empty-state:before{content:"✓";font-size:48px;color:var(--success, #16a34a)}.compare-summary{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:12px}.compare-summary .stat{display:flex;align-items:center;gap:4px}.compare-summary .stat.added{color:#16a34a}.compare-summary .stat.removed{color:#dc2626}.diff-panel.editing{border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f64d}.diff-panel-header.editing{background:#3b82f626;color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.edit-toggle-btn{display:flex;align-items:center;gap:4px;margin-left:auto;padding:4px 10px;font-size:12px;font-weight:500;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:4px;cursor:pointer;transition:all .15s}.edit-toggle-btn:hover,.edit-toggle-btn.active{background:var(--accent-primary);color:var(--text-inverse);border-color:var(--accent-primary)}.diff-panel-content.editing{padding:0;display:flex;flex-direction:column}.diff-editor{flex:1;min-height:300px;border:none!important;border-radius:0!important}.diff-editor>div{height:100%}.diff-edit-textarea{width:100%;height:100%;min-height:300px;padding:16px;border:none;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;line-height:1.8;font-family:inherit;resize:none;outline:none}.diff-edit-textarea:focus{box-shadow:inset 0 0 0 2px var(--accent-primary)}.compare-btn.restore{display:flex;align-items:center;gap:6px;background:#f8717126;color:#dc2626;border:1px solid #dc2626}.compare-btn.restore:hover{background:#f871714d}.compare-btn.save{display:flex;align-items:center;gap:6px;background:var(--accent-primary);color:var(--text-inverse)}.compare-btn.save:hover{background:var(--accent-hover)}.compare-btn.save:disabled{opacity:.5;cursor:not-allowed}.whitespace-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.whitespace-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.whitespace-toggle:hover{color:var(--text-primary)}.confirm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1200;animation:compareFadeIn .15s ease-out}.confirm-modal{background:var(--bg-elevated);border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:400px;animation:compareSlideUp .2s ease-out}.confirm-modal-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid var(--border-default)}.confirm-modal-header .warning-icon{font-size:24px}.confirm-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.confirm-modal-body{padding:20px;color:var(--text-secondary);font-size:14px;line-height:1.6}.confirm-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-default);background:var(--bg-surface);border-radius:0 0 12px 12px}.shortcut-hint{font-size:11px;color:var(--text-tertiary);margin-left:4px;opacity:.8}.compare-fullscreen-footer{display:flex;justify-content:space-between;align-items:center}.compare-footer-left{display:flex;align-items:center;gap:16px}.compare-footer-right{display:flex;align-items:center;gap:10px}.diff-added{background-color:var(--diff-added-bg);border-bottom:2px solid var(--diff-added-border);padding:1px 2px;border-radius:2px;color:inherit}.diff-removed{background-color:var(--diff-removed-bg);text-decoration:line-through;text-decoration-color:var(--diff-removed-border);text-decoration-thickness:2px;padding:1px 2px;border-radius:2px;color:inherit}.diff-panel-content.scrollable{overflow-y:auto;flex:1;padding:8px}.scene-row{background:var(--bg-elevated);border-radius:8px;margin-bottom:12px;border:1px solid var(--border-subtle);overflow:hidden}.scene-row.has-changes{border-left:3px solid var(--warning)}.scene-row-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);font-size:13px;font-weight:500}.scene-number{color:var(--accent-primary);font-weight:600}.scene-title{color:var(--text-primary)}.change-indicator{color:var(--warning);margin-left:auto}.no-change-indicator{color:var(--success);margin-left:auto}.scene-row-content{padding:12px;min-height:80px;white-space:pre-wrap;line-height:1.6;color:var(--text-primary);display:flex;flex-direction:column}.scene-row-content.editable{padding:0}.scene-row-content .diff-editor{min-height:80px;border:none;flex:1}.no-changes-message{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--success);font-size:14px;padding:16px;min-height:48px;flex:1}.no-changes-message .no-changes-icon{font-size:18px}.compare-editor-row{margin-bottom:0;display:flex;flex-direction:column}.compare-editor-content{padding:0;display:flex;flex-direction:column}.compare-editor{flex:1;min-height:60px;font-size:14px;line-height:1.8;color:var(--text-primary);cursor:text}.compare-editor:focus{outline:2px solid var(--accent);outline-offset:-2px}.compare-resize-handle{height:8px;cursor:row-resize;background:transparent;transition:background .2s;border-radius:0 0 4px 4px}.compare-resize-handle:hover{background:var(--accent);opacity:.5}.compare-resize-handle:active{background:var(--accent);opacity:.8}.compare-layout{display:flex;flex-direction:column;height:100%;min-height:0}.compare-headers{display:flex;flex-shrink:0;border-bottom:1px solid var(--border-default)}.compare-header-cell{flex:1;padding:12px 16px;font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}.compare-header-cell.old{background:#f8717126;color:#dc2626;border-right:1px solid var(--border-default)}.compare-header-cell.new{background:#4ade8026;color:#16a34a}.compare-content-area{flex:1;overflow:auto;min-height:0}.compare-row{display:flex;align-items:stretch;border-bottom:1px solid var(--border-subtle);position:relative}.compare-row.vertical{writing-mode:vertical-rl}.compare-cell{flex:1;min-width:0;display:flex;flex-direction:column}.compare-cell.left{border-right:1px solid var(--border-default);background:var(--bg-elevated)}.compare-cell.right{background:var(--bg-surface)}.compare-cell-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);font-size:13px;flex-shrink:0}.compare-cell.left .compare-cell-header{background:#f8717114}.compare-cell.right .compare-cell-header{background:#4ade8014}.compare-cell-content{flex:1;padding:12px;font-size:14px;line-height:1.8;white-space:pre-wrap;word-break:break-all;min-height:60px}.compare-row-resize{position:absolute;bottom:0;left:0;right:0;height:6px;cursor:row-resize;background:transparent;transition:background .2s;z-index:5}.compare-row-resize:hover{background:var(--accent-primary);opacity:.5}.compare-row-resize:active{background:var(--accent-primary);opacity:.8}.compare-cell-header .scene-info{display:flex;align-items:center;gap:6px}.compare-cell-header .scene-number{color:var(--text-secondary);font-weight:500}.compare-cell-header .scene-title{color:var(--text-primary);font-weight:500}.compare-cell-header .change-indicator{color:#f59e0b;font-size:12px}.compare-cell-header .no-change-indicator{color:#22c55e;font-size:12px}[data-theme=dark] .compare-header-cell.old{background:#f871711a;color:#f87171}[data-theme=dark] .compare-header-cell.new{background:#4ade801a;color:#4ade80}[data-theme=dark] .compare-cell.left .compare-cell-header{background:#f871710d}[data-theme=dark] .compare-cell.right .compare-cell-header{background:#4ade800d}.compare-writing-toggle{display:flex;border:1px solid var(--border-default);border-radius:6px;overflow:hidden;margin-left:12px}.compare-writing-toggle button{padding:4px 12px;border:none;background:transparent;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:all .15s ease}.compare-writing-toggle button:hover{background:var(--bg-elevated)}.compare-writing-toggle button.active{background:var(--accent-primary);color:#fff}.compare-main.vertical-mode{flex:1;overflow:auto;padding:16px}.compare-vertical-layout{display:flex;flex-direction:column;gap:16px;height:100%}.compare-vertical-row{display:flex;align-items:stretch;gap:8px;padding:12px;border-radius:8px;flex:1;min-height:250px}.compare-vertical-row.past{background:#f8717114;border:1px solid rgba(248,113,113,.2)}.compare-vertical-row.current{background:#4ade8014;border:1px solid rgba(74,222,128,.2)}.compare-vertical-label{writing-mode:vertical-rl;font-size:14px;font-weight:600;padding:12px 8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;color:var(--text-secondary);width:70px;flex-shrink:0;background:var(--bg-elevated);border-radius:8px}.stamp-save-selector-vertical{writing-mode:vertical-rl;text-orientation:mixed;font-size:12px;padding:8px 6px;border:1px solid var(--border-default);border-radius:4px;background:var(--bg-surface);cursor:pointer;min-height:60px}.label-divider{width:100%;height:1px;background:var(--border-subtle);margin:4px 0}.label-spacer{min-height:60px}.compare-vertical-row.past .compare-vertical-label{color:#f87171}.compare-vertical-row.current .compare-vertical-label{color:#4ade80;justify-content:center}.compare-vertical-scenes{display:flex;flex-direction:row-reverse;gap:8px;flex:1;overflow-x:auto;padding:4px}.compare-vertical-card{min-width:180px;max-width:220px;flex-shrink:0;display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-surface);overflow:hidden}.compare-vertical-card.editable{background:var(--bg-elevated)}.compare-vertical-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);font-size:12px}.compare-vertical-card-header .scene-number{color:var(--text-muted);font-size:11px}.compare-vertical-card-header .scene-title{font-weight:500;color:var(--text-primary)}.compare-vertical-card-content{flex:1;padding:12px;font-size:14px;line-height:1.8;writing-mode:vertical-rl;overflow:auto;min-height:150px}.compare-vertical-card.editable .compare-vertical-card-content{outline:none;cursor:text}.compare-vertical-card.editable .compare-vertical-card-content:focus{background:#3b82f60d}.compare-vertical-card-footer{padding:4px 12px;font-size:11px;color:var(--text-muted);text-align:right;border-top:1px solid var(--border-subtle);background:var(--bg-elevated)}[data-theme=dark] .compare-vertical-row.past{background:#f871710d}[data-theme=dark] .compare-vertical-row.current{background:#4ade800d}.compare-card-width-handle{position:absolute;left:0;top:0;bottom:0;width:6px;cursor:col-resize;background:transparent;transition:background .15s ease}.compare-card-width-handle:hover{background:#3b82f64d}.compare-card-width-handle:active{background:#3b82f680}.compare-vertical-card{position:relative}.character-sheet{--cs-bg-primary: var(--bg-elevated);--cs-bg-secondary: var(--bg-surface);--cs-text-primary: var(--text-primary);--cs-text-secondary: var(--text-secondary);--cs-accent: var(--accent-primary);--cs-border: var(--border-default);--cs-hover: var(--bg-surface-elevated)}.character-sheet{display:flex;height:100%;background:var(--cs-bg-primary);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}.cs-sidebar{width:220px;border-right:1px solid var(--cs-border);background:var(--cs-bg-secondary);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease-out}.cs-sidebar.collapsed{width:0;border-right:none;overflow:hidden}.cs-sidebar-header{padding:12px 16px;border-bottom:1px solid var(--cs-border);display:flex;justify-content:space-between;align-items:center}.cs-sidebar-title{font-size:12px;font-weight:600;color:var(--cs-text-secondary);text-transform:uppercase;letter-spacing:.02em}.cs-sidebar-list{flex:1;overflow-y:auto;padding:8px}.cs-sidebar-item-wrapper{display:flex;align-items:center;margin-bottom:4px}.cs-sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s ease;border:none;background:transparent;flex:1;text-align:left}.cs-sidebar-item:hover{background:var(--cs-hover)}.cs-sidebar-item.active{background:#0071e31a}.cs-sidebar-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:12px;flex-shrink:0}.cs-sidebar-name{font-size:13px;font-weight:500;color:var(--cs-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-sidebar-delete{opacity:0;background:transparent;border:none;color:var(--cs-text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:opacity .15s ease,color .15s ease}.cs-sidebar-item-wrapper:hover .cs-sidebar-delete{opacity:1}.cs-sidebar-delete:hover{color:#ff3b30}.cs-main{flex:1;overflow-y:auto;padding:24px 32px;background:var(--cs-bg-primary)}.cs-content{max-width:900px;margin:0}.cs-upper-layer{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--cs-border)}.cs-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:12px}.cs-avatar-large{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:24px;flex-shrink:0;cursor:pointer}.cs-header-info{flex:1}.cs-name-input{font-size:24px;font-weight:700;color:var(--cs-text-primary);background:transparent;border:none;outline:none;width:100%;padding:0;margin-bottom:4px}.cs-name-input::placeholder{color:var(--cs-text-secondary)}.cs-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;color:var(--cs-text-secondary);font-size:13px}.cs-meta-separator{color:var(--cs-border)}.cs-meta-input{background:transparent;border:none;outline:none;color:var(--cs-text-secondary);font-size:13px;width:auto;padding:0}.cs-meta-input:focus{color:var(--cs-text-primary)}.cs-meta-input::placeholder{color:var(--cs-border)}.cs-ability-row{display:flex;gap:24px}.cs-ability-item{display:flex;align-items:center;gap:8px}.cs-ability-label{font-size:13px;font-weight:600;color:var(--cs-text-secondary)}.cs-ability-input{background:transparent;border:none;outline:none;color:var(--cs-text-primary);font-size:13px;flex:1}.cs-ability-input::placeholder{color:var(--cs-border)}.cs-tree-section{margin-bottom:12px}.cs-tree-parent{margin-bottom:2px}.cs-tree-parent-header{display:flex;align-items:center;gap:6px;padding:8px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.cs-tree-parent-header:hover .cs-tree-parent-title{color:var(--cs-accent)}.cs-tree-chevron{color:var(--cs-text-secondary);transition:transform .2s ease;flex-shrink:0}.cs-tree-chevron.expanded{transform:rotate(90deg)}.cs-tree-parent-title{font-size:14px;font-weight:600;color:var(--cs-text-primary)}.cs-tree-parent-input{padding-left:20px}.cs-tree-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--cs-border);outline:none;color:var(--cs-text-primary);font-size:14px;padding:6px 0;transition:border-color .15s ease}.cs-tree-input:focus{border-bottom-color:var(--cs-accent)}.cs-tree-input::placeholder{color:var(--cs-border);opacity:.7}.cs-tree-children{padding-left:8px;margin-left:6px;border-left:1px solid var(--cs-border)}.cs-tree-child{position:relative;padding:4px 0}.cs-tree-child-content{display:flex;align-items:center;gap:8px;padding-left:12px}.cs-tree-child-icon{color:var(--cs-border);font-family:monospace;font-size:14px;flex-shrink:0}.cs-tree-child .cs-tree-input{flex:1}.cs-tree-delete{color:var(--cs-text-secondary);background:transparent;border:none;cursor:pointer;opacity:0;transition:opacity .15s ease,color .15s ease;font-size:16px;padding:2px 6px}.cs-tree-child:hover .cs-tree-delete{opacity:1}.cs-tree-delete:hover{color:#ff3b30}.cs-tree-add-btn{display:inline-flex;align-items:center;gap:4px;color:var(--cs-text-secondary);background:transparent;border:none;cursor:pointer;font-size:12px;padding:4px 0;transition:color .15s ease}.cs-tree-add-btn:hover{color:var(--cs-accent)}.cs-tree-line{display:none}.cs-middle-textarea{width:100%;background:transparent;border:none;outline:none;color:var(--cs-text-primary);font-size:13px;line-height:1.6;resize:none;padding:0;margin-bottom:12px}.cs-middle-textarea::placeholder{color:var(--cs-text-secondary)}.cs-middle-episodes{display:flex;flex-direction:column;gap:8px}.cs-middle-episode-row{display:flex;align-items:center;gap:8px}.cs-middle-episode-row .cs-middle-fillin-input{flex:1}.cs-middle-episode-label{color:var(--cs-accent);font-size:12px;font-weight:500}.cs-middle-episode-input{flex:1;background:transparent;border:none;outline:none;color:var(--cs-text-primary);font-size:13px}.cs-middle-episode-input::placeholder{color:var(--cs-border)}.cs-middle-episode-delete{color:var(--cs-text-secondary);cursor:pointer;opacity:0;transition:opacity .15s ease;background:transparent;border:none;padding:2px;font-size:14px}.cs-middle-episode:hover .cs-middle-episode-delete{opacity:1}.cs-middle-episode-delete:hover{color:#ff3b30}.cs-section{margin-bottom:12px;border:1px solid var(--cs-border);border-radius:10px;background:var(--cs-bg-primary);overflow:hidden}.cs-section-header{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--cs-bg-secondary);border-bottom:1px solid transparent}.cs-section-header:hover{background:var(--cs-hover)}.cs-section-title{font-size:13px;font-weight:600;color:var(--cs-text-primary)}.cs-section-summary{font-size:13px;color:var(--cs-text-secondary);margin-left:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cs-section-content{padding:12px 14px;overflow:hidden;transition:max-height .2s ease-out,opacity .2s ease-out,padding .2s ease-out}.cs-section-content.collapsed{max-height:0;opacity:0;padding:0 14px}.cs-section-content.expanded{max-height:300px;opacity:1}.cs-textarea{width:100%;background:transparent;border:none;outline:none;color:var(--cs-text-primary);font-size:13px;line-height:1.6;resize:none;padding:0}.cs-textarea::placeholder{color:var(--cs-text-secondary)}.cs-tags-section-simple{margin:16px 0}.cs-tags-trigger{padding:10px 14px;border:1px solid var(--cs-border);border-radius:8px;background:var(--cs-bg-primary);cursor:pointer;transition:border-color .15s ease;min-height:40px}.cs-tags-trigger:hover{border-color:var(--cs-accent)}.cs-tags-placeholder{color:var(--cs-text-secondary);font-size:14px}.cs-tags-hint{color:var(--cs-border);font-size:12px;margin-left:4px}.cs-tags-compact{display:flex;flex-wrap:wrap;gap:6px}.cs-tag-compact{display:inline-block;background:var(--cs-bg-secondary);color:var(--cs-text-primary);padding:4px 10px;border-radius:12px;font-size:12px;border:1px solid var(--cs-border)}.cs-tags-more{color:var(--cs-accent);font-size:12px;padding:4px 8px}.cs-bulk-modal{background:var(--cs-bg-primary);border-radius:12px;width:min(520px,90vw);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.cs-bulk-modal-content{padding:16px;overflow-y:auto;flex:1}.cs-bulk-table{width:100%;border-collapse:collapse}.cs-bulk-table th{text-align:left;font-size:12px;font-weight:600;color:var(--cs-text-secondary);padding:8px 4px;border-bottom:1px solid var(--cs-border)}.cs-bulk-table td{padding:6px 4px;vertical-align:middle}.cs-bulk-select{width:100%;background:var(--cs-bg-secondary);border:1px solid var(--cs-border);border-radius:6px;color:var(--cs-text-primary);font-size:13px;padding:8px 10px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.cs-bulk-select:focus{outline:none;border-color:var(--cs-accent)}.cs-bulk-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--cs-border);color:var(--cs-text-primary);font-size:13px;padding:8px 4px;outline:none}.cs-bulk-input:focus{border-bottom-color:var(--cs-accent)}.cs-bulk-input::placeholder{color:var(--cs-border)}.cs-bulk-delete{background:transparent;border:none;color:var(--cs-text-secondary);cursor:pointer;font-size:16px;padding:4px 8px;opacity:.5;transition:opacity .15s ease,color .15s ease}.cs-bulk-delete:hover:not(:disabled){opacity:1;color:#ff3b30}.cs-bulk-delete:disabled{opacity:.2;cursor:not-allowed}.cs-bulk-add{margin-top:12px}.cs-bulk-category-label{font-size:13px;font-weight:500;color:var(--cs-text-primary);padding:8px 10px;display:block}.cs-modal-header-actions{display:flex;align-items:center;gap:8px}.cs-category-manager{background:var(--cs-bg-secondary);border-bottom:1px solid var(--cs-border);padding:12px 16px}.cs-category-manager-header{font-size:12px;font-weight:600;color:var(--cs-text-secondary);margin-bottom:10px;text-transform:uppercase}.cs-category-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.cs-category-item{display:inline-flex;align-items:center;gap:4px;background:var(--cs-bg-primary);border:1px solid var(--cs-border);border-radius:16px;padding:4px 8px 4px 12px;font-size:12px}.cs-category-delete{background:transparent;border:none;color:var(--cs-text-secondary);cursor:pointer;font-size:14px;padding:0 4px;opacity:.6;transition:opacity .15s ease,color .15s ease}.cs-category-delete:hover{opacity:1;color:#ff3b30}.cs-category-add-row{display:flex;gap:8px}.cs-category-add-input{flex:1;background:var(--cs-bg-primary);border:1px solid var(--cs-border);border-radius:6px;color:var(--cs-text-primary);font-size:12px;padding:6px 10px;outline:none}.cs-category-add-input:focus{border-color:var(--cs-accent)}.cs-category-add-input::placeholder{color:var(--cs-border)}.cs-category-add-btn{background:var(--cs-accent);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer;transition:opacity .15s ease}.cs-category-add-btn:hover{opacity:.9}.cs-tags-section{margin-bottom:20px;padding:16px;border:1px solid var(--cs-border);border-radius:10px;background:var(--cs-bg-secondary)}.cs-tags-header{margin-bottom:10px}.cs-tags-title{font-size:12px;font-weight:600;color:var(--cs-text-secondary);text-transform:uppercase;letter-spacing:.02em}.cs-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.cs-tag-category{display:flex;align-items:center;gap:6px;background:var(--cs-bg-primary);color:var(--cs-text-primary);padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;border:1px solid var(--cs-border);cursor:pointer;transition:all .15s ease}.cs-tag-category:hover{border-color:var(--cs-accent);color:var(--cs-accent)}.cs-tag-category-label{font-weight:600}.cs-tag-category-count{background:var(--cs-accent);color:#fff;font-size:10px;padding:2px 6px;border-radius:10px}.cs-tags-display{display:flex;flex-wrap:wrap;gap:6px}.cs-tag{display:inline-flex;align-items:center;background:var(--cs-bg-primary);color:var(--cs-text-primary);padding:4px 10px;border-radius:12px;font-size:12px;border:1px solid var(--cs-border)}.cs-tag-fears{border-color:#ff3b30;color:#ff3b30}.cs-tag-likes{border-color:#34c759;color:#34c759}.cs-tag-dislikes{border-color:#ff9500;color:#ff9500}.cs-tag-catchphrases{border-color:#5856d6;color:#5856d6}.cs-tag-secrets{border-color:#af52de;color:#af52de}.cs-tag-remove{background:transparent;border:none;color:var(--cs-text-secondary);cursor:pointer;margin-left:4px;font-size:14px}.cs-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cs-column-section{border:1px solid var(--cs-border);border-radius:10px;background:var(--cs-bg-primary);overflow:hidden}.cs-column-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--cs-bg-secondary);border-bottom:1px solid var(--cs-border)}.cs-column-title{font-size:13px;font-weight:600;color:var(--cs-text-primary)}.cs-column-content{padding:12px;max-height:400px;overflow-y:auto}.cs-empty-column{padding:16px;text-align:center;color:var(--cs-text-secondary);font-size:12px}.cs-trait-card{background:var(--cs-bg-secondary);border-radius:8px;padding:10px;margin-bottom:10px;border:1px solid var(--cs-border)}.cs-trait-card:last-child{margin-bottom:0}.cs-trait-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.cs-trait-name{font-size:13px;font-weight:600;color:var(--cs-text-primary);background:transparent;border:none;outline:none;flex:1}.cs-trait-name::placeholder{color:var(--cs-text-secondary)}.cs-trait-delete{color:var(--cs-text-secondary);cursor:pointer;opacity:0;transition:opacity .15s ease;background:transparent;border:none;padding:4px}.cs-trait-card:hover .cs-trait-delete{opacity:1}.cs-trait-delete:hover{color:#ff3b30}.cs-trait-episodes{padding-left:10px;border-left:2px solid var(--cs-border)}.cs-trait-episode{display:flex;align-items:flex-start;gap:6px;margin-bottom:4px}.cs-trait-episode-input{flex:1;background:transparent;border:none;outline:none;color:var(--cs-text-secondary);font-size:12px;line-height:1.5}.cs-trait-episode-input::placeholder{color:var(--cs-border)}.cs-trait-episode-delete{color:var(--cs-text-secondary);cursor:pointer;opacity:0;transition:opacity .15s ease;background:transparent;border:none;padding:2px;font-size:12px}.cs-trait-episode:hover .cs-trait-episode-delete{opacity:1}.cs-add-btn{display:inline-flex;align-items:center;gap:4px;color:var(--cs-text-secondary);font-size:12px;cursor:pointer;background:transparent;border:none;padding:4px 0;transition:color .15s ease}.cs-add-btn:hover{color:var(--cs-accent)}.cs-icon-btn{background:transparent;border:none;color:var(--cs-text-secondary);cursor:pointer;padding:6px;border-radius:6px;transition:background .15s ease,color .15s ease}.cs-icon-btn:hover{background:var(--cs-hover);color:var(--cs-text-primary)}.cs-toggle-btn{position:absolute;top:16px;left:16px;z-index:10}.cs-chevron-left{transform:rotate(180deg)}.cs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--cs-text-secondary);gap:12px}.cs-empty-icon{opacity:.2}.cs-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}.cs-modal{background:var(--cs-bg-primary);border-radius:12px;width:400px;max-width:90vw;box-shadow:0 20px 40px #0003}.cs-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--cs-border)}.cs-modal-title{font-size:16px;font-weight:600;color:var(--cs-text-primary)}.cs-modal-content{padding:16px}.cs-modal-input-row{display:flex;gap:8px;margin-bottom:16px}.cs-modal-input{flex:1;padding:10px 14px;border:1px solid var(--cs-border);border-radius:8px;background:var(--cs-bg-secondary);color:var(--cs-text-primary);font-size:14px;outline:none}.cs-modal-input:focus{border-color:var(--cs-accent)}.cs-modal-add-btn{padding:10px 16px;background:var(--cs-accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.cs-modal-add-btn:hover{opacity:.9}.cs-modal-tags{display:flex;flex-wrap:wrap;gap:8px;min-height:60px}.cs-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px;border-top:1px solid var(--cs-border)}.cs-modal-cancel{padding:10px 16px;background:transparent;color:var(--cs-text-secondary);border:1px solid var(--cs-border);border-radius:8px;font-size:14px;cursor:pointer}.cs-modal-cancel:hover{background:var(--cs-hover)}.cs-modal-save{padding:10px 16px;background:var(--cs-accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.cs-modal-save:hover{opacity:.9}
