@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Spectral:wght@400;600&display=swap";@import"https://fonts.googleapis.com/css2?family=VT323&display=swap";.create-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.create-modal-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:slideUp .3s ease-out}.create-modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-sm)}.create-modal-icon{font-size:28px;line-height:1}.create-modal-title{flex:1;margin:0;font-size:var(--font-lg);font-weight:600;color:var(--text-main)}.create-modal-close{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.create-modal-close:hover{color:var(--text-main)}.create-modal-body{padding:var(--space-lg)}.create-modal-form-group{margin-bottom:var(--space-lg)}.create-modal-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-main);margin-bottom:var(--space-xs)}.create-modal-input{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-md);font-family:var(--font-family);border:2px solid var(--border);border-radius:var(--radius-sm);transition:border-color .2s ease;box-sizing:border-box}.create-modal-input:focus{outline:none;border-color:var(--primary)}.create-modal-input:disabled{background-color:var(--bg-secondary);cursor:not-allowed}.create-modal-error{margin-top:var(--space-xs);font-size:var(--font-xs);color:var(--error);min-height:16px}.create-modal-footer{display:flex;gap:var(--space-sm);justify-content:flex-end}.create-modal-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.create-modal-btn:disabled{opacity:.5;cursor:not-allowed}.create-modal-btn-cancel{background:transparent;border-color:var(--border);color:var(--text-secondary)}.create-modal-btn-cancel:hover:not(:disabled){border-color:var(--text-secondary);color:var(--text-main)}.create-modal-btn-create{background-color:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 4px #1a73e833}.create-modal-btn-create:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 8px #1a73e84d;transform:translateY(-1px)}.create-modal-btn-create:active:not(:disabled){transform:scale(.98)}.node-actions-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.node-actions-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:320px;animation:slideUp .3s ease-out}.node-actions-header{position:relative;padding:50px var(--space-lg) 15px;display:flex;align-items:center;justify-content:center}.node-actions-title{position:relative;margin:0;font-size:25px;font-weight:500;font-family:var(--font-family);color:var(--text-main);line-height:1.4;word-break:break-word;text-align:center;cursor:default;transition:color .2s ease}.node-actions-title:hover{color:var(--primary)}.info-tooltip{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background-color:#1a1a1a;color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);white-space:nowrap;font-size:var(--font-xs);font-weight:400;z-index:1001;box-shadow:0 4px 12px #0006}.node-actions-title:hover .info-tooltip{display:block}.tooltip-row{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.15)}.tooltip-icon{font-size:18px;line-height:1}.tooltip-type{font-size:var(--font-sm);font-weight:600}.tooltip-item{font-size:var(--font-xs);line-height:1.6;color:#ffffffe6}.node-actions-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.node-actions-close:hover{color:var(--text-main)}.node-actions-body{padding:15px var(--space-lg) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.node-action-btn{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-main);cursor:pointer;transition:all .2s ease;text-align:left}.node-action-btn:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-1)}.node-action-btn:active{transform:translateY(0)}.action-icon{font-size:20px;line-height:1;flex-shrink:0}.action-label{flex:1}.node-action-btn-danger{border-color:var(--error);color:var(--error)}.node-action-btn-danger:hover{border-color:var(--error);background:#d930250d;box-shadow:0 2px 4px #d9302533}.move-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.move-modal-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:slideUp .3s ease-out}.move-modal-header{position:relative;padding:50px var(--space-lg) 15px;display:flex;align-items:center;justify-content:center}.move-modal-title{position:relative;margin:0;font-size:25px;font-weight:500;font-family:var(--font-family);color:var(--text-main);line-height:1.4;text-align:center}.move-modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.move-modal-close:hover{color:var(--text-main)}.move-modal-body{padding:15px var(--space-lg) var(--space-lg);position:relative}.move-modal-label{display:block;font-size:16px;font-weight:500;font-family:var(--font-family);color:var(--text-main);margin-bottom:var(--space-xs)}.move-modal-input{width:100%;height:36px;padding:var(--space-sm) var(--space-md);font-size:var(--font-md);font-family:var(--font-family);border:2px solid var(--border);border-radius:var(--radius-sm);transition:border-color .2s ease;box-sizing:border-box}.move-modal-input:focus{outline:none;border-color:var(--primary)}.move-modal-input.shake{animation:shake .3s ease-in-out;border-color:var(--error)}.folder-dropdown{position:absolute;top:calc(100% - 8px);left:var(--space-lg);right:var(--space-lg);max-height:300px;overflow-y:auto;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-2);z-index:10}.folder-tree-list{padding:var(--space-xs) 0}.folder-tree-item{-webkit-user-select:none;user-select:none}.folder-tree-row{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background-color .15s ease}.folder-tree-row:hover{background-color:var(--bg-hover)}.expand-icon{width:16px;font-size:10px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expand-icon-placeholder{width:16px;flex-shrink:0}.folder-name{font-size:18px;font-weight:500;font-family:var(--font-family);color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-loading{padding:var(--space-sm) var(--space-md);font-size:var(--font-sm);color:var(--text-secondary)}.folder-tree-empty{padding:var(--space-md);text-align:center;font-size:var(--font-sm);color:var(--text-secondary)}.move-modal-footer{padding:var(--space-md) var(--space-lg) var(--space-lg);display:flex;gap:var(--space-sm);justify-content:flex-end}.move-modal-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.move-modal-btn:disabled{opacity:.5;cursor:not-allowed}.move-modal-btn-cancel{background:transparent;border-color:var(--border);color:var(--text-secondary)}.move-modal-btn-cancel:hover:not(:disabled){border-color:var(--text-secondary);color:var(--text-main)}.move-modal-btn-move{background-color:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 4px #1a73e833}.move-modal-btn-move:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 8px #1a73e84d;transform:translateY(-1px)}.move-modal-btn-move:active:not(:disabled){transform:scale(.98)}.rename-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.rename-modal-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:slideUp .3s ease-out}.rename-modal-header{position:relative;padding:50px var(--space-lg) 15px;display:flex;align-items:center;justify-content:center}.rename-modal-title{position:relative;margin:0;font-size:25px;font-weight:500;font-family:var(--font-family);color:var(--text-main);line-height:1.4;text-align:center}.rename-modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.rename-modal-close:hover{color:var(--text-main)}.rename-modal-body{padding:15px var(--space-lg) var(--space-lg)}.rename-modal-label{display:block;font-size:16px;font-weight:500;font-family:var(--font-family);color:var(--text-main);margin-bottom:var(--space-xs)}.rename-modal-input{width:100%;height:36px;padding:var(--space-sm) var(--space-md);font-size:var(--font-md);font-family:var(--font-family);border:2px solid var(--border);border-radius:var(--radius-sm);transition:border-color .2s ease;box-sizing:border-box}.rename-modal-input:focus{outline:none;border-color:var(--primary)}.rename-modal-input:disabled{opacity:.5;cursor:not-allowed}.rename-modal-error{margin-top:var(--space-xs);font-size:var(--font-sm);color:var(--error);animation:shake .3s ease-in-out}.rename-modal-footer{padding:var(--space-md) var(--space-lg) var(--space-lg);display:flex;gap:var(--space-sm);justify-content:flex-end}.rename-modal-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.rename-modal-btn:disabled{opacity:.5;cursor:not-allowed}.rename-modal-btn-cancel{background:transparent;border-color:var(--border);color:var(--text-secondary)}.rename-modal-btn-cancel:hover:not(:disabled){border-color:var(--text-secondary);color:var(--text-main)}.rename-modal-btn-rename{background-color:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 4px #1a73e833}.rename-modal-btn-rename:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 8px #1a73e84d;transform:translateY(-1px)}.rename-modal-btn-rename:active:not(:disabled){transform:scale(.98)}.delete-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.delete-modal-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:slideUp .3s ease-out}.delete-modal-header{position:relative;padding:50px var(--space-lg) 15px;display:flex;align-items:center;justify-content:center}.delete-modal-title{position:relative;margin:0;font-size:25px;font-weight:500;font-family:var(--font-family);color:var(--text-main);line-height:1.4;text-align:center}.delete-modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.delete-modal-close:hover{color:var(--text-main)}.delete-modal-body{padding:15px var(--space-lg) var(--space-lg)}.delete-modal-warning{text-align:center}.delete-modal-message{font-size:16px;font-family:var(--font-family);color:var(--text-main);margin:0 0 var(--space-md) 0;line-height:1.5}.delete-modal-node-info{font-size:18px;font-family:var(--font-family);color:var(--text-main);margin:var(--space-md) 0;padding:var(--space-md);background-color:var(--bg-hover);border-radius:var(--radius-sm)}.delete-modal-hint{font-size:14px;font-family:var(--font-family);color:var(--text-secondary);margin:var(--space-md) 0 0 0;font-style:italic}.delete-modal-error{margin-top:var(--space-md);font-size:var(--font-sm);color:var(--error);text-align:center;animation:shake .3s ease-in-out}.delete-modal-footer{padding:var(--space-md) var(--space-lg) var(--space-lg);display:flex;gap:var(--space-sm);justify-content:flex-end}.delete-modal-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.delete-modal-btn:disabled{opacity:.5;cursor:not-allowed}.delete-modal-btn-cancel{background:transparent;border-color:var(--primary);color:var(--primary)}.delete-modal-btn-cancel:hover:not(:disabled){background-color:var(--primary);color:#fff;box-shadow:0 2px 4px #1a73e833}.delete-modal-btn-delete{background:transparent;border-color:var(--error);color:var(--error)}.delete-modal-btn-delete:hover:not(:disabled){background-color:var(--error);color:#fff;box-shadow:0 2px 4px #dc26264d;transform:translateY(-1px)}.delete-modal-btn-delete:active:not(:disabled){transform:scale(.98)}.drag-move-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.drag-move-modal-card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.drag-move-modal-header{position:relative;padding:50px var(--space-lg) 15px;display:flex;align-items:center;justify-content:center}.drag-move-modal-title{position:relative;margin:0;font-size:25px;font-weight:500;font-family:var(--font-family);color:var(--text-main);line-height:1.4;text-align:center}.drag-move-modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.drag-move-modal-close:hover{color:var(--text-main)}.drag-move-modal-body{padding:15px var(--space-lg) var(--space-lg)}.drag-move-modal-confirmation{text-align:center}.drag-move-modal-message{font-size:16px;font-family:var(--font-family);color:var(--text-main);margin:0 0 var(--space-sm) 0;line-height:1.5}.drag-move-modal-node-info{font-size:18px;font-family:var(--font-family);color:var(--text-main);margin:var(--space-sm) 0;padding:var(--space-md);background-color:var(--bg-hover);border-radius:var(--radius-sm)}.drag-move-modal-error{margin-top:var(--space-md);font-size:var(--font-sm);color:var(--error);text-align:center;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.drag-move-modal-footer{padding:var(--space-md) var(--space-lg) var(--space-lg);display:flex;gap:var(--space-sm);justify-content:flex-end}.drag-move-modal-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.drag-move-modal-btn:disabled{opacity:.5;cursor:not-allowed}.drag-move-modal-btn-cancel{background:transparent;border-color:var(--primary);color:var(--primary)}.drag-move-modal-btn-cancel:hover:not(:disabled){background-color:var(--primary);color:#fff;box-shadow:0 2px 4px #1a73e833}.drag-move-modal-btn-confirm{background-color:var(--primary);border-color:var(--primary);color:#fff}.drag-move-modal-btn-confirm:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 2px 4px #1a73e84d;transform:translateY(-1px)}.drag-move-modal-btn-confirm:active:not(:disabled){transform:scale(.98)}.logout-button-wrapper{position:relative;width:200px;margin:0 auto;padding:var(--space-md)}.logout-button{width:200px;padding:var(--space-xs) var(--space-sm);font-size:var(--font-md);border:2px solid var(--primary);background:transparent;color:var(--primary);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-family);font-weight:500;transition:all .2s ease;text-align:center}.logout-button:hover{border-color:var(--error);color:var(--error)}.logout-button:active{transform:scale(.98)}.logout-dialog{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:200px;background-color:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-3);padding:var(--space-md);z-index:1001;animation:dialogSlideUp .2s ease-out}@keyframes dialogSlideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.logout-dialog-text{margin:0 0 var(--space-md) 0;font-size:var(--font-sm);color:var(--text-main);text-align:center;line-height:1.4}.logout-dialog-buttons{display:flex;gap:var(--space-sm);justify-content:center}.logout-dialog-btn{flex:1;padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-family);font-weight:500;transition:all .2s ease;border:2px solid}.logout-btn-no{border-color:var(--primary);background:transparent;color:var(--primary)}.logout-btn-no:hover{background-color:var(--primary-bg)}.logout-btn-yes{border-color:var(--error);background:transparent;color:var(--error)}.logout-btn-yes:hover{background-color:#d9302514}.logout-dialog-btn:active{transform:scale(.97)}.test-sign-banner{position:relative;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-left:4px solid #1976d2;border-radius:8px;padding:12px 48px 12px 16px;margin:0 var(--space-lg);margin-bottom:var(--space-md);box-shadow:0 2px 8px #1976d226;animation:slideDown .4s ease-out;z-index:50}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.test-sign-content{display:flex;align-items:center;gap:12px}.test-sign-icon{font-size:24px;flex-shrink:0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.test-sign-text{flex:1;font-size:16px;line-height:1.6;color:#0d47a1;font-family:var(--font-family)}.test-sign-text strong{font-weight:600;color:#01579b}.test-sign-link{color:#1976d2;text-decoration:none;font-weight:500;transition:all .2s ease;border-bottom:1px solid transparent}.test-sign-link:hover{color:#0d47a1;border-bottom-color:#0d47a1}.test-sign-wechat{font-family:Courier New,monospace;background-color:#1976d21a;padding:2px 6px;border-radius:4px;font-weight:500;color:#01579b;font-size:16px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.test-sign-wechat:hover{background-color:#1976d233;transform:scale(1.05)}.test-sign-wechat:active{transform:scale(.98)}.test-sign-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:#1976d2;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.test-sign-close:hover{background-color:#1976d226;color:#0d47a1;transform:rotate(90deg)}.test-sign-close:active{transform:rotate(90deg) scale(.9)}.test-sign-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background-color:#2e2e2e;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;gap:8px;font-size:15px;font-family:var(--font-family);z-index:10000;animation:toastSlideIn .3s ease-out}.test-sign-toast.fade-out{animation:toastFadeOut .3s ease-out forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastFadeOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}.test-sign-toast-icon{color:#4caf50;font-size:18px;font-weight:700}.sort-toggles{display:flex;gap:8px;align-items:center}.sort-toggle{display:flex;align-items:center;gap:4px;padding:6px 12px;background-color:transparent;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#6b7280}.sort-toggle:hover{background-color:#f3f4f6;border-color:#9ca3af}.sort-toggle[data-state=on]{background-color:#1a73e8;border-color:#1a73e8;color:#fff}.sort-toggle[data-state=on]:hover{background-color:#1557b0;border-color:#1557b0}.sort-toggle-icon{width:16px;height:16px}.sort-direction-icon{width:14px;height:14px}.sort-tooltip-content{background-color:#000;color:#fff;padding:8px 12px;border-radius:4px;font-size:13px;line-height:1.4;box-shadow:0 2px 8px #00000026;z-index:1000;animation:fadeIn .2s ease-out}.sort-tooltip-arrow{fill:#000}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}:root{--primary: #1A73E8;--primary-hover: #174EA6;--primary-bg: #E8F0FE;--surface: #FFFFFF;--bg-app: #F8F9FA;--text-main: #202124;--text-secondary: #5F6368;--text-disabled: #DADCE0;--border: #DADCE0;--success: #1E8E3E;--error: #D93025;--warning: #F9AB00;--font-family: "Google Sans", "Roboto", -apple-system, sans-serif;--font-xs: 12px;--font-sm: 14px;--font-md: 16px;--font-lg: 20px;--font-xl: 24px;--radius-pill: 20px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--shadow-1: 0 1px 2px 0 rgba(60,64,67,.3), 0 1px 3px 1px rgba(60,64,67,.15);--shadow-2: 0 4px 8px 3px rgba(60,64,67,.15);--shadow-3: 0 8px 16px 4px rgba(60,64,67,.15);--overlay-bg: rgba(0, 0, 0, .4);--bg-secondary: #EEEEEE;--bg-hover: rgba(0, 0, 0, .04)}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:var(--bg-app)}.login-card{background-color:var(--surface);padding:var(--space-xl);border-radius:var(--radius-md);box-shadow:var(--shadow-1);width:100%;max-width:400px}.login-title{font-family:var(--font-family);font-size:var(--font-xl);color:var(--text-main);margin-bottom:var(--space-lg);text-align:center}.login-footer{margin-top:var(--space-lg);text-align:center;font-size:var(--font-sm);color:var(--text-secondary)}.login-footer a{color:var(--primary);text-decoration:none}.login-footer a:hover{text-decoration:underline}.signup-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:var(--bg-app)}.signup-card{background-color:var(--surface);padding:var(--space-xl);border-radius:var(--radius-md);box-shadow:var(--shadow-1);width:100%;max-width:400px}.signup-title{font-family:var(--font-family);font-size:var(--font-xl);color:var(--text-main);margin-bottom:var(--space-lg);text-align:center}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-family:var(--font-family);font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-group input{width:100%;padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-sm);box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary)}.btn-primary{width:100%;padding:var(--space-sm) var(--space-md);background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-family);font-size:var(--font-sm);cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:var(--primary-hover)}.btn-primary:disabled{background-color:var(--text-disabled);cursor:not-allowed}.error-message{color:var(--error);font-size:var(--font-sm);margin-bottom:var(--space-md);min-height:20px;text-align:center}.signup-footer{margin-top:var(--space-lg);text-align:center;font-size:var(--font-sm);color:var(--text-secondary)}.signup-footer a{color:var(--primary);text-decoration:none}.signup-footer a:hover{text-decoration:underline}.hidden{display:none!important}.verification-text{font-family:var(--font-family);font-size:var(--font-sm);color:var(--text-secondary);text-align:center;margin-bottom:var(--space-lg)}.resend-container{margin-top:var(--space-md);text-align:center;font-size:var(--font-sm)}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-sm);padding:0}.btn-link:hover{text-decoration:underline}.btn-link:disabled{color:var(--text-disabled);cursor:default;text-decoration:none}.workspace-container{display:grid;grid-template-columns:280px 1fr;min-height:calc(100vh - 200px);background-color:var(--bg-app);font-family:var(--font-family)}.workspace-sidebar{background-color:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:var(--space-md);position:sticky;top:0;height:calc(100vh - 120px);overflow-y:auto;align-self:flex-start}.sidebar-header{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-sm);position:relative;z-index:101}.sidebar-header .btn-primary{width:200px;align-self:center;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);font-size:var(--font-md);font-weight:500;font-family:var(--font-family);background-color:var(--primary);color:#fff;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #1a73e833}.sidebar-header .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 8px #1a73e84d;background-color:var(--primary-hover)}.sidebar-header .btn-primary:active{transform:scale(.98)}.sidebar-header h2{font-size:var(--font-md);color:var(--text-main)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-md)}.workspace-search-row{width:200px;position:relative}#workspace-search-input{width:200px;padding:6px 28px 6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:var(--font-family);box-sizing:border-box}#workspace-search-input:focus{outline:none;border-color:var(--primary)}#workspace-search-clear{position:absolute;top:50%;right:6px;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;border:none;background:#e0e0e0;color:#333;font-size:12px;line-height:1;cursor:pointer}#workspace-search-clear:hover{background:#d0d0d0}.form-error{margin-top:6px;font-size:12px;color:var(--error);min-height:14px}.workspace-main{display:flex;flex-direction:column;position:relative;min-height:100vh}.workspace-main:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:url(/assets/desktop/cat_mainpage.png?v=3) center center no-repeat;background-size:contain;z-index:1;pointer-events:none;opacity:1}.main-header{background-color:var(--surface);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-md);position:relative;z-index:100}.breadcrumb{display:flex;gap:var(--space-xs);font-size:var(--font-sm);color:var(--text-secondary);position:relative;z-index:101}.breadcrumb-item{cursor:pointer}.breadcrumb-item:hover{color:var(--primary);text-decoration:underline}.breadcrumb-item:after{content:"/";margin-left:var(--space-xs);color:var(--text-disabled)}.breadcrumb-item:last-child:after{content:""}.path-jump{flex:0 0 320px}.view-options{margin-left:auto;display:flex;align-items:center}#path-input{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:var(--font-family);position:relative;z-index:101}#path-input:focus{outline:none;border-color:var(--primary)}.path-input-shake{animation:path-shake .3s ease-in-out}@keyframes path-shake{0%{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-3px)}to{transform:translate(0)}}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-lg);padding:var(--space-lg);position:relative;background-color:#ffffff0a}.grid-item{background-color:#ffffffb3;border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s,box-shadow .2s;border:1px solid transparent;position:relative;z-index:10}.grid-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:var(--primary-bg)}.grid-item.drag-over{border-color:var(--primary);box-shadow:var(--shadow-1);transform:translateY(-2px)}.grid-item.shake{animation:item-shake .3s ease-in-out}@keyframes item-shake{0%{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-3px)}to{transform:translate(0)}}.item-icon{color:var(--primary);margin-bottom:var(--space-sm);position:relative;z-index:10}.item-info{text-align:center;width:100%}.item-title{display:block;font-size:var(--font-sm);font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative;z-index:10}.item-meta{font-size:var(--font-xs);color:var(--text-secondary);position:relative;z-index:10}.item-title-input{width:100%;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:var(--font-family)}.item-error{display:block;min-height:14px;font-size:12px;color:var(--error);margin-top:4px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);width:100%;max-width:450px;display:flex;flex-direction:column}.modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;cursor:move}.modal-header h3{margin:0;font-size:var(--font-lg)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary)}.modal-body{padding:var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--space-md)}.btn-text{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-sm) var(--space-md)}.btn-text:hover{color:var(--text-main)}.action-card,.move-card,.confirm-card{max-width:420px}.modal-title-group{display:flex;flex-direction:column;gap:4px}.modal-eyebrow{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.modal-title{margin:0}.action-body{display:grid;gap:var(--space-md)}.action-btn{border:1px solid var(--border);background:var(--surface);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s}.action-btn:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-1)}.action-btn.danger{border-color:var(--danger, #e05d5d);color:var(--danger, #e05d5d)}.confirm-text{margin:0;color:var(--text-main);font-size:var(--font-sm)}.btn-danger{background:var(--danger, #e05d5d);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer}#logout-button-container{margin-top:auto}.study-container{display:grid;--splitter-width: 8px;--study-left-width: 240px;--study-right-width: 320px;grid-template-columns:var(--study-left-width) var(--splitter-width) 1fr var(--splitter-width) var(--study-right-width);background-color:var(--bg-app);font-family:var(--font-family);margin-bottom:60px}.study-sidebar,.study-right-panel{background-color:var(--surface);display:flex;flex-direction:column;min-height:0;position:relative;z-index:3}.study-right-panel{border-left:none}.panel-splitter{width:var(--splitter-width);cursor:col-resize;background:linear-gradient(to right,transparent,rgba(0,0,0,.08),transparent);position:relative;z-index:2}.panel-splitter:hover:after{opacity:1}.panel-splitter:after{content:"";position:absolute;top:0;bottom:0;left:2px;right:2px;background:#00000014;opacity:0;transition:opacity .2s}.panel-header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:relative;z-index:4}.panel-header-left{display:flex;align-items:center;gap:var(--space-sm)}.btn-back{font-size:var(--font-xs);padding:var(--space-xs) var(--space-sm)}.panel-header h3{font-size:var(--font-sm);margin:0}.panel-actions{display:flex;gap:var(--space-xs);position:relative;z-index:5}.chapter-list{flex:1;min-height:0}.chapter-empty{padding:var(--space-md);color:var(--text-secondary);font-size:var(--font-sm)}.chapter-item{padding:var(--space-sm) var(--space-md);cursor:pointer;display:flex;gap:var(--space-sm);font-size:var(--font-sm);border-bottom:1px solid var(--bg-app)}.chapter-item:hover{background-color:var(--primary-bg)}.chapter-item.active{background-color:var(--primary-bg);color:var(--primary);font-weight:600}.chapter-order{color:var(--text-secondary);min-width:20px}.study-center-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);background-color:var(--bg-app);min-height:0;gap:var(--space-lg)}.board-mount{width:100%;flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.board-mount>.chessboard{width:100%;height:100%;aspect-ratio:1 / 1;box-shadow:var(--shadow-2)}.board-mount>.chessboard-v2{width:66.6667%;height:auto;aspect-ratio:1 / 1;margin-left:auto;margin-right:auto;box-shadow:var(--shadow-2)}.board-mount .chessboard .square{aspect-ratio:1 / 1}.board-controls{margin-top:var(--space-lg);display:flex;gap:var(--space-md)}.panel-tabs{display:flex;border-bottom:1px solid var(--border)}.tab-btn{flex:1;padding:var(--space-sm);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:var(--font-xs);font-weight:600;color:var(--text-secondary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-content{display:none;flex:1;padding:var(--space-md);min-height:0}.tab-content.active{display:flex;flex-direction:column}.tab-content#tab-pgn{overflow:hidden}.analysis-module{margin-bottom:var(--space-md)}.move-tree{font-size:var(--font-sm);line-height:1.6;flex:1;min-height:0}.move-tree-row{display:grid;grid-template-columns:40px 1fr 1fr;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs)}.move-tree-number{color:var(--text-secondary);font-variant-numeric:tabular-nums}.move-tree-move{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-panel);padding:var(--space-xxs) var(--space-xs);text-align:left;cursor:pointer}.move-tree-move:disabled{opacity:.4;cursor:default}.move-tree-move:not(:disabled):hover{background:var(--bg-app)}.pgn-comment{margin-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);flex-shrink:0}.pgn-comment-tabs{display:flex;gap:var(--space-xs);align-items:center}.pgn-tab-btn{border:1px solid var(--border);border-radius:999px;background:var(--bg-panel);padding:4px 10px;font-size:var(--font-xs);cursor:pointer}.pgn-tab-btn.active{background:var(--text-primary);color:var(--bg-app)}.pgn-comment-panel{display:none;flex-direction:column;gap:var(--space-sm)}.pgn-comment-panel.active{display:flex}#pgn-comment-input{width:100%;min-height:70px;padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-sm);resize:vertical}#pgn-fen-display{width:100%;min-height:70px;padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--font-sm);resize:vertical}.move-tree-empty,.board-empty,.discussion-empty{color:var(--text-secondary);font-size:var(--font-sm)}.btn-icon{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);cursor:pointer}.btn-icon:hover{background-color:var(--bg-app)}.discussion-container{display:flex;flex-direction:column;height:100%}.discussion-thread-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-md);padding-bottom:var(--space-md)}.discussion-thread-item{border-bottom:1px solid var(--bg-app);padding-bottom:var(--space-sm)}.discussion-thread-header{display:flex;justify-content:space-between;font-size:var(--font-xs);margin-bottom:var(--space-xs)}.discussion-thread-author{font-weight:600;color:var(--text-main)}.discussion-thread-date{color:var(--text-secondary)}.discussion-thread-content{font-size:var(--font-sm);color:var(--text-main);line-height:1.4}.discussion-thread-actions{margin-top:var(--space-xs);display:flex;gap:var(--space-md)}.discussion-input-area{border-top:1px solid var(--border);padding-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}#discussion-input{width:100%;min-height:80px;padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-sm);resize:vertical}.discussion-input-controls{display:flex;justify-content:flex-end}.btn-xs{padding:2px 4px;font-size:11px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:100px;background-color:#fff;border-bottom:1px solid #dbdbdb;font-family:Roboto,sans-serif;position:sticky;top:0;z-index:1000}.header-left{display:flex;align-items:center;gap:24px}.header-left .logo{display:flex;align-items:center;text-decoration:none;color:#202124;height:100%}.header-left .logo-image{height:100px;width:auto;display:block}.header-center{display:flex;align-items:center;gap:8px}.header-center .nav-link{font-size:20px;font-weight:500;color:#5f6368;text-decoration:none;padding:8px 16px;border-radius:4px;transition:background-color .3s}.header-center .nav-link:hover{background-color:#f1f3f4}.header-right .username{font-size:18px;font-weight:500;color:#202124}.header-right .nav-link{font-size:18px;font-weight:500;color:#1a73e8;text-decoration:none}.header-right{display:flex;align-items:center;gap:12px}body{background:var(--bg-app, #F8F9FA);margin:0}main{background:transparent}.app-footer{position:relative;width:100%;background:linear-gradient(135deg,#231a4a,#2d1f5c,#1a0f3a);color:#fff;padding:2rem 3rem 1.5rem;margin-top:auto;overflow:hidden}.app-footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(212,175,55,.6) 20%,rgba(240,198,116,.8) 50%,rgba(212,175,55,.6) 80%,transparent 100%)}.footer-gradient-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at bottom,rgba(138,103,255,.08) 0%,transparent 60%);pointer-events:none}.footer-content{position:relative;display:grid;grid-template-columns:1.2fr 1fr 1.5fr;gap:3rem;max-width:1400px;margin:0 auto;margin-bottom:1.5rem}.footer-main{display:flex;align-items:center}.footer-brand{display:flex;align-items:center;gap:1.2rem}.brand-icon{font-size:3.5rem;color:#d4af37;text-shadow:0 0 20px rgba(212,175,55,.5);animation:gentleGlow 3s ease-in-out infinite}@keyframes gentleGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}.brand-text{display:flex;flex-direction:column;gap:.2rem}.brand-title{font-size:.75rem;text-transform:uppercase;letter-spacing:2px;color:#fff9;font-weight:500;margin:0}.brand-names{font-size:1.3rem;font-weight:600;margin:0;background:linear-gradient(135deg,#fff,#e0d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-contact{display:flex;flex-direction:column;gap:.8rem}.footer-heading{font-size:.9rem;text-transform:uppercase;letter-spacing:1.5px;color:#d4af37;margin:0 0 .8rem;font-weight:600}.contact-item{display:flex;align-items:center;gap:.7rem;font-size:.9rem;line-height:1.6}.contact-icon{width:18px;height:18px;color:#d4af37;flex-shrink:0;opacity:.9}.contact-label{color:#ffffffb3;font-size:.85rem;margin-right:-.3rem}.contact-link{color:#ffffffd9;text-decoration:none;transition:all .3s ease;position:relative}.contact-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:linear-gradient(90deg,#d4af37,#f0c674);transition:width .3s ease}.contact-link:hover{color:#fff}.contact-link:hover:after{width:100%}.contact-text{color:#ffffffd9}.footer-appreciation{display:flex;flex-direction:column;gap:.8rem}.appreciation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem 1.2rem}.appreciation-name{font-size:.88rem;color:#fffc;position:relative;padding:.35rem 0 .35rem 1rem;transition:all .3s ease}.appreciation-name:before{content:"•";position:absolute;left:0;color:#8a67ff;font-size:1.2rem;line-height:1}.appreciation-name:hover{color:#fff;transform:translate(4px)}.footer-bottom{position:relative;padding-top:1rem;margin-top:.5rem}.footer-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);margin-bottom:1rem}.footer-copyright{text-align:center;font-size:.8rem;color:#ffffff80;margin:0;letter-spacing:.5px}@media (max-width: 1024px){.footer-content{grid-template-columns:1fr 1fr;gap:2rem}.footer-appreciation{grid-column:1 / -1}.appreciation-grid{grid-template-columns:repeat(3,1fr);gap:.4rem 1rem}}@media (max-width: 768px){.app-footer{padding:1.5rem 1.5rem 1rem}.footer-content{grid-template-columns:1fr;gap:1.5rem}.footer-appreciation{grid-column:auto}.appreciation-grid{grid-template-columns:repeat(2,1fr);gap:.4rem 1rem}.brand-icon{font-size:2.5rem}.brand-names{font-size:1.1rem}}@media (max-width: 480px){.appreciation-grid{grid-template-columns:1fr}.footer-content{gap:1.2rem}}.recent-articles-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:2px solid var(--border);border-radius:var(--radius-md);background-color:var(--surface);cursor:pointer;transition:all .2s ease;color:var(--text-secondary);padding:0}.recent-articles-trigger:hover{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow-1)}.recent-articles-trigger:active{transform:scale(.95)}.recent-articles-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-bg);animation:fadeIn .2s ease-out;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.recent-articles-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-3);width:90%;max-width:500px;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease-out;z-index:1001}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.recent-articles-header{padding:var(--space-lg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-sm)}.recent-articles-icon{display:flex;align-items:center;justify-content:center;color:var(--primary)}.recent-articles-title{flex:1;margin:0;font-size:var(--font-lg);font-weight:600;font-family:var(--font-family);color:var(--text-main)}.recent-articles-close{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.recent-articles-close:hover{color:var(--text-main)}.recent-articles-description{padding:var(--space-md) var(--space-lg) 0;font-size:var(--font-sm);font-family:var(--font-family);color:var(--text-secondary);margin:0}.recent-articles-body{padding:var(--space-lg)}.recent-articles-empty{text-align:center;padding:var(--space-xl) var(--space-lg)}.recent-articles-empty-icon{margin:0 auto var(--space-md);opacity:.3;color:var(--text-secondary)}.recent-articles-empty-title{font-size:var(--font-md);font-family:var(--font-family);font-weight:500;color:var(--text-main);margin:0 0 var(--space-xs) 0}.recent-articles-empty-subtitle{font-size:var(--font-sm);font-family:var(--font-family);color:var(--text-secondary);margin:0}.recent-articles-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.recent-articles-item{width:100%;padding:var(--space-md);border:2px solid var(--border);border-radius:var(--radius-md);background-color:var(--surface);cursor:pointer;text-align:left;transition:all .2s ease;display:flex;align-items:center;gap:var(--space-md);font-family:var(--font-family)}.recent-articles-item:hover{border-color:var(--primary);background-color:var(--primary-bg);transform:translate(4px);box-shadow:var(--shadow-1)}.recent-articles-item:active{transform:translate(4px) scale(.98)}.recent-articles-item-number{font-size:var(--font-xs);font-weight:600;color:var(--primary);background-color:var(--primary-bg);padding:2px var(--space-sm);border-radius:var(--radius-sm);min-width:20px;text-align:center;flex-shrink:0}.recent-articles-item-title{font-size:var(--font-md);font-weight:600;font-family:var(--font-family);color:var(--text-main);margin:0;line-height:1.4;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-articles-item:hover .recent-articles-item-title{color:var(--primary)}.recent-articles-item-time{font-size:var(--font-xs);color:var(--text-secondary);flex-shrink:0;margin-left:auto}:root{--tagger-bg: #0f1216;--tagger-bg-soft: #151b22;--tagger-accent: #f2b33d;--tagger-accent-2: #4fc3d4;--tagger-text: #f7f2e8;--tagger-muted: #98a0a8;--tagger-card: #1b222b;--tagger-border: rgba(255, 255, 255, .08)}.tagger-page{min-height:calc(100vh - 80px);padding:48px 6vw 96px;background:radial-gradient(circle at top,#1f2732,#0f1216 55%);color:var(--tagger-text);font-family:Space Grotesk,Segoe UI,sans-serif;position:relative;overflow:hidden}.tagger-page:before,.tagger-page:after{content:"";position:absolute;border-radius:999px;filter:blur(0);opacity:.9;z-index:0}.tagger-page:before{width:420px;height:420px;right:-140px;top:-140px;background:radial-gradient(circle,rgba(79,195,212,.25),transparent 70%)}.tagger-page:after{width:320px;height:320px;left:-120px;bottom:-120px;background:radial-gradient(circle,rgba(242,179,61,.2),transparent 70%)}.tagger-page>*{position:relative;z-index:1}.tagger-kicker{text-transform:uppercase;letter-spacing:.32em;font-size:.7rem;color:var(--tagger-accent)}.tagger-hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:32px;align-items:stretch;margin-bottom:48px;animation:taggerReveal .7s ease-out}.tagger-hero-copy h1,.tagger-detail-hero h1{font-family:Spectral,Times New Roman,serif;font-size:clamp(2.4rem,3vw,3.2rem);margin:12px 0}.tagger-hero-copy p{color:var(--tagger-muted);max-width:520px;font-size:1.05rem}.tagger-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;animation:taggerReveal .7s ease-out .1s both}.tagger-card{background:var(--tagger-card);border-radius:18px;padding:18px;border:1px solid var(--tagger-border);text-decoration:none;color:inherit;display:grid;gap:16px;transition:transform .25s ease,box-shadow .25s ease}.tagger-card:hover{transform:translateY(-4px);box-shadow:0 24px 40px #00000059}.tagger-card-top{display:flex;justify-content:space-between;align-items:center}.tagger-card-title{font-size:1.1rem;font-weight:600}.tagger-chip{font-size:.7rem;padding:4px 10px;border-radius:999px;border:1px solid rgba(79,195,212,.4);color:var(--tagger-accent-2)}.tagger-card-body{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tagger-card-label{color:var(--tagger-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em}.tagger-card-value{font-size:1.1rem;font-weight:600}.tagger-card-foot{font-size:.8rem;color:var(--tagger-muted)}.tagger-panel{background:var(--tagger-card);padding:22px;border-radius:18px;border:1px solid var(--tagger-border);box-shadow:0 18px 30px #0000004d}.tagger-panel h2{margin-top:0}.tagger-mode{display:grid;gap:12px;padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#0c0f1399}.tagger-mode-header{display:flex;justify-content:space-between;gap:12px;align-items:center}.tagger-mode-label{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;color:var(--tagger-muted)}.tagger-mode-copy{margin:6px 0 0;font-size:.85rem;color:var(--tagger-muted)}.tagger-mode-pill{font-size:.75rem;padding:6px 12px;border-radius:999px;border:1px solid rgba(79,195,212,.4);color:var(--tagger-accent-2);text-transform:uppercase;letter-spacing:.12em}.tagger-mode-options{display:flex;gap:10px;flex-wrap:wrap}.tagger-mode-options button{border:1px solid var(--tagger-border);background:transparent;color:var(--tagger-muted);padding:10px 14px;border-radius:999px;cursor:pointer;font-weight:600}.tagger-mode-options button.active{background:var(--tagger-accent);color:#141414;border-color:transparent}.tagger-mode-options button:disabled{cursor:not-allowed;opacity:.6}.tagger-mode-help{margin:0;font-size:.82rem;color:var(--tagger-muted)}.tagger-panel-wide,.tagger-form{display:grid;gap:18px}.tagger-form label{font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--tagger-muted)}.tagger-form input{width:100%;padding:12px 14px;margin-top:6px;border-radius:12px;border:1px solid transparent;background:#0f141a;color:var(--tagger-text);font-size:.95rem}.tagger-form button,.tagger-actions button,.tagger-back,.tagger-confirm{background:var(--tagger-accent);color:#141414;border:none;padding:12px 20px;border-radius:999px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.tagger-form button:hover,.tagger-actions button:hover,.tagger-back:hover,.tagger-confirm:hover{transform:translateY(-1px);box-shadow:0 12px 30px #f2b33d40}.tagger-actions button:disabled{cursor:not-allowed;opacity:.65;box-shadow:none;transform:none}.tagger-upload{display:grid;place-items:center;border:1px dashed rgba(255,255,255,.2);padding:28px;border-radius:16px;background:#0f121699;cursor:pointer}.tagger-progress-block{margin-top:14px;display:grid;gap:8px}.tagger-progress-label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--tagger-muted)}.tagger-upload input{display:none}.tagger-upload-meta{display:grid;gap:12px;margin-top:18px}.tagger-log{margin-top:16px;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#0c0f13b3;display:grid;gap:6px;font-size:.85rem;max-height:220px;overflow-y:auto}.tagger-log span{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;color:var(--tagger-muted)}.tagger-log-line{color:var(--tagger-text)}.tagger-log-line.muted{color:var(--tagger-muted)}.tagger-upload-meta div{display:flex;justify-content:space-between;font-size:.9rem}.tagger-warning{margin-top:14px;padding:12px 14px;background:#f2b33d1f;border:1px solid rgba(242,179,61,.2);border-radius:12px;color:var(--tagger-accent)}.tagger-detail-hero{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:32px;animation:taggerReveal .6s ease-out}.tagger-status{background:var(--tagger-card);padding:18px 20px;border-radius:16px;border:1px solid var(--tagger-border);display:grid;gap:6px}.tagger-status span{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--tagger-muted)}.tagger-status strong{font-size:1.2rem}.tagger-columns{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.6fr);gap:24px}.tagger-panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.tagger-tabs{display:flex;gap:8px}.tagger-tabs button{border:1px solid var(--tagger-border);background:transparent;color:var(--tagger-muted);padding:8px 14px;border-radius:999px;cursor:pointer}.tagger-tabs button.active{background:var(--tagger-accent);color:#141414;border-color:transparent}.tagger-meta{display:flex;justify-content:space-between;font-size:.85rem;color:var(--tagger-muted)}.tagger-table{display:grid;gap:8px}.tagger-row{display:grid;grid-template-columns:1.2fr .6fr .6fr;padding:10px 14px;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.04)}.tagger-row-head{font-size:.75rem;text-transform:uppercase;letter-spacing:.16em;color:var(--tagger-muted);background:transparent;border:none}.tagger-actions{display:flex;gap:12px;justify-content:flex-end}.tagger-back{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--tagger-text);padding:8px 14px}.tagger-empty,.tagger-loading{padding:32px;background:#ffffff0a;border-radius:18px;text-align:center;border:1px dashed var(--tagger-border)}.tagger-progress{margin-top:16px;height:8px;background:#ffffff14;border-radius:999px;overflow:hidden}.tagger-progress-bar{height:100%;background:linear-gradient(90deg,var(--tagger-accent),var(--tagger-accent-2));border-radius:999px;transition:width .3s ease}.tagger-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080ab3;display:grid;place-items:center;z-index:40}.tagger-modal{background:var(--tagger-card);border-radius:16px;padding:24px;border:1px solid var(--tagger-border);max-width:420px;display:grid;gap:12px}.tagger-modal button{justify-self:end}.tagger-modal-list{font-size:.85rem;color:var(--tagger-muted);display:grid;gap:8px}.tagger-confirm{margin-top:18px}.tagger-error{margin-top:12px;color:#ff7a7a}.tagger-failed{display:grid;gap:10px;max-height:320px;overflow-y:auto;padding-right:6px}.tagger-failed-row{display:grid;grid-template-columns:.4fr .6fr 2fr;gap:12px;padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;font-size:.9rem}.tagger-failed-code{color:var(--tagger-accent);font-weight:600}.tagger-failed-msg{color:var(--tagger-muted)}.tagger-recompute{background:#2f3b4c;color:#f4f7fb}.tagger-recompute:hover{box-shadow:0 12px 30px #2f3b4c59}.tagger-delete{background:#d46a6a;color:#141414}.tagger-delete:hover{box-shadow:0 12px 30px #d46a6a59}.tagger-muted{color:var(--tagger-muted);font-size:.85rem}@keyframes taggerReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.tagger-hero,.tagger-columns{grid-template-columns:1fr}.tagger-panel-header{flex-direction:column;align-items:flex-start}.tagger-detail-hero{flex-direction:column}}@media (max-width: 640px){.tagger-page{padding:32px 5vw 72px}.tagger-card-body{grid-template-columns:1fr}.tagger-actions{flex-direction:column;align-items:stretch}}.terminal-window{display:flex;flex-direction:column;border-radius:4px;overflow:hidden;box-shadow:0 8px 32px #0006,0 2px 8px #0000004d;-webkit-user-select:none;user-select:none}.terminal-window.dos-style{border:2px solid #808080;background:silver}.terminal-window.unix-style{border:1px solid #3a3a3a;background:#2d2d2d}.terminal-window-titlebar{display:flex;align-items:center;justify-content:space-between;padding:2px 4px;cursor:move}.dos-style .terminal-window-titlebar{background:linear-gradient(to right,navy,#1084d0);color:#fff;font-family:"MS Sans Serif",Segoe UI,sans-serif;font-size:12px;font-weight:700;padding:2px 4px}.unix-style .terminal-window-titlebar{background:#3a3a3a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;padding:6px 12px}.terminal-window-title{flex:1}.terminal-window-controls{display:flex;gap:4px}.terminal-window-btn{border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}.dos-style .terminal-window-btn{width:16px;height:14px;background:silver;border:1px outset #c0c0c0;font-family:Marlett,sans-serif;font-size:10px;padding:0}.dos-style .terminal-window-btn:active{border-style:inset}.unix-style .terminal-window-btn{width:12px;height:12px;border-radius:50%;font-size:0;padding:0}.unix-style .terminal-window-btn.close{background:#ff5f57}.unix-style .terminal-window-btn.minimize{background:#ffbd2e}.unix-style .terminal-window-btn.maximize{background:#28ca41}.unix-style .terminal-window-btn:hover:after{font-size:10px;color:#0009}.unix-style .terminal-window-btn.close:hover:after{content:"×"}.unix-style .terminal-window-btn.minimize:hover:after{content:"−"}.unix-style .terminal-window-btn.maximize:hover:after{content:"+"}.terminal-window-toolbar{display:flex;align-items:center;gap:16px;padding:6px 8px;background:#e0e0e0;border-bottom:1px solid #888;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px}.system-picker{display:flex;align-items:center;gap:6px}.system-picker-label{color:#333}.system-picker-select{padding:2px 6px;border:1px solid #888;border-radius:3px;background:#fff;font-size:12px}.terminal-effects-toggle{display:flex;gap:12px}.terminal-effects-toggle label{display:flex;align-items:center;gap:4px;color:#333;cursor:pointer}.terminal-effects-toggle input[type=checkbox]{cursor:pointer}.terminal-window-content{flex:1;min-height:0;overflow:hidden}.terminal{width:100%;height:100%;padding:8px 12px;box-sizing:border-box;position:relative;overflow:hidden;font-size:16px;line-height:1.3}.terminal-scroll{height:100%;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1}.terminal-scroll::-webkit-scrollbar{width:12px}.terminal-scroll::-webkit-scrollbar-track{background:#0000004d}.terminal-scroll::-webkit-scrollbar-thumb{background:#fff3;border-radius:6px}.terminal-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.terminal-line{white-space:pre-wrap;word-break:break-all;min-height:1.3em}.terminal-prompt{-webkit-user-select:none;user-select:none}.terminal-input-line{display:flex;align-items:center;white-space:pre}.terminal-input-text{white-space:pre}.terminal-cursor{display:inline-block;width:.6em;height:1.1em;opacity:0;vertical-align:text-bottom;animation:none}.terminal-cursor.visible{opacity:1}.terminal-hidden-input{position:absolute;left:-9999px;opacity:0;width:1px;height:1px}.terminal-scanlines{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(0,0,0,.15) 0px,rgba(0,0,0,.15) 1px,transparent 1px,transparent 2px);z-index:10}.terminal-crt-glow{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;box-shadow:inset 0 0 60px #00ff001a;z-index:9}@keyframes flicker{0%{opacity:.97}50%{opacity:1}to{opacity:.98}}.terminal{animation:flicker .15s infinite}.resize-handle{position:absolute;z-index:100}.resize-handle.n{top:0;left:10px;right:10px;height:4px;cursor:ns-resize}.resize-handle.s{bottom:0;left:10px;right:10px;height:4px;cursor:ns-resize}.resize-handle.e{top:10px;right:0;bottom:10px;width:4px;cursor:ew-resize}.resize-handle.w{top:10px;left:0;bottom:10px;width:4px;cursor:ew-resize}.resize-handle.ne{top:0;right:0;width:10px;height:10px;cursor:nesw-resize}.resize-handle.nw{top:0;left:0;width:10px;height:10px;cursor:nwse-resize}.resize-handle.se{bottom:0;right:0;width:10px;height:10px;cursor:nwse-resize}.resize-handle.sw{bottom:0;left:0;width:10px;height:10px;cursor:nesw-resize}.terminal-window-minimized{position:fixed;bottom:10px;left:10px;padding:6px 12px;background:silver;border:2px outset #c0c0c0;font-family:"MS Sans Serif",Segoe UI,sans-serif;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;z-index:999}.terminal-window-minimized:hover{background:#d0d0d0}.terminal-window-minimized-icon{font-weight:700}.terminal-launcher{position:fixed;bottom:20px;right:20px;z-index:9999;width:48px;height:48px;border-radius:8px;border:none;cursor:pointer;background:#1a1a1a;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff1a;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.terminal-launcher:hover,.terminal-launcher.is-hovered{background:#2a2a2a;transform:scale(1.05);box-shadow:0 4px 16px #0006,0 0 20px #00ff0026,inset 0 1px #ffffff1a}.terminal-launcher:active{transform:scale(.95)}.terminal-launcher-icon{font-family:VT323,Courier New,monospace;font-size:22px;color:#0f0;text-shadow:0 0 8px rgba(0,255,0,.6);-webkit-user-select:none;user-select:none}.terminal-launcher:hover .terminal-launcher-icon{text-shadow:0 0 12px rgba(0,255,0,.8)}@keyframes terminal-pulse{0%,to{box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff1a}50%{box-shadow:0 2px 8px #0000004d,0 0 12px #00ff001a,inset 0 1px #ffffff1a}}.terminal-launcher{animation:terminal-pulse 3s ease-in-out infinite}.terminal-launcher:hover{animation:none}.cat-pet-container{display:inline-block;transition:opacity .2s ease}.cat-pet-container:hover{opacity:.95}.cat-pet-container.dragging{opacity:.8;transition:none}.cat-sprite{display:block;pointer-events:none;will-change:background-position}.cat-sprite{-ms-interpolation-mode:nearest-neighbor;image-rendering:-moz-crisp-edges;image-rendering:-webkit-optimize-contrast;image-rendering:pixelated;image-rendering:crisp-edges}.patch-study-page{display:flex;flex-direction:column;min-height:100vh;padding:16px;box-sizing:border-box;overflow:hidden}.patch-study-header{margin-bottom:16px;border:1px solid #000;padding:2px 12px;border-radius:6px;display:grid;grid-template-columns:1fr auto;grid-template-areas:"title actions" "notice status";align-items:center}.patch-study-header h2{margin:2px 0;font-size:40px;grid-area:title;justify-self:start;text-align:left}.patch-study-title{cursor:pointer;transition:background-color .2s;padding:2px 6px;border-radius:4px}.patch-study-title:hover{background-color:#f0f0f0}.patch-study-title-edit{grid-area:title;display:flex;flex-direction:column;gap:4px}.patch-study-title-input{font-size:40px;font-weight:700;border:2px solid #2e6bff;border-radius:4px;padding:2px 6px;outline:none;font-family:inherit;width:100%;box-sizing:border-box}.patch-study-title-error{color:#e74c3c;font-size:14px;margin-left:6px}.patch-study-notice{color:#888;font-size:16px;margin:0;grid-area:notice;justify-self:start;align-self:center}.patch-study-breadcrumb{color:#888;font-size:16px;margin:0;grid-area:notice;justify-self:start;align-self:center;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.breadcrumb-separator{color:#ccc;-webkit-user-select:none;user-select:none}.breadcrumb-item{padding:2px 6px;border-radius:3px;transition:all .2s}.breadcrumb-item.clickable{cursor:pointer;color:#2e6bff}.breadcrumb-item.clickable:hover{background-color:#e3f2ff;color:#1e5bd9}.breadcrumb-item.current{color:#333;font-weight:500;cursor:default}.patch-study-save-status{margin-top:0;color:#666;font-size:16px;grid-area:status;justify-self:end;align-self:center}.patch-study-actions{grid-area:actions;justify-self:end;align-self:center;display:flex;gap:2px;align-items:flex-end}.patch-study-save-button{background:#2e6bff;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:14px;cursor:pointer}.patch-study-save-button:disabled{opacity:.6;cursor:not-allowed}.patch-study-layout{display:flex;flex:0 0 600px;gap:16px;border:1px solid #000;border-radius:6px;padding:12px;min-height:0;height:600px;overflow:hidden;box-sizing:border-box}.patch-study-footer-row{display:flex;gap:16px;margin-top:12px}.patch-study-footer-spacer{width:280px;flex-shrink:0}.patch-study-footer-box{height:200px;border:1px solid #000;flex:1;padding:8px;box-sizing:border-box}.patch-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:10000}.patch-modal{background:#fff;border-radius:10px;padding:20px 24px;width:360px;box-shadow:0 10px 30px #0003}.patch-modal h3{margin:0 0 8px;font-size:18px;color:#111}.patch-modal p{margin:0 0 12px;color:#444;font-size:14px}.patch-modal-input{width:100%;margin-bottom:12px;padding:8px 10px;border:1px solid #cfcfcf;border-radius:6px;font-size:14px;box-sizing:border-box}.patch-modal-error{margin-bottom:12px;color:#b71c1c;font-size:13px}.patch-modal-actions{display:flex;justify-content:flex-end;gap:10px}.patch-modal-button{padding:6px 12px;border:1px solid #ccc;background:#fff;border-radius:6px;cursor:pointer}.patch-modal-button.primary{background:#2e6bff;border-color:#2e6bff;color:#fff}.patch-modal-button.secondary{background:#f5f5f5;border-color:#ddd;color:#333}.patch-modal-button:disabled{opacity:.6;cursor:not-allowed}.study-comment-box{width:100%;height:100%;display:flex;flex-direction:column;gap:8px;min-height:0}.study-comment-input{width:100%;height:100%;resize:none;border:1px solid #ccc;border-radius:4px;padding:8px;font-size:14px;box-sizing:border-box}.study-comment-tabs{display:flex;gap:6px;align-items:center}.study-comment-tab{padding:4px 12px;border:1px solid #242424;border-radius:999px;background:#f5f5f5;color:#111;font-size:12px;cursor:pointer}.study-comment-tab.is-active{background:#111;color:#fff}.study-comment-panel{flex:1;min-height:0}.study-info-panel{display:flex;flex-direction:column;gap:8px;height:auto}.study-fen-wrap{position:relative}.study-fen-box{width:100%;flex:0 0 auto;height:auto;resize:none;border:1px solid #ccc;border-radius:4px;padding:8px 96px 8px 8px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;box-sizing:border-box;text-align:left;line-height:1.4}.study-fen-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.study-fen-button{padding:6px 12px;border:1px solid #242424;background:#fff;border-radius:6px;cursor:pointer;font-size:12px}.study-fen-button.is-inline{position:absolute;right:10px;top:50%;transform:translateY(-50%)}.study-fen-button:disabled{opacity:.6;cursor:not-allowed}.patch-study-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;border-right:1px solid #000;padding-right:12px;min-height:0;overflow:hidden}.patch-sidebar-content{display:flex;flex-direction:column;gap:12px;min-height:0;flex:1}.patch-analysis-scroll{display:flex;flex-direction:column;gap:12px;min-height:0;flex:1;overflow-y:auto}.patch-sidebar-tabs{display:flex;gap:6px;align-items:center;border:1px solid #242424;border-radius:999px;padding:4px;background:#f5f5f5}.patch-sidebar-tab{border:none;background:transparent;padding:4px 10px;font-size:12px;cursor:pointer;border-radius:999px}.patch-sidebar-tab.is-active{background:#242424;color:#fff}.patch-analysis-settings{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;align-items:center;border:1px solid #242424;border-radius:6px;padding:8px;background:#fff}.patch-analysis-field{display:flex;flex-direction:column;gap:4px;font-size:12px}.patch-analysis-label{color:#242424;font-size:12px}.patch-analysis-field select{font-size:12px;width:100%}.patch-analysis-field select:disabled{opacity:.6;cursor:not-allowed}.patch-analysis-toggle{display:flex;align-items:center;height:100%}.patch-toggle{display:inline-flex;align-items:center;cursor:pointer}.patch-toggle input{position:absolute;opacity:0;width:0;height:0}.patch-toggle-track{width:36px;height:20px;background:#d1d1d1;border-radius:999px;position:relative;border:1px solid #bfbfbf;transition:background .2s,border-color .2s}.patch-toggle-track:after{content:"";position:absolute;width:16px;height:16px;left:1px;top:1px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #0003;transition:transform .2s}.patch-toggle input:checked+.patch-toggle-track{background:#242424;border-color:#242424}.patch-toggle input:checked+.patch-toggle-track:after{transform:translate(16px)}.patch-toggle input:focus-visible+.patch-toggle-track{outline:2px solid #242424;outline-offset:2px}.patch-analysis-panel{background:#f5f5f5;border:1px solid #242424;border-radius:6px;display:flex;flex-direction:column;min-height:0;flex:0 0 auto;padding:8px;gap:8px}.patch-imitator-panel{background:#fff}.patch-imitator-settings{display:grid;grid-template-columns:1fr auto;gap:10px 12px;align-items:end;border:1px solid #242424;border-radius:6px;padding:8px;background:#fff}.patch-imitator-field{display:flex;flex-direction:column;gap:4px;font-size:12px}.patch-imitator-field select{font-size:12px;width:100%}.patch-imitator-add{border:1px solid #242424;background:#242424;color:#fff;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer;height:28px}.patch-imitator-add:disabled{opacity:.6;cursor:not-allowed}.patch-imitator-card{border:1px solid #242424;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px;background:#f9f9f9}.patch-imitator-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.patch-imitator-title{font-size:13px;font-weight:600;color:#111}.patch-imitator-meta{font-size:11px;color:#666;display:flex;gap:8px;align-items:center}.patch-imitator-updated{color:#999}.patch-imitator-remove{border:1px solid #242424;background:#fff;border-radius:999px;padding:4px 8px;font-size:11px;cursor:pointer}.patch-imitator-status{display:flex;gap:8px;align-items:center}.patch-imitator-moves{display:flex;flex-direction:column;gap:6px;font-family:Courier New,Courier,monospace;font-size:12px}.patch-imitator-row{display:grid;grid-template-columns:60px 1fr;gap:8px;align-items:start}.patch-imitator-prob{text-align:right;color:#111}.patch-imitator-move{display:flex;flex-direction:column;gap:2px;color:#333}.patch-imitator-move.is-inaccuracy{color:#ff6a3d}.patch-imitator-tags{color:#777;font-size:11px}.patch-analysis-status{display:flex;gap:8px;align-items:center;font-size:12px;line-height:16px;color:#242424}.patch-analysis-badge{padding:2px 6px;border-radius:999px;font-size:11px;text-transform:uppercase}.patch-analysis-badge.is-running{background:#ffe9a8}.patch-analysis-badge.is-ready{background:#d1f3dd}.patch-analysis-badge.is-error{background:#ffd1d1}.patch-analysis-badge.is-idle{background:#e6e6e6}.patch-analysis-health{color:#555}.patch-analysis-updated{margin-left:auto;color:#666}.patch-analysis-source{color:#666}.patch-analysis-error{color:#b91c1c;font-size:12px;line-height:16px}.patch-analysis-lines{flex:0 0 auto;min-height:0;overflow:visible;font-family:Menlo,monospace;font-size:12px;line-height:16px;display:flex;flex-direction:column;gap:6px}.patch-context-menu{position:fixed;background:#fff;border:1px solid #242424;border-radius:8px;box-shadow:0 12px 24px #00000026;padding:6px;min-width:180px;z-index:2000}.patch-context-item{width:100%;text-align:left;border:none;background:transparent;padding:8px 10px;border-radius:6px;font-size:12px;cursor:pointer}.patch-context-item:hover:not(:disabled){background:#f0f0f0}.patch-context-item:disabled{opacity:.5;cursor:not-allowed}.patch-context-item.is-danger{color:#b91c1c}.patch-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:2100}.patch-confirm-card{background:#fff;border-radius:12px;padding:16px;width:320px;border:1px solid #242424;box-shadow:0 16px 30px #0003}.patch-confirm-title{font-size:14px;font-weight:600;margin-bottom:8px}.patch-confirm-body{font-size:12px;color:#444;margin-bottom:14px}.patch-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.patch-confirm-btn{border:1px solid #242424;background:#fff;border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}.patch-confirm-btn.is-danger{background:#b91c1c;border-color:#b91c1c;color:#fff}.patch-analysis-line{display:grid;grid-template-columns:50px 1fr;gap:8px;align-items:start;line-height:16px}.patch-analysis-score{text-align:right;color:#111}.patch-analysis-pv{color:#333}.patch-analysis-empty{color:#666;font-size:12px}.patch-study-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;overflow:hidden}.patch-study-rightbar{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid #000;padding-left:12px;min-height:0;overflow:hidden}.patch-study-splitter{width:8px;cursor:col-resize;background:linear-gradient(to right,transparent,rgba(0,0,0,.08),transparent);position:relative}.patch-study-splitter:after{content:"";position:absolute;top:0;bottom:0;left:2px;right:2px;background:#00000014;opacity:0;transition:opacity .2s}.patch-study-splitter:hover:after{opacity:1}.patch-right-panel{background:#f5f5f5;border:1px solid #242424;border-radius:6px;display:flex;flex-direction:column;flex:1;min-height:520px;padding:8px;overflow:hidden}.study-board-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:4px}.study-board-nav{display:flex;justify-content:flex-end;width:100%;align-self:stretch}.study-board-nav-group{display:flex;gap:10px}.study-board-nav-button{width:56px;height:32px}.study-board-placeholder{color:#666;font-size:16px}.move-tree-container{width:100%;background:transparent;border-radius:4px;padding:16px;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.move-tree-placeholder{color:#666;font-size:14px}.move-tree-content{flex:1;min-height:0;overflow:auto}.move-tree-title{position:sticky;top:0;z-index:1;background:#f5f5f5;padding-top:8px}.patch-chapter-list{background:#f5f5f5;border:1px solid #242424;border-radius:6px;display:flex;flex-direction:column;flex:1;min-height:520px}.patch-chapter-list__header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px 10px;border-bottom:1px solid #242424}.patch-chapter-list__header h3{margin:0;font-size:14px;color:#000}.patch-chapter-list__header p{margin:2px 0 0;font-size:12px;color:#000}.patch-chapter-list__new{background:#2e6bff;color:#fff;border:none;border-radius:999px;font-size:12px;padding:6px 12px;cursor:pointer}.patch-chapter-list__new:hover{background:#1f5cf0}.patch-chapter-list__scroll{overflow-y:scroll;scrollbar-gutter:stable;max-height:none;flex:1;min-height:0;padding:8px 12px 8px 8px;display:flex;flex-direction:column;gap:8px}.patch-chapter-list__scroll::-webkit-scrollbar{width:8px}.patch-chapter-list__scroll::-webkit-scrollbar-thumb{background:#00000040;border-radius:999px}.patch-chapter-list__scroll::-webkit-scrollbar-track{background:transparent}.patch-chapter-list__item{width:100%;background:#fff;color:#000;border:1px solid #2a2a2a;border-radius:6px;padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left;position:relative}.patch-chapter-list__item:hover{border-color:#3a3a3a;background:#f0f0f0}.patch-chapter-list__item.is-active{border-color:#2e6bff;background:#2e6bff26}.patch-chapter-list__item.is-dragging{opacity:.6}.patch-chapter-list__item.is-drop-before{margin-top:16px}.patch-chapter-list__item.is-drop-before:before{content:"";position:absolute;top:-12px;left:6px;right:6px;border-top:2px solid #2e6bff}.patch-chapter-list__item.is-drop-after{margin-bottom:16px}.patch-chapter-list__item.is-drop-after:after{content:"";position:absolute;bottom:-12px;left:6px;right:6px;border-bottom:2px solid #2e6bff}.patch-chapter-list__drag{width:24px;height:24px;border-radius:6px;border:1px solid #cfcfcf;background:#f7f7f7;color:#666;display:inline-flex;align-items:center;justify-content:center;cursor:grab;flex-shrink:0}.patch-chapter-list__drag:active{cursor:grabbing}.patch-chapter-list__drag svg{width:14px;height:14px;fill:currentColor}.patch-chapter-list__order{width:26px;height:26px;border-radius:6px;border:1px solid #cfcfcf;background:#f7f7f7;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#666;flex-shrink:0;cursor:grab}.patch-chapter-list__order:active{cursor:grabbing}.patch-chapter-list__title{font-size:13px;line-height:1.2}.patch-chapter-list__title-edit{flex:1;display:flex;flex-direction:column}.patch-chapter-list__title-input{flex:1;border:1px solid #2a2a2a;border-radius:4px;padding:6px 8px;font-size:13px;line-height:1.2;background:#fff;color:#000}.patch-chapter-list__error{display:block;margin-top:4px;font-size:12px;color:#d93025}.patch-chapter-list__delete{margin-left:auto;width:26px;height:26px;border-radius:50%;border:1px solid #cfcfcf;background:#f7f7f7;color:#777;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.patch-chapter-list__delete:hover{background:#ffe6ee;border-color:#e6a9bf;color:#d94f84}.patch-chapter-list__delete:disabled{opacity:.6;cursor:not-allowed}.patch-chapter-list__delete svg{width:14px;height:14px;fill:currentColor}.patch-action-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:10000}.patch-action-card{background:#fff;border:1px solid #242424;border-radius:10px;padding:16px 18px;width:320px;box-shadow:0 8px 16px #0003}.patch-action-title{font-size:14px;font-weight:700;margin-bottom:10px}.patch-action-body{font-size:13px;color:#333;margin-bottom:16px}.patch-action-emphasis{margin-top:4px;font-weight:600}.patch-action-buttons{display:flex;justify-content:flex-end;gap:8px}.patch-action-btn{padding:6px 12px;border:1px solid #cfcfcf;background:#fff;border-radius:6px;cursor:pointer;font-size:12px}.patch-action-btn.is-danger{background:#e53935;border-color:#e53935;color:#fff}.patch-chapter-list__empty{padding:16px;text-align:center;font-size:12px;color:#000}
