@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700;900&display=swap";.json-editor{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.toolbar{display:flex;gap:10px;padding:12px 16px;background:var(--toolbar-bg);border-bottom:2px solid var(--border-color);flex-shrink:0;flex-wrap:wrap;align-items:center}.toolbar-primary,.toolbar-secondary{display:flex;gap:10px;flex-wrap:wrap}.toolbar-overflow{display:none;position:relative}.toolbar button{padding:8px 16px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:var(--font-semibold);color:var(--text-primary);transition:all .3s ease}.toolbar button:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.toolbar button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(1)}.toolbar .export-btn{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color);font-weight:var(--font-medium);position:relative;overflow:hidden;transition:all .3s ease}.toolbar .export-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.toolbar .export-btn.export-success{background:var(--success-color);border-color:transparent;animation:successPulse .6s ease-in-out}.toolbar .export-btn.export-success .export-icon{display:inline-block;font-size:18px;font-weight:700;animation:iconBounce .6s cubic-bezier(.68,-.55,.265,1.55)}.toolbar .export-btn.export-error{background:var(--error-color);border-color:transparent;animation:errorShake .5s ease-in-out}.toolbar .export-btn.export-error .export-icon{display:inline-block;font-size:18px;font-weight:700;animation:iconBounce .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes successPulse{0%{transform:scale(1);box-shadow:0 0 #10b981b3}50%{transform:scale(1.1);box-shadow:0 0 0 10px #10b98100}to{transform:scale(1);box-shadow:0 0 #10b98100}}@keyframes errorShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes iconBounce{0%{transform:scale(0) rotate(-180deg);opacity:0}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0);opacity:1}}.toolbar .comment-btn{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}.toolbar .comment-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.overflow-menu-btn{padding:8px 12px!important;font-size:20px!important;font-weight:700;line-height:1;min-width:44px}.overflow-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg, 0 10px 25px rgba(0, 0, 0, .15));min-width:220px;z-index:1000;overflow:hidden}.overflow-menu-dropdown button{display:block;width:100%;text-align:left;padding:12px 16px;border:none;border-bottom:1px solid var(--border-color);background:var(--bg-primary);border-radius:0;font-size:14px;transition:all .2s ease}.overflow-menu-dropdown button:last-child{border-bottom:none}.overflow-menu-dropdown button:hover:not(:disabled){background:var(--hover-bg);transform:none;box-shadow:none}.overflow-menu-dropdown button:disabled{opacity:.5}.mobile-actions-fab{display:none;position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--gradient-1);color:#fff;border:none;font-size:24px;box-shadow:var(--shadow-lg, 0 8px 16px rgba(0, 0, 0, .2));cursor:pointer;z-index:999;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.mobile-actions-fab:hover{transform:scale(1.1);box-shadow:0 12px 24px #667eea66}.mobile-actions-fab:active{transform:scale(.95)}.mobile-actions-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .3s ease}.mobile-actions-sheet{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -4px 20px #0003;z-index:1001;max-height:80vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.68,-.55,.265,1.55)}.mobile-actions-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid var(--border-color)}.mobile-actions-header h3{margin:0;font-size:18px;font-weight:var(--font-semibold);color:var(--text-primary)}.mobile-actions-header .close-btn{background:none;border:none;font-size:32px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.mobile-actions-header .close-btn:hover{color:var(--text-primary)}.mobile-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:20px}.mobile-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;min-height:88px}.mobile-action-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.mobile-action-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(1)}.mobile-action-btn .action-label{font-size:12px;font-weight:var(--font-semibold);color:var(--text-primary);text-align:center}.mobile-action-btn.export{background:var(--gradient-1);color:#fff;border-color:transparent}.mobile-action-btn.export .action-label{color:#fff}.mobile-action-btn.export:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.comment-section{padding:12px;background:var(--bg-secondary, #f9f9f9);border-top:2px solid var(--border-color, #e5e5e5);border-left:3px solid #764ba2}.error-banner{background:linear-gradient(to right,#6366f108,#8b5cf608);border-bottom:1px solid rgba(99,102,241,.15);border-top:1px solid rgba(99,102,241,.15);display:flex;flex-direction:column;gap:0;z-index:10;position:relative;box-shadow:0 2px 8px #6366f114}.error-message{padding:16px 20px;color:var(--text-primary);font-size:14px;font-family:var(--font-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);font-weight:var(--font-medium);display:flex;align-items:flex-start;gap:12px;line-height:1.6}.error-message.clickable{cursor:pointer;transition:all .2s ease}.error-message.clickable:hover{background:#6366f10d}.error-icon{font-size:20px;flex-shrink:0;color:#6366f1cc;margin-top:2px}.error-text{flex:1;color:var(--text-primary)}.auto-fix-section{padding:8px 16px 12px;display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;background:#667eea0d;border-top:1px solid rgba(102,126,234,.2);position:relative;z-index:15;pointer-events:auto}.auto-fix-label{font-size:13px;font-weight:var(--font-bold);color:var(--primary-color);text-transform:uppercase;letter-spacing:.5px;padding-top:4px}.fix-count{font-size:11px;font-weight:var(--font-medium);color:var(--text-secondary);text-transform:none;letter-spacing:normal}.auto-fix-buttons{display:flex;gap:8px;flex-wrap:wrap;flex:1}.auto-fix-btn{padding:8px 14px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 6px #667eea4d;white-space:nowrap;pointer-events:auto;position:relative;z-index:5}.auto-fix-btn:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 10px #667eea66}.auto-fix-btn:active{transform:translateY(0);box-shadow:0 2px 4px #667eea4d}.fix-number{font-weight:var(--font-bold);margin-right:4px;opacity:.9}.json-textarea-wrapper{flex:1;overflow:hidden;background:var(--json-bg);position:relative}.editor-with-line-numbers{display:flex;height:100%;overflow:auto}.line-numbers{flex-shrink:0;padding:20px 0;background:var(--bg-secondary);border-right:2px solid var(--border-color);-webkit-user-select:none;user-select:none;min-width:50px;text-align:right;overflow-y:scroll;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.line-numbers::-webkit-scrollbar{display:none}.line-number{font-family:var(--font-mono);font-size:14px;line-height:1.6;color:var(--text-muted);padding:0 12px;height:22.4px}.editor-content{flex:1;overflow:auto;min-width:0}.json-textarea{flex:1;min-height:100%;overflow:auto!important}.json-textarea textarea,.json-textarea-input{outline:none!important;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important}.json-textarea .token{user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;pointer-events:auto}.json-textarea .token,.json-textarea pre,.json-textarea code,.json-textarea span{transition:none!important}.json-textarea ::selection,.json-textarea-input ::selection{background-color:#6366f14d;color:inherit}.json-editor-pre,.json-textarea pre,.json-textarea code{user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;white-space:pre;word-wrap:normal;overflow-wrap:normal}.json-textarea-wrapper>*{pointer-events:auto}.json-textarea-wrapper .empty-state-overlay{pointer-events:none}.json-textarea-wrapper .empty-state-overlay *{pointer-events:auto}.empty-state-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--json-bg);z-index:10;pointer-events:none;animation:fadeIn .3s ease}.empty-state-content{text-align:center;max-width:500px;padding:40px 20px;pointer-events:auto}.empty-state-icon{font-size:72px;font-weight:var(--font-bold);background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px;font-family:var(--font-mono);animation:scaleIn .5s cubic-bezier(.68,-.55,.265,1.55)}.drop-target-icon{background:none!important;-webkit-text-fill-color:initial!important;display:flex;justify-content:center;align-items:center}.drop-icon-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px}.drop-arrow{font-size:48px;color:var(--primary-color);animation:bounceDown 1.5s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(102,126,234,.3))}.drop-box{font-size:56px;animation:pulse 2s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}@keyframes bounceDown{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(12px);opacity:.7}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.empty-state-title{font-size:28px;font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 12px;animation:slideUp .4s ease}.empty-state-description{font-size:16px;color:var(--text-muted);margin:0 0 32px;line-height:1.6;animation:slideUp .5s ease}.empty-state-description strong{color:var(--text-primary);font-weight:var(--font-semibold)}.description-hint{font-size:14px;color:var(--text-secondary);opacity:.8;font-style:italic}.empty-state-actions{display:flex;flex-direction:column;gap:12px;justify-content:center;margin-bottom:24px;width:100%;max-width:320px;margin-left:auto;margin-right:auto;animation:slideUp .6s ease}.load-sample-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:15px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);min-height:52px;width:100%}.load-sample-btn.primary{background:var(--gradient-1);border-color:transparent;color:#fff;box-shadow:var(--shadow-md)}.load-sample-btn.primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.load-sample-btn.primary:active{transform:translateY(-1px)}.load-sample-btn.secondary{background:var(--bg-secondary);color:var(--text-primary)}.load-sample-btn.secondary:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.load-sample-btn.secondary:active{transform:translateY(0)}.load-sample-btn .btn-icon{font-size:20px;line-height:1}.load-sample-btn .btn-text{line-height:1}.empty-state-hint{font-size:14px;color:var(--text-muted);font-style:italic;animation:fadeIn .8s ease}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.json-textarea::placeholder{color:var(--text-muted)!important;opacity:.6}.json-textarea .token.property{color:var(--json-key)}.json-textarea .token.string{color:var(--json-string)}.json-textarea .token.number{color:var(--json-number)}.json-textarea .token.boolean{color:var(--json-boolean);font-weight:var(--font-semibold)}.json-textarea .token.null{color:var(--json-null);font-style:italic;font-weight:var(--font-semibold)}.json-textarea .token.punctuation,.json-textarea .token.operator{color:var(--text-secondary)}.text-search-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-secondary);border-bottom:2px solid var(--border-color);flex-wrap:wrap}.search-input-wrapper{position:relative;flex:1 1 200px;min-width:200px;max-width:400px}.text-search-bar .search-input{width:100%;padding:8px 32px 8px 12px;font-size:13px;border:2px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);outline:none;transition:all .3s ease;font-family:var(--font-mono)}.text-search-bar .search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:20px;padding:4px 6px;line-height:1;transition:all .3s ease}.clear-search:hover{color:var(--text-primary)}.search-controls{display:flex;align-items:center;gap:8px;padding-left:12px;border-left:2px solid var(--border-color)}.match-count{font-size:12px;color:var(--text-secondary);font-weight:var(--font-medium);white-space:nowrap}.nav-button{padding:4px 10px;font-size:14px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s ease;line-height:1;font-weight:var(--font-semibold)}.nav-button:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color)}.nav-button:disabled{opacity:.4;cursor:not-allowed}.no-matches{font-size:12px;color:var(--error-color);font-weight:var(--font-medium);white-space:nowrap}@media(max-width:1024px){.toolbar-secondary{display:none}.toolbar-overflow{display:block}}@media(max-width:768px){.toolbar{display:none}.mobile-actions-fab{display:flex;align-items:center;justify-content:center}.mobile-actions-overlay,.mobile-actions-sheet{display:block}.text-search-bar{flex-direction:column;gap:8px;padding:8px 12px}.search-input-wrapper{width:100%;max-width:100%}.search-controls{border-left:none;border-top:1px solid var(--border-color);padding-left:0;padding-top:8px;width:100%;justify-content:space-between}.empty-state-content{padding:30px 20px}.empty-state-icon{font-size:56px;margin-bottom:20px}.empty-state-title{font-size:24px}.empty-state-description{font-size:15px;margin-bottom:28px}.empty-state-actions{flex-direction:column;gap:12px;width:100%}.load-sample-btn{width:100%;justify-content:center;padding:16px 24px;min-height:56px}.load-sample-btn .btn-icon{font-size:22px}.load-sample-btn .btn-text{font-size:16px}}@media(max-width:480px){.mobile-actions-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:16px}.mobile-action-btn{min-height:80px;padding:12px 8px}.mobile-action-btn .action-icon{font-size:24px}.mobile-action-btn .action-label{font-size:11px}.mobile-actions-fab{bottom:20px;right:20px;width:52px;height:52px;font-size:22px}.empty-state-content{padding:24px 16px}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-title{font-size:20px}.empty-state-description{font-size:14px;margin-bottom:24px}.empty-state-hint{font-size:13px}.error-message{padding:14px 16px;font-size:13px}.error-icon{font-size:18px}.auto-fix-section{flex-direction:column;align-items:flex-start;padding:0 12px 10px}.auto-fix-buttons{width:100%}.auto-fix-btn{flex:1;justify-content:center;min-width:100%}.line-numbers{min-width:40px}.line-number{padding:0 8px}.text-search-bar{padding:8px}.text-search-bar .search-input{font-size:14px;padding:10px 32px 10px 10px}.nav-button{min-width:44px;min-height:44px;padding:8px 12px}}.empty-state-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;text-align:center;padding:2rem;pointer-events:none}.empty-state-overlay *{pointer-events:auto}.empty-state-content{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:3rem 2rem;max-width:500px;animation:fadeInScale .4s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-state-title{font-size:1.5rem;font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 .75rem}.empty-state-description{font-size:1rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.empty-state-btn{padding:1rem 2rem;background:var(--gradient-1);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:var(--shadow-md)}.empty-state-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.empty-state-divider{margin:1.5rem 0;position:relative;display:flex;align-items:center;justify-content:center}.empty-state-divider:before,.empty-state-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.empty-state-divider span{padding:0 1rem;color:var(--text-secondary);font-size:.875rem;font-weight:var(--font-medium)}.empty-state-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.empty-state-secondary-btn{padding:.75rem 1.5rem;background:transparent;color:var(--text-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:.95rem;font-weight:var(--font-medium);cursor:pointer;transition:all .3s ease}.empty-state-secondary-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.templates-btn{background:var(--bg-primary)!important;border-color:var(--border-color)!important;color:var(--text-primary)!important}.templates-btn:hover:not(:disabled){background:var(--hover-bg)!important;border-color:var(--primary-color)!important;color:var(--primary-color)!important}@media(max-width:768px){.empty-state-overlay{width:calc(100% - 2rem);padding:1rem}.empty-state-content{padding:2rem 1.5rem}.empty-state-icon{font-size:3rem}.empty-state-title{font-size:1.25rem}.empty-state-description{font-size:.95rem}.empty-state-btn{width:100%;padding:.875rem 1.5rem}.empty-state-actions{flex-direction:column;width:100%}.empty-state-secondary-btn{width:100%}}@media(max-width:480px){.empty-state-content{padding:1.5rem 1rem}.empty-state-icon{font-size:2.5rem}.empty-state-title{font-size:1.1rem}.empty-state-description{font-size:.9rem}}.inline-editor-wrapper{display:inline-flex;flex-direction:column;gap:4px;position:relative}.inline-editor{font-family:Courier New,monospace;font-size:14px;padding:2px 6px;border:2px solid #4a90e2;border-radius:3px;background:#fff;outline:none;min-width:80px;box-shadow:0 0 0 2px #4a90e233}.inline-editor:focus{border-color:#357abd;box-shadow:0 0 0 3px #4a90e24d}.inline-editor-error{border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c33}.inline-editor-error:focus{border-color:#c0392b;box-shadow:0 0 0 3px #e74c3c4d}.inline-editor-error-message{position:absolute;top:100%;left:0;margin-top:2px;font-size:12px;color:#e74c3c;background:#fff;padding:2px 6px;border-radius:3px;border:1px solid #e74c3c;white-space:nowrap;z-index:10}.inline-editor-select{font-family:Courier New,monospace;font-size:14px;padding:2px 6px;border:2px solid #4a90e2;border-radius:3px;background:#fff;outline:none;cursor:pointer;box-shadow:0 0 0 2px #4a90e233}.inline-editor-select:focus{border-color:#357abd;box-shadow:0 0 0 3px #4a90e24d}.inline-editor-null{color:#95a5a6;cursor:not-allowed;background:#ecf0f1}.edit-modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}.edit-modal{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-xl);width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.edit-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);border-radius:8px 8px 0 0}.header-left{display:flex;flex-direction:column;gap:4px}.edit-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.modal-path{font-size:12px;color:var(--text-secondary);font-family:monospace}.close-button{width:32px;height:32px;border:none;background:transparent;font-size:20px;color:var(--text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.edit-modal-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.view-toggle{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:4px;padding:2px}.toggle-btn{padding:6px 16px;font-size:13px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:3px;transition:all .2s;font-weight:500}.toggle-btn.active{background:var(--bg-primary);color:var(--primary-color);box-shadow:var(--shadow-sm)}.editor-actions{display:flex;gap:8px}.action-btn{padding:6px 12px;font-size:12px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.action-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color)}.action-btn:active{background:var(--bg-tertiary);transform:translateY(1px)}.edit-modal-error{padding:12px 20px;background:var(--bg-tertiary);border-bottom:1px solid var(--error-color);border-left:4px solid var(--error-color);color:var(--error-color);font-size:13px}.edit-modal-error strong{font-weight:600}.edit-modal-content{flex:1;overflow:auto;padding:20px;background:var(--bg-secondary)}.json-textarea{width:100%;height:400px;font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;line-height:1.5;padding:12px;border:1px solid var(--border-color);border-radius:4px;resize:vertical;background:var(--json-bg);color:var(--json-text);outline:none}.json-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 .2rem #6366f140}.json-formatted{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;line-height:1.5;padding:12px;background:var(--json-bg);color:var(--json-text);border:1px solid var(--border-color);border-radius:4px;overflow:auto;max-height:400px;margin:0}.edit-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-secondary);border-radius:0 0 8px 8px}.cancel-btn,.save-btn{padding:8px 20px;font-size:14px;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.cancel-btn{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color)}.cancel-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.save-btn{background:var(--primary-color);color:#fff}.save-btn:hover{background:var(--primary-dark)}.save-btn:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.6}.save-btn:active{background:var(--primary-dark);transform:translateY(1px)}.tree-node{font-family:var(--font-mono);font-size:13px;line-height:1.6}.node-line{display:flex;align-items:center;padding:4px 6px;-webkit-user-select:text;user-select:text;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}.node-line:hover{background:var(--hover-bg)}.node-line.selected{background:linear-gradient(135deg,#667eea26,#764ba226);border:2px solid var(--primary-color);margin:-2px;box-shadow:0 0 8px #6366f133}.node-line.search-match{background:#f59e0b26;border:2px solid var(--warning-color);margin:-2px}.search-highlight{background-color:#f59e0b80;font-weight:600;border-radius:2px;padding:1px 2px}.node-line.selected.search-match{background:#667eea40;border:2px solid var(--primary-color)}.expand-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);font-size:11px;margin-right:6px;flex-shrink:0;border-radius:var(--radius-sm);transition:all .2s ease}.expand-icon:hover{background:var(--primary-light);color:#fff}.expand-placeholder{width:18px;display:inline-block;margin-right:6px;flex-shrink:0}.node-key{color:var(--json-key);font-weight:var(--font-semibold)}.colon{color:var(--text-muted);margin:0 6px}.bracket{color:var(--text-secondary);font-weight:var(--font-semibold)}.ellipsis{color:var(--text-muted);margin:0 6px}.collection-size{color:var(--text-muted);font-size:11px;margin-left:8px;font-style:italic}.value-string{color:var(--json-string);font-weight:var(--font-regular)}.value-number{color:var(--json-number);font-weight:var(--font-semibold)}.value-boolean{color:var(--json-boolean);font-weight:var(--font-bold)}.value-null{color:var(--json-null);font-style:italic;font-weight:var(--font-semibold)}.node-children{margin-left:24px;border-left:2px solid var(--border-color);padding-left:10px}.closing-bracket{padding:2px 0}.context-menu-overlay{position:fixed;inset:0;z-index:999;background:transparent}.context-menu{position:fixed;z-index:1000;background:var(--modal-bg);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);min-width:220px;padding:6px 0}.context-menu-item{display:block;width:100%;padding:10px 18px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;font-weight:var(--font-medium);color:var(--text-primary);transition:all .2s ease}.context-menu-item:hover{background:var(--primary-light);color:#fff}.context-menu-item:active{background:var(--primary-dark)}.context-menu-item .menu-icon{display:inline-block;margin-right:8px;font-size:16px}.context-menu-divider{height:1px;background:var(--border-color);margin:6px 0}.edit-icon{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;width:24px;height:24px;font-size:16px;opacity:.8;cursor:pointer;color:var(--primary-color);background:#667eea1a;border-radius:4px;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.edit-icon:hover{opacity:1;transform:scale(1.3);background:#667eea33;box-shadow:0 2px 8px #667eea4d}.comment-icon{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;width:24px;height:24px;font-size:16px;opacity:.8;cursor:pointer;color:#764ba2;background:#764ba21a;border-radius:4px;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.comment-icon:hover{opacity:1;transform:scale(1.3);background:#764ba233;box-shadow:0 2px 8px #764ba24d}.comment-input-container{margin-top:8px;margin-left:20px;padding:8px;background:var(--bg-secondary, #f9f9f9);border-left:3px solid var(--accent-color, #764ba2);border-radius:4px}.node-line.diff-missing-in-target{background:#dc35451a;border-left:4px solid #dc3545;padding-left:8px}.node-line.diff-missing-in-source{background:#1565c01a;border-left:4px solid #1565c0;padding-left:8px}.node-line.diff-type-mismatch{background:#ffc1071a;border-left:4px solid #ffc107;padding-left:8px}.node-line.diff-value-different{background:#ff98001a;border-left:4px solid #ff9800;padding-left:8px}.node-line.diff-array-length{background:#9c27b01a;border-left:4px solid #9c27b0;padding-left:8px}.node-line.selected.diff-missing-in-target,.node-line.selected.diff-missing-in-source,.node-line.selected.diff-type-mismatch,.node-line.selected.diff-value-different,.node-line.selected.diff-array-length{background:linear-gradient(135deg,#667eea40,#764ba240)}@media(max-width:768px){.tree-node{font-size:14px}.node-line{padding:8px;min-height:44px}.expand-icon{width:32px;height:32px;font-size:16px;margin-right:8px}.expand-placeholder{width:32px;margin-right:8px}.inline-actions{gap:6px}.inline-action-btn{width:36px;height:36px;font-size:16px}.comment-indicator{width:24px;height:24px;font-size:14px}.comment-input-container{margin-left:12px;padding:10px}.collection-size{font-size:12px}.edit-input{padding:10px;font-size:14px;min-height:44px}.context-menu{min-width:240px;border-radius:16px;padding:12px 0}.context-menu-item{padding:14px 20px;font-size:16px;min-height:48px;display:flex;align-items:center}.context-menu-item .menu-icon{font-size:20px;margin-right:12px}.context-menu-divider{margin:8px 0}.edit-icon,.comment-icon{opacity:.9;font-size:18px;width:32px;height:32px}}@media(max-width:480px){.tree-node{font-size:13px}.node-line{padding:10px;min-height:48px}.expand-icon{width:36px;height:36px;font-size:18px;margin-right:10px}.expand-placeholder{width:36px;margin-right:10px}.inline-action-btn{width:40px;height:40px;font-size:18px}.comment-indicator{width:28px;height:28px;font-size:16px}.children{padding-left:24px}}.tree-column-selector{background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 4px 16px #00000026;margin:0 16px 12px;max-height:500px;display:flex;flex-direction:column;font-family:inherit}.tree-selector-header{padding:14px 18px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea14,#764ba214);display:flex;justify-content:space-between;align-items:center;border-radius:6px 6px 0 0}.tree-selector-header h4{margin:0;font-size:15px;font-weight:600;color:#333}.tree-selector-actions{display:flex;gap:8px}.select-all-btn,.deselect-all-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid #ccc;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.select-all-btn:hover{background:#28a745;color:#fff;border-color:#28a745}.deselect-all-btn:hover{background:#dc3545;color:#fff;border-color:#dc3545}.tree-selector-stats{padding:10px 18px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#666}.expand-all-btn{padding:4px 10px;font-size:11px;font-weight:600;border:1px solid #ccc;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s;color:#007bff}.expand-all-btn:hover{background:#007bff;color:#fff;border-color:#007bff}.tree-selector-content{flex:1;overflow-y:auto;padding:12px 0;max-height:350px}.tree-node{width:100%}.tree-node-row{display:flex;align-items:center;padding:6px 18px;gap:6px;transition:background .15s;cursor:pointer}.tree-node-row:hover{background:#f5f5f5}.tree-node-row.level-1{padding-left:18px}.tree-node-row.level-2{padding-left:42px}.tree-node-row.level-3{padding-left:66px}.expand-btn{width:18px;height:18px;padding:0;border:none;background:transparent;cursor:pointer;font-size:10px;color:#666;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s,color .2s}.expand-btn:hover{color:#007bff;transform:scale(1.2)}.expand-placeholder{width:18px;height:18px;flex-shrink:0}.tree-node-label{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer;-webkit-user-select:none;user-select:none}.tree-node-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;flex-shrink:0}.node-icon{font-size:16px;flex-shrink:0;line-height:1}.node-name{font-size:13px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;color:#333;font-weight:500;flex:1}.node-type{font-size:11px;color:#999;font-weight:400;text-transform:lowercase;flex-shrink:0}.cardinality-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:#007bff;color:#fff;border-radius:10px;font-size:10px;font-weight:600;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;flex-shrink:0}.tree-node-children{width:100%}.tree-selector-footer{padding:12px 18px;border-top:1px solid #e0e0e0;background:#f8f9fa;display:flex;justify-content:flex-end;border-radius:0 0 6px 6px}.done-btn{padding:8px 20px;font-size:14px;font-weight:600;border:1px solid #007bff;background:#007bff;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s}.done-btn:hover{background:#0056b3;border-color:#0056b3;transform:translateY(-1px);box-shadow:0 2px 8px #007bff4d}.array-table-view{height:100%;display:flex;flex-direction:column;background:var(--bg-primary)}.array-table-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:2px solid var(--border-color);background:var(--bg-secondary);gap:12px}.array-table-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap}.header-controls{display:flex;align-items:center;gap:12px;flex:1;justify-content:flex-end}.column-selector-btn{padding:6px 12px;font-size:13px;font-weight:600;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap;color:var(--text-primary)}.column-selector-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover)}.array-filter-input{flex:1;max-width:300px;padding:6px 12px;font-size:13px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:4px;outline:none}.array-filter-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f11a}.column-selector-popup{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:var(--shadow-lg);margin:0 16px 12px;max-height:400px;display:flex;flex-direction:column}.column-selector-header{padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.column-selector-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.column-selector-actions{display:flex;gap:8px}.select-all-btn,.deselect-all-btn{padding:4px 10px;font-size:12px;font-weight:600;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:4px;cursor:pointer;transition:all .2s}.select-all-btn:hover{background:var(--success-color);color:#fff;border-color:var(--success-color)}.deselect-all-btn:hover{background:var(--error-color);color:#fff;border-color:var(--error-color)}.column-selector-list{padding:12px 16px;overflow-y:auto;max-height:300px}.column-checkbox-item{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.column-checkbox-item:hover{background:var(--hover-bg)}.column-checkbox-item.selected{background:var(--bg-tertiary)}.column-checkbox-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;flex-shrink:0}.column-order-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--primary-color);color:#fff;border-radius:10px;font-size:11px;font-weight:600;flex-shrink:0}.column-name{font-size:13px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;color:var(--text-primary);flex:1}.column-selector-footer{padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);display:flex;justify-content:flex-end}.close-selector-btn{padding:6px 16px;font-size:13px;font-weight:600;border:1px solid var(--primary-color);background:var(--primary-color);color:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.close-selector-btn:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.array-table-container{flex:1;overflow:auto}.array-table{border-collapse:collapse;font-size:13px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;table-layout:fixed}.array-table thead{position:sticky;top:0;background:var(--bg-primary);z-index:10;box-shadow:var(--shadow-sm)}.array-table th{padding:10px 12px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap;background:var(--bg-secondary)}.array-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.array-table th.sortable:hover{background:var(--hover-bg)}.array-table th.index-header{width:60px;background:var(--bg-tertiary)}.array-table th.resizable-header{position:relative;padding-right:4px}.column-header-content{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:12px;pointer-events:none}.resize-handle{position:absolute;top:0;right:-4px;width:8px;height:100%;cursor:col-resize;-webkit-user-select:none;user-select:none;background:transparent;z-index:10;border-right:2px solid transparent;transition:border-color .2s}.resize-handle:hover{border-right-color:var(--primary-color)}.resizing-column .resize-handle,body.resizing-column{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}.array-table .sort-icon{font-size:10px;color:var(--text-secondary);margin-left:4px}.array-table tbody tr{cursor:pointer;transition:background .15s}.array-table tbody tr:hover{background:var(--hover-bg)}.array-table tbody tr.selected-row{background:var(--bg-tertiary);border:1px solid var(--primary-color)}.array-table td{padding:8px 12px;border-bottom:1px solid var(--border-color-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.array-table .index-cell{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);text-align:center}.array-table .data-cell{color:var(--text-primary)}.array-table-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px}.no-results{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.data-cell.editable-cell{cursor:pointer;transition:background .15s}.data-cell.editable-cell:hover{background:var(--bg-tertiary)}.cell-content{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:20px}.cell-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-edit-btn{flex-shrink:0;padding:2px 6px;border:none;background:transparent;cursor:pointer;font-size:12px;opacity:.6;transition:opacity .15s,background .15s;border-radius:3px}.cell-edit-btn:hover{opacity:1;background:#6366f11a}.cell-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.cell-comment-btn{flex-shrink:0;padding:2px 6px;border:none;background:transparent;cursor:pointer;font-size:12px;opacity:.3;transition:opacity .15s,background .15s,transform .15s;border-radius:3px}.cell-comment-btn.visible{opacity:.6}.cell-comment-btn:hover{opacity:1;background:#764ba21a;transform:scale(1.1)}.cell-comment-btn.has-comment{opacity:.8;background:#764ba226}.cell-comment-btn.has-comment:hover{opacity:1;background:#764ba240}.data-cell.cell-with-comment{border-left:3px solid #764ba2;background:#764ba208}.index-cell-content{display:flex;align-items:center;justify-content:center;gap:6px}.index-number{font-weight:600;color:var(--text-secondary)}.row-comment-btn{flex-shrink:0;padding:2px 4px;border:none;background:transparent;cursor:pointer;font-size:11px;opacity:.4;transition:opacity .15s,background .15s,transform .15s;border-radius:3px}.row-comment-btn:hover{opacity:1;background:#764ba226;transform:scale(1.15)}.row-comment-btn.has-comment{opacity:.9;background:#764ba233}.row-comment-btn.has-comment:hover{opacity:1;background:#764ba24d}.array-table tbody tr.row-with-comment{border-left:4px solid #764ba2}.array-table tbody tr.row-with-comment .index-cell{background:#764ba214}.statistics-view{height:100%;display:flex;flex-direction:column;background:#fff;overflow-y:auto}.statistics-header{padding:15px 20px;border-bottom:1px solid #dee2e6;background:#f8f9fa}.statistics-header h3{margin:0 0 5px;font-size:14px;font-weight:600;color:#333}.statistics-name{font-size:12px;color:#666;font-family:monospace}.statistics-type{padding:15px 20px;background:#fff;border-bottom:1px solid #dee2e6}.type-badge{display:inline-block;padding:6px 12px;background:#007bff;color:#fff;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.statistics-list{padding:15px 20px;display:flex;flex-direction:column;gap:16px}.stat-item{display:flex;flex-direction:column;gap:6px}.stat-header{display:flex;justify-content:space-between;align-items:baseline}.stat-label{font-size:13px;font-weight:600;color:#495057}.stat-value{font-size:14px;font-weight:600;color:#007bff;font-family:Monaco,Menlo,monospace}.stat-bar-container{width:100%;height:24px;background:#e9ecef;border-radius:4px;overflow:hidden;position:relative}.stat-bar{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);display:flex;align-items:center;padding:0 8px;transition:width .3s ease;min-width:40px}.stat-bar-label{font-size:11px;font-weight:600;color:#fff;white-space:nowrap}.properties-panel{height:100%;background:var(--bg-primary);border-left:2px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.properties-header{padding:18px 24px;border-bottom:2px solid var(--border-color);background:linear-gradient(135deg,#667eea14,#764ba214);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px}.header-title{flex:1}.properties-header h3{margin:0 0 6px;font-size:16px;font-weight:var(--font-bold);color:var(--text-primary)}.selected-node-name{font-size:12px;color:var(--text-secondary);font-family:var(--font-mono)}.view-toggle{display:flex;gap:4px;background:var(--bg-secondary);border-radius:var(--radius-md);padding:3px;border:2px solid var(--border-color)}.toggle-btn{padding:8px 14px;font-size:13px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all .3s ease;font-weight:var(--font-semibold)}.toggle-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.toggle-btn.active{background:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.path-display{padding:14px 24px;background:var(--bg-secondary);border-bottom:2px solid var(--border-color);display:flex;flex-direction:column;gap:10px}.view-toggle-compact{display:flex;gap:6px;padding:10px 16px;background:var(--bg-secondary);border-bottom:2px solid var(--border-color);justify-content:center}.toggle-btn-compact{padding:8px 16px;font-size:13px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all .3s ease;font-weight:var(--font-semibold);min-width:100px}.toggle-btn-compact:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--text-primary)}.toggle-btn-compact.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.path-section{display:flex;align-items:center;gap:10px}.path-label{font-size:11px;font-weight:var(--font-bold);color:var(--text-secondary);min-width:70px;text-transform:uppercase;letter-spacing:.5px}.path-value{font-family:var(--font-mono);font-size:12px;color:var(--text-primary);background:var(--bg-primary);padding:6px 10px;border-radius:var(--radius-sm);border:2px solid var(--border-color);flex:1;overflow-x:auto;white-space:nowrap}.path-copy-btn{padding:6px 10px;font-size:14px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;color:var(--text-primary);display:inline-flex;align-items:center;flex-shrink:0}.path-copy-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.path-copy-btn:active{transform:translateY(0)}.path-copy-btn.value{border-color:var(--success-color);color:var(--success-color)}.path-copy-btn.value:hover{background:#4caf501a;border-color:var(--success-color)}.copy-feedback-inline{font-size:12px;color:var(--success-color);font-weight:var(--font-semibold);animation:fadeIn .3s ease-in;padding-left:80px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.properties-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:30px;text-align:center}.properties-empty p{color:var(--text-muted);font-size:15px}.properties-table{width:100%;border-collapse:collapse;font-size:13px;overflow:auto}.properties-table thead{position:sticky;top:0;background:var(--bg-secondary);z-index:1}.properties-table th{text-align:left;padding:12px 18px;font-weight:var(--font-bold);color:var(--text-primary);border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.properties-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.properties-table th.sortable:hover{background:var(--hover-bg);color:var(--primary-color)}.sort-icon{font-size:11px;margin-left:6px;color:var(--primary-color)}.properties-table tbody{display:block;overflow-y:auto;height:calc(100vh - 200px)}.properties-table thead,.properties-table tbody tr{display:table;width:100%;table-layout:fixed}.properties-table td{padding:10px 18px;border-bottom:1px solid var(--border-color-light)}.properties-table tbody tr:hover{background:var(--hover-bg)}.prop-name{font-weight:var(--font-semibold);color:var(--json-key);font-family:var(--font-mono);width:40%;word-break:break-word}.prop-value{color:var(--text-primary);font-family:var(--font-mono);font-size:12px;width:60%;word-break:break-word;white-space:pre-wrap}.prop-value-content{display:flex;align-items:center;gap:6px;width:100%}.prop-value-text{flex:1;min-width:0}.prop-value-actions{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;margin-left:8px}.prop-value.editable{cursor:pointer;transition:all .2s ease;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none}.prop-value.editable:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:var(--primary-color)}.edit-icon{cursor:pointer;opacity:.6;transition:all .2s ease;font-size:14px;display:inline-flex;align-items:center;padding:3px 5px;border-radius:var(--radius-sm);background:#667eea1a}.edit-icon:hover{opacity:1;background:#667eea40;transform:scale(1.15)}.drill-down-icon{cursor:pointer;opacity:.7;transition:all .2s ease;font-size:14px;display:inline-flex;align-items:center;padding:3px 5px;border-radius:var(--radius-sm);background:#34a8531a}.drill-down-icon:hover{opacity:1;background:#34a85340;transform:scale(1.15)}.comment-icon-action{cursor:pointer;opacity:.6;transition:all .2s ease;font-size:14px;display:inline-flex;align-items:center;padding:3px 5px;border-radius:var(--radius-sm);background:#764ba21a}.comment-icon-action:hover{opacity:1;background:#764ba240;transform:scale(1.15)}@media(max-width:768px){.properties-panel{border-left:none;border-top:2px solid var(--border-color)}.properties-header,.path-display{display:none}.view-toggle-compact{padding:8px 12px}.toggle-btn-compact{padding:10px 14px;font-size:14px;min-height:44px}.view-toggle .toggle-btn:last-child{display:none}.view-toggle{flex-shrink:0}.toggle-btn{padding:10px 16px;font-size:14px;min-height:40px}.properties-table{font-size:13px;margin:0}.properties-table thead{position:sticky;top:0;z-index:2}.properties-table th{padding:12px 16px;font-size:13px;background:var(--bg-secondary)}.properties-table td{padding:12px 16px}.properties-table tbody{height:calc(100vh - 120px)}.prop-name{width:35%;font-size:12px}.prop-value{width:65%;font-size:11px}.properties-empty{padding:24px 16px}.properties-empty p{font-size:14px}.edit-icon,.comment-icon-action{font-size:16px;padding:6px 8px;min-width:36px;min-height:36px}}@media(max-width:480px){.properties-header{padding:12px}.properties-header h3{font-size:14px}.selected-node-name{font-size:10px}.toggle-btn{padding:8px 12px;font-size:13px}.properties-table{font-size:12px}.properties-table th,.properties-table td{padding:10px 14px}.properties-table tbody{height:calc(100vh - 100px)}.prop-name,.prop-value{font-size:11px}.properties-empty{padding:20px 12px}.properties-empty p{font-size:13px}.edit-icon,.comment-icon-action{font-size:18px;padding:8px 10px;min-width:40px;min-height:40px}}.search-bar{display:flex;align-items:center;gap:8px;flex:1 1 auto;min-width:150px;max-width:100%;flex-wrap:wrap}.search-input-container{position:relative;flex:1 1 auto;min-width:120px;max-width:300px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;opacity:.5}.search-input{width:100%;padding:8px 32px;font-size:13px;border:2px solid var(--border-color);border-radius:var(--radius-md);outline:none;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease;height:36px}.search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.clear-search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:4px;line-height:1;transition:all .3s ease}.clear-search-btn:hover{color:var(--text-primary)}.mode-select{padding:8px 12px;font-size:13px;font-weight:var(--font-medium);border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;outline:none;transition:all .3s ease;height:36px;flex-shrink:0;min-width:90px}.mode-select:hover{border-color:var(--primary-color)}.mode-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.search-results{display:flex;align-items:center;gap:6px;padding-left:8px;border-left:2px solid var(--border-color);flex-shrink:0}.match-count{font-size:12px;color:var(--text-secondary);font-weight:var(--font-semibold);white-space:nowrap;min-width:40px}.nav-btn{padding:6px 10px;font-size:13px;font-weight:var(--font-bold);border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s ease;line-height:1;min-width:32px;height:32px}.nav-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.no-matches{font-size:12px;color:var(--error-color);font-weight:var(--font-semibold);padding-left:8px;border-left:2px solid var(--border-color);flex-shrink:0;white-space:nowrap}@media(max-width:768px){.search-bar{flex-wrap:wrap;gap:8px}.search-input-container{flex:1 1 100%;max-width:100%}.mode-select{flex:1;min-width:100px}.search-results{flex:1;justify-content:flex-end;padding-left:8px}}@media(max-width:480px){.search-input{font-size:14px;padding:10px 32px;height:40px}.mode-select{font-size:14px;height:40px}.nav-btn{padding:8px 10px;height:36px;font-size:14px}}.floating-action-palette{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:16px}.fab-backdrop{position:fixed;inset:0;background:#0003;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:-1;animation:fadeIn .3s ease}.fab-main{width:64px;height:64px;border-radius:50%;background:var(--gradient-1);color:#fff;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;box-shadow:var(--shadow-primary);transition:all .4s cubic-bezier(.68,-.55,.265,1.55);position:relative;overflow:visible}.fab-main:hover{transform:scale(1.1);box-shadow:var(--shadow-primary-hover)}.fab-main.open{transform:rotate(135deg);background:var(--gradient-2)}.fab-main.open:hover{transform:rotate(135deg) scale(1.1)}.fab-main-icon{font-size:28px;line-height:1;transition:transform .3s ease}.fab-main.open .fab-main-icon{font-size:36px;transform:rotate(-135deg)}.fab-main-label{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.fab-main:not(.open){animation:gentlePulse 2s ease-in-out infinite}@keyframes gentlePulse{0%,to{box-shadow:var(--shadow-primary)}50%{box-shadow:var(--shadow-primary-hover)}}.fab-actions{display:flex;flex-direction:column;gap:20px;margin-bottom:8px}.fab-action-group{display:flex;flex-direction:column;align-items:flex-end;gap:10px;animation:slideInUp .4s cubic-bezier(.68,-.55,.265,1.55);animation-delay:calc(var(--group-index) * .1s);animation-fill-mode:both}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.fab-group-label{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary-color);margin-bottom:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:16px;border:2px solid var(--primary-color);box-shadow:0 2px 8px #667eea33}.fab-action{display:flex;align-items:center;gap:12px;padding:12px 20px;border:2px solid var(--border-color);border-radius:28px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 4px 12px #0000001a;white-space:nowrap;animation:slideInRight .3s cubic-bezier(.68,-.55,.265,1.55);animation-delay:calc(var(--action-index) * .05s + var(--group-index) * .1s);animation-fill-mode:both;min-width:220px;justify-content:flex-start}@keyframes slideInRight{0%{opacity:0;transform:translate(40px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.fab-action:hover:not(:disabled){transform:translate(-4px) scale(1.05);box-shadow:0 6px 20px #00000026}.fab-action:active:not(:disabled){transform:translate(-2px) scale(1.02)}.fab-action.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.8)}.fab-action-icon{font-size:20px;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.fab-action-label{font-size:13px}.fab-action-create:hover:not(:disabled){border-color:#10b981;background:linear-gradient(135deg,#10b9811a,#0596691a);color:#10b981}.fab-action-edit:hover:not(:disabled){border-color:#ff6b6b;background:linear-gradient(135deg,#ff6b6b1a,#ee5a6f1a);color:#ff6b6b}.fab-action-format:hover:not(:disabled){border-color:#4a90e2;background:linear-gradient(135deg,#4a90e21a,#357abd1a);color:#4a90e2}.fab-action-social:hover:not(:disabled){border-color:#764ba2;background:linear-gradient(135deg,#764ba21a,#5d3a7f1a);color:#764ba2}.fab-hint{position:fixed;bottom:100px;right:24px;padding:8px 16px;background:#000c;color:#fff;border-radius:20px;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .3s ease;pointer-events:none}@media(max-width:768px){.floating-action-palette{bottom:16px;right:16px}.fab-main{width:56px;height:56px}.fab-main-icon{font-size:24px}.fab-main.open .fab-main-icon{font-size:32px}.fab-main-label{font-size:9px}.fab-action{padding:10px 16px;font-size:13px}.fab-action-icon{font-size:18px;width:20px;height:20px}.fab-action-label{font-size:12px}.fab-group-label{font-size:12px;padding:6px 14px}.fab-action{min-width:200px}.fab-hint{bottom:84px;right:16px;font-size:11px;padding:6px 12px}}@media(max-width:480px){.floating-action-palette{bottom:12px;right:12px}.fab-main{width:52px;height:52px}.fab-actions{gap:16px}.fab-action-group{gap:8px}.fab-action{min-width:180px}}.json-viewer{height:100%;background:var(--bg-primary);overflow:auto}.json-viewer.split-view{display:flex;overflow:hidden;position:relative}.tree-panel{overflow-y:auto;overflow-x:hidden;min-width:200px;flex-shrink:0;background:var(--bg-primary);display:flex;flex-direction:column;position:relative}.viewer-content{padding:0;overflow-x:visible}.sticky-header-container{position:sticky;top:0;z-index:100;background:var(--bg-primary);padding:16px 20px 12px;border-bottom:2px solid var(--border-color)}.consolidated-toolbar{display:flex;align-items:flex-start;flex-wrap:wrap;gap:8px;padding:12px 16px;background:var(--bg-secondary);border-radius:var(--radius-md);border:2px solid var(--border-color);box-shadow:0 2px 8px #0000001a;overflow:visible}.consolidated-toolbar .search-bar{flex:1 1 auto;min-width:150px;max-width:100%}.consolidated-toolbar .toolbar-btn.compact{flex-shrink:0}.consolidated-toolbar .toolbar-select.compact{flex-shrink:0;min-width:80px}.json-label,.json-icon{display:none}.json-icon:before{display:none}.viewer-error{padding:40px;text-align:center}.viewer-error h3{color:var(--error-color);margin-bottom:12px;font-size:20px;font-weight:var(--font-bold)}.viewer-error p{color:var(--text-primary);font-family:var(--font-mono);font-size:13px;background:var(--bg-secondary);padding:20px;border-radius:var(--radius-md);border-left:4px solid var(--error-color);text-align:left;max-width:600px;margin:0 auto;line-height:1.6}.viewer-empty{padding:40px;text-align:center}.viewer-empty p{color:var(--text-muted);font-size:15px}.tree-content{padding:16px 20px 20px;flex:1;overflow-y:visible;margin-top:0}.toolbar-btn.compact{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:var(--font-semibold);border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:all .3s ease;height:36px;white-space:nowrap;flex-shrink:0}.toolbar-btn.compact .btn-icon{font-size:16px;line-height:1;flex-shrink:0}.toolbar-btn.compact .btn-text{font-size:13px}.toolbar-btn.compact:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.toolbar-btn.compact:active{transform:translateY(0)}.toolbar-select.compact{padding:8px 12px;font-size:13px;font-weight:var(--font-semibold);border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:all .3s ease;height:36px;min-width:80px;flex-shrink:0}.toolbar-select.compact:hover{border-color:var(--primary-color)}.toolbar-select.compact:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media(max-width:1200px){.consolidated-toolbar{gap:6px;padding:10px 14px}.search-input-container{max-width:250px}.toolbar-btn.compact,.toolbar-select.compact{font-size:12px}}@media(max-width:900px){.consolidated-toolbar{gap:6px;padding:10px 12px}.search-input-container{max-width:200px}.toolbar-btn.compact .btn-text{font-size:11px}.toolbar-btn.compact{padding:8px 10px;gap:4px}.toolbar-select.compact{min-width:70px;font-size:12px;padding:8px 10px}}.toolbar-btn{padding:8px 16px;font-size:14px;font-weight:var(--font-semibold);border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:all .3s ease}.toolbar-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.toolbar-btn:active{transform:translateY(0)}.toolbar-select{padding:8px 16px;font-size:14px;font-weight:var(--font-semibold);border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:all .3s ease}.toolbar-select:hover{border-color:var(--primary-color)}.toolbar-select:focus{outline:2px solid var(--primary-color);outline-offset:2px}.resizer{width:5px;background:var(--border-color);cursor:col-resize;flex-shrink:0;position:relative;transition:all .3s ease}.resizer:hover{background:var(--primary-color);box-shadow:0 0 8px var(--primary-light)}.resizer.dragging{background:var(--primary-dark);box-shadow:0 0 12px var(--primary-color)}.resizer:before{content:"";position:absolute;inset:0 -5px}.properties-panel-container{overflow:hidden;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-primary)}@media(max-width:768px){.json-viewer.split-view{flex-direction:column}.tree-panel{width:100%!important;min-width:100%;max-height:60vh;border-right:none;border-bottom:2px solid var(--border-color)}.properties-panel-container{width:100%!important;min-height:40vh;max-height:40vh}.resizer{display:none}.sticky-header-container{padding:12px 16px}.consolidated-toolbar{flex-wrap:wrap;padding:10px 12px;gap:8px}.consolidated-toolbar .search-bar{flex:1 1 100%;max-width:100%;order:1}.toolbar-btn.compact{flex:1 1 auto;min-width:fit-content;padding:10px 12px;font-size:13px;order:2}.toolbar-select.compact{flex:1 1 auto;min-width:70px;padding:10px 12px;font-size:13px;order:3}.tree-content{padding:12px 16px 16px}.viewer-error,.viewer-empty{padding:30px 20px}.viewer-error h3{font-size:18px}.viewer-error p{font-size:12px;padding:16px}.viewer-empty p{font-size:14px}}@media(max-width:768px)and (min-width:601px){.toolbar-btn.compact .btn-text{display:none}.toolbar-btn.compact{padding:8px 10px;min-width:40px;justify-content:center}.toolbar-btn.compact .btn-icon{font-size:18px}.toolbar-select.compact{min-width:60px}}@media(max-width:600px){.sticky-header-container{padding:10px 12px}.consolidated-toolbar{padding:8px 10px;gap:6px}.toolbar-btn.compact .btn-text{display:none}.toolbar-btn.compact{padding:8px 10px;min-width:44px;justify-content:center}.toolbar-btn.compact .btn-icon{font-size:18px}.toolbar-select.compact{padding:8px 10px;font-size:12px;min-width:60px}.tree-content{padding:10px 12px 12px}.viewer-error,.viewer-empty{padding:24px 16px}.viewer-error h3{font-size:16px}}.mobile-viewer-fab{display:none;position:fixed;bottom:104px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--gradient-1);color:#fff;border:none;font-size:24px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:999;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.mobile-viewer-fab:hover{transform:scale(1.1);box-shadow:0 8px 24px #0000004d}.mobile-viewer-fab:active{transform:scale(.95)}.mobile-actions-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease}.mobile-actions-sheet{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-radius:24px 24px 0 0;box-shadow:0 -4px 24px #0003;z-index:1001;max-height:80vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.68,-.55,.265,1.55)}.mobile-actions-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid var(--border-color);position:sticky;top:0;background:var(--bg-primary);z-index:1}.mobile-actions-header h3{margin:0;font-size:18px;font-weight:var(--font-bold);color:var(--text-primary)}.mobile-actions-header .close-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-primary);font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-actions-header .close-btn:hover{background:var(--hover-bg);transform:scale(1.1)}.mobile-actions-header .close-btn:active{transform:scale(.9)}.mobile-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:24px}.mobile-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;min-height:88px}.mobile-action-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mobile-action-btn:active:not(:disabled){transform:translateY(0)}.mobile-action-btn:disabled{opacity:.4;cursor:not-allowed}.mobile-action-btn .action-icon{font-size:28px;line-height:1}.mobile-action-btn .action-label{font-size:13px;font-weight:var(--font-semibold);color:var(--text-primary);text-align:center;line-height:1.2}.search-container{position:relative;display:flex;align-items:center;gap:8px}.mobile-search-close{display:none;width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:24px;line-height:1;cursor:pointer;transition:all .2s ease;flex-shrink:0}.mobile-search-close:hover{background:var(--hover-bg);border-color:var(--primary-color)}.mobile-search-close:active{transform:scale(.9)}.desktop-only{display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-properties-toggle{display:none}@media(max-width:768px){.mobile-viewer-fab{display:flex;align-items:center;justify-content:center;bottom:88px}.mobile-actions-overlay,.mobile-actions-sheet{display:block}.desktop-only{display:none!important}.search-container{display:none}.search-container.mobile-search-active{display:flex;margin:0 16px 12px}.mobile-search-active .mobile-search-close{display:flex;align-items:center;justify-content:center;margin-right:16px}.tree-panel{width:100%!important;min-width:100%;max-height:100vh;border-right:none;border-bottom:none}.properties-panel-container{position:fixed!important;bottom:0;left:0;right:0;width:100%!important;min-height:auto!important;max-height:85vh;background:var(--bg-primary);border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #0003;z-index:998;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);overflow:hidden;display:flex;flex-direction:column}.properties-panel-container.mobile-collapsed{transform:translateY(calc(100% - 48px))}.properties-panel-container.mobile-expanded{transform:translateY(0)}.mobile-properties-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:12px 20px;background:var(--bg-secondary);border:none;border-bottom:2px solid var(--border-color);cursor:pointer;flex-shrink:0;position:relative}.mobile-properties-toggle .toggle-handle{width:40px;height:4px;background:var(--border-color);border-radius:2px;margin-bottom:8px}.mobile-properties-toggle .toggle-text{font-size:13px;font-weight:var(--font-semibold);color:var(--text-muted)}.mobile-properties-toggle:active .toggle-handle{background:var(--primary-color)}.properties-panel{flex:1;overflow-y:auto;overflow-x:hidden}.properties-panel-container.mobile-expanded~.mobile-viewer-fab,.properties-panel-container.mobile-expanded~.floating-action-palette{display:none}}@media(max-width:480px){.mobile-actions-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:20px}.mobile-action-btn{min-height:80px;padding:16px 12px}.mobile-action-btn .action-icon{font-size:24px}.mobile-action-btn .action-label{font-size:12px}.mobile-actions-header{padding:16px 20px}.mobile-actions-header h3{font-size:16px}.mobile-viewer-fab{width:52px;height:52px;bottom:92px;right:20px;font-size:22px}}.differences-summary{display:flex;flex-direction:column;background:var(--bg-primary);border-bottom:2px solid var(--border-color);max-height:300px;min-height:150px;flex-shrink:0}.differences-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color-light);background:var(--bg-secondary)}.differences-title{display:flex;align-items:center;gap:12px}.differences-title h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.differences-count{padding:4px 10px;background:var(--primary-color);color:#fff;border-radius:12px;font-size:12px;font-weight:600}.differences-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.tree-controls{display:flex;gap:6px;padding-right:16px;border-right:1px solid var(--border-color)}.tree-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s;white-space:nowrap}.tree-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-1px)}.tree-btn:active{transform:translateY(0)}.differences-filters{display:flex;gap:8px}.view-toggle{display:flex;gap:4px;border-left:1px solid var(--border-color);padding-left:16px}.view-btn{width:32px;height:32px;padding:0;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:4px;font-size:16px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.view-btn:hover{background:var(--hover-bg);border-color:var(--primary-color)}.view-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.download-btn{background:var(--success-color);color:#fff;border-color:var(--success-color)}.download-btn:hover{background:var(--success-color);opacity:.9;border-color:var(--success-color)}.filter-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:var(--hover-bg);border-color:var(--primary-color)}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.filter-count{padding:2px 6px;background:#0000001a;border-radius:8px;font-size:11px;font-weight:600}.filter-btn.active .filter-count{background:#ffffff4d}.differences-list{flex:1;overflow-y:auto;padding:8px}.no-differences-filter{display:flex;align-items:center;justify-content:center;padding:32px;color:var(--text-secondary);font-size:14px}.difference-item{padding:12px;margin-bottom:8px;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;background:var(--bg-primary)}.difference-item:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translate(4px)}.difference-item.highlighted{background:var(--bg-secondary);border-color:var(--primary-color);border-width:2px;box-shadow:var(--shadow-md)}.difference-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.diff-type-badge{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap}.badge-missing-target{background:#fee;color:#c00}.badge-missing-source{background:#e3f2fd;color:#1565c0}.badge-type-mismatch{background:#fff3cd;color:#856404}.badge-value-different{background:#ffe5cc;color:#c50}.badge-array-length{background:#f3e5f5;color:#6a1b9a}.badge-default{background:#e9ecef;color:#495057}.diff-path{font-family:Monaco,Courier New,monospace;font-size:12px;color:var(--text-primary);font-weight:500}.difference-description{font-size:13px;color:var(--text-secondary);padding-left:4px}.differences-list::-webkit-scrollbar{width:8px}.differences-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.differences-list::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}.differences-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.differences-table-container{flex:1;overflow:auto;padding:0}.differences-table{width:100%;border-collapse:collapse;font-size:13px}.differences-table thead{position:sticky;top:0;background:var(--bg-secondary);z-index:10}.differences-table th{padding:12px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap;-webkit-user-select:none;user-select:none}.differences-table th.sortable{cursor:pointer;transition:background .2s}.differences-table th.sortable:hover{background:var(--hover-bg)}.differences-table tbody tr{border-bottom:1px solid var(--border-color-light);transition:all .2s;cursor:pointer}.differences-table tbody tr:hover{background:var(--hover-bg)}.differences-table tbody tr.highlighted{background:var(--bg-secondary);border-left:4px solid var(--primary-color)}.differences-table td{padding:10px 12px;vertical-align:top}.path-cell{font-family:Monaco,Courier New,monospace;font-size:12px;color:var(--text-primary);font-weight:500;max-width:200px;word-break:break-all}.value-cell{max-width:250px;word-break:break-word}.value-cell code{background:var(--bg-secondary);padding:2px 6px;border-radius:3px;font-size:12px;color:var(--text-primary);font-family:Monaco,Courier New,monospace}.undefined-value{color:var(--text-muted);font-style:italic}.description-cell{color:var(--text-secondary);max-width:300px}.differences-table-container::-webkit-scrollbar{width:8px;height:8px}.differences-table-container::-webkit-scrollbar-track{background:var(--bg-secondary)}.differences-table-container::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}.differences-table-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.side-by-side-viewer{display:flex;flex-direction:column;flex:1;overflow:hidden;background:var(--bg-primary)}.tree-panels{display:flex;flex:1;overflow:hidden}.tree-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.panel-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.panel-document-select{width:100%;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-primary);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.panel-document-select:hover{border-color:var(--primary-color)}.panel-document-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.tree-content{flex:1;overflow-y:auto;padding:16px}.tree-divider{width:2px;background:var(--border-color);flex-shrink:0}.tree-content::-webkit-scrollbar{width:10px}.tree-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.tree-content::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:5px}.tree-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.single-document-viewer{display:flex;flex-direction:column;height:100%;overflow:hidden}.single-document-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-color-primary)}.tree-container{flex:1;overflow-y:auto;padding:16px;background:var(--bg-color-primary)}[data-theme=dark] .single-document-panel,[data-theme=dark] .tree-container{background:var(--dark-bg-color-primary)}@media(max-width:768px){.tree-container{padding:12px}}.document-selector-container{flex:1;display:flex;flex-direction:column;gap:8px;position:relative}.selector-label{font-size:14px;font-weight:600;color:var(--text-primary)}.selector-button-wrapper{position:relative;display:flex;align-items:center;gap:4px}.selector-button{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:14px;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left;flex:1}.selector-clear-button{display:flex;align-items:center;justify-content:center;width:32px;height:38px;padding:0;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:16px;flex-shrink:0}.selector-clear-button:hover{background:var(--bg-tertiary);border-color:var(--error-color);color:var(--error-color)}.selector-button:hover{border-color:var(--primary-color)}.selector-button:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.selector-button-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selector-button-icon{margin-left:8px;font-size:12px;opacity:.6}.selector-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--bg-primary);border:2px solid var(--primary-color);border-radius:6px;box-shadow:var(--shadow-lg);z-index:1000;max-height:400px;display:flex;flex-direction:column}.selector-search{padding:12px;border-bottom:1px solid var(--border-color)}.selector-search-input{width:100%;padding:8px 12px;font-size:14px;border:1px solid var(--border-color);border-radius:4px;outline:none;background:var(--bg-secondary);color:var(--text-primary)}.selector-search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.selector-options{overflow-y:auto;max-height:340px}.selector-group{border-bottom:1px solid var(--border-color-light)}.selector-group:last-child{border-bottom:none}.selector-group-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-secondary);font-size:13px;font-weight:600;color:var(--text-secondary);position:sticky;top:0;z-index:1}.selector-group-header.active{background:var(--bg-tertiary);color:var(--primary-color);border-left:4px solid var(--primary-color);padding-left:8px}.selector-group-icon{font-size:16px}.selector-group-name{flex:1}.selector-group-count{font-size:12px;opacity:.7}.selector-option{display:block;width:100%;padding:10px 12px 10px 36px;font-size:14px;border:none;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;text-align:left;transition:background .15s}.selector-option:hover{background:var(--hover-bg)}.selector-option.selected{background:var(--bg-tertiary);color:var(--primary-color);font-weight:500}.selector-no-results{padding:24px 12px;text-align:center;color:var(--text-secondary);font-size:14px}@media(max-width:768px){.selector-label{font-size:13px}.selector-button{padding:8px 12px;font-size:13px}.selector-dropdown{max-height:300px}.selector-options{max-height:240px}.selector-group-header{padding:8px 10px;font-size:12px}.selector-option{padding:8px 10px 8px 30px;font-size:13px}.selector-search-input{padding:6px 10px;font-size:13px}}.compare-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.compare-document-selectors{display:flex;gap:16px;padding:20px;background:#f8f9fa;border-bottom:1px solid #dee2e6}.selector-container{flex:1;display:flex;flex-direction:column;gap:8px}.selector-container label{font-size:14px;font-weight:600;color:#495057}.document-selector{padding:10px 14px;font-size:14px;border:2px solid #dee2e6;border-radius:6px;background:#fff;color:#495057;cursor:pointer;transition:all .2s}.document-selector:hover{border-color:#4a90e2}.document-selector:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.compare-single-view{display:flex;flex-direction:column;flex:1;overflow:hidden}.compare-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:60px 40px;text-align:center;color:var(--text-secondary)}.empty-state-icon{font-size:80px;margin-bottom:24px;opacity:.5}.compare-empty-state h2{margin:0 0 16px;font-size:24px;font-weight:600;color:var(--text-primary)}.compare-empty-state p{margin:0 0 32px;font-size:16px;color:var(--text-secondary)}.compare-select-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:60px 40px;text-align:center;color:var(--text-secondary)}.compare-select-prompt h2{margin:0 0 16px;font-size:24px;font-weight:600;color:var(--text-primary)}.compare-select-prompt p{margin:0;font-size:16px;color:var(--text-secondary)}.empty-state-steps{display:flex;flex-direction:column;gap:16px;max-width:400px;text-align:left}.step{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary-color);color:#fff;border-radius:50%;font-weight:600;font-size:14px;flex-shrink:0}.step-text{font-size:14px;color:var(--text-primary)}.compare-errors{display:flex;flex-direction:column;gap:12px;padding:20px;background:var(--bg-secondary);border-bottom:2px solid var(--warning-color);margin:0 0 16px}.error-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.error-icon{font-size:24px}.error-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.error-message{padding:10px 14px;background:var(--bg-tertiary);color:var(--error-color);border:1px solid var(--border-color);border-left:4px solid var(--error-color);border-radius:4px;font-size:14px;font-family:Courier New,monospace}.error-help{padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;margin-top:8px}.error-help p{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--text-primary)}.error-help ul{margin:0;padding-left:20px;list-style-type:disc}.error-help li{margin:6px 0;font-size:13px;color:var(--text-secondary);line-height:1.5}.compare-results-section,.compare-preview-section{display:flex;flex-direction:column;flex:1;overflow:hidden}.compare-results-section.expanded{overflow:hidden}.compare-results-section.expanded .differences-summary{flex:1;max-height:none}.compare-results-section.expanded .side-by-side-viewer{display:none}.no-differences-message{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg-secondary);border:1px solid var(--success-color);border-radius:8px;margin:16px}.no-differences-message p{margin:0;font-size:16px;color:var(--success-color);font-weight:500}@media(max-width:768px){.compare-document-selectors{flex-direction:column;padding:16px 12px;gap:12px}.selector-container label{font-size:13px}.document-selector{padding:8px 12px;font-size:13px}.compare-empty-state{padding:40px 20px}.empty-state-icon{font-size:60px}.compare-empty-state h2{font-size:20px}.compare-empty-state p{font-size:14px}.empty-state-steps{max-width:100%;width:100%}.step{padding:10px 12px}.step-number{width:28px;height:28px;font-size:13px}.step-text{font-size:13px}.compare-errors{padding:16px 12px}.error-header h3{font-size:16px}.error-icon{font-size:20px}.error-message{font-size:12px;padding:8px 12px}.error-help{padding:10px 12px}.error-help p{font-size:13px}.error-help li{font-size:12px}.compare-results-section,.compare-preview-section{flex-direction:column}.no-differences-message{padding:20px;margin:12px}.no-differences-message p{font-size:14px}}@media(max-width:480px){.compare-empty-state{padding:30px 16px}.empty-state-icon{font-size:48px}.compare-empty-state h2{font-size:18px}.compare-empty-state p{font-size:13px}.step{padding:8px 10px}}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10000;min-width:280px;max-width:500px;font-size:14px;font-weight:500;animation:toastSlideIn .3s cubic-bezier(.68,-.55,.265,1.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast--exit{animation:toastSlideOut .3s cubic-bezier(.68,-.55,.265,1.55)}@keyframes toastSlideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(120%);opacity:0}}.toast__icon{font-size:18px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex-shrink:0}.toast__message{flex:1;line-height:1.4}.toast--success{background:linear-gradient(135deg,#10b981f2,#059669f2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast--success .toast__icon{background:#fff3}.toast--error{background:linear-gradient(135deg,#ef4444f2,#dc2626f2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast--error .toast__icon{background:#fff3}.toast--info{background:linear-gradient(135deg,#3b82f6f2,#2563ebf2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast--info .toast__icon{background:#fff3}.toast--warning{background:linear-gradient(135deg,#f59e0bf2,#d97706f2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast--warning .toast__icon{background:#fff3}@media(prefers-color-scheme:dark){.toast{box-shadow:0 4px 12px #00000080}.toast--success{background:linear-gradient(135deg,#10b981fa,#059669fa)}.toast--error{background:linear-gradient(135deg,#ef4444fa,#dc2626fa)}.toast--info{background:linear-gradient(135deg,#3b82f6fa,#2563ebfa)}.toast--warning{background:linear-gradient(135deg,#f59e0bfa,#d97706fa)}}@media(max-width:640px){.toast{bottom:16px;right:16px;left:16px;min-width:auto;max-width:none}}.user-menu-container{position:relative;display:flex;align-items:center;width:100%}.user-menu-trigger{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;border:none;background:transparent;cursor:pointer;transition:all .2s ease;position:relative}.user-menu-trigger:hover{background:var(--hover-bg)}.user-menu-trigger:active{background:var(--active-bg)}.user-menu-trigger[aria-expanded=true]{background:var(--hover-bg)}.user-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--accent-color)}.user-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-avatar-placeholder{font-size:14px;font-weight:600;color:#fff;-webkit-user-select:none;user-select:none}.user-info{flex:1;min-width:0;text-align:left}.user-name{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;bottom:calc(100% + 8px);left:0;width:280px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;animation:dropdownSlideUp .2s ease;overflow:hidden}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border-color);background:var(--sidebar-bg)}.user-menu-icon{flex-shrink:0}.user-menu-avatar-small{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-menu-avatar-small-initials{width:32px;height:32px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.user-menu-info{flex:1;min-width:0}.user-menu-email{font-size:14px;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-items{padding:8px 0}.user-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;cursor:pointer;transition:background .15s ease;text-align:left;font-size:14px;color:var(--text-primary)}.user-menu-item:hover{background:var(--hover-bg)}.user-menu-item:active{background:var(--active-bg)}.user-menu-item-icon{font-size:16px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-menu-item-label{flex:1;font-weight:400;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.user-menu-item-badge{font-size:11px;color:var(--text-secondary);font-weight:500;opacity:.7}.user-menu-item-disabled{opacity:.5;cursor:not-allowed!important}.user-menu-item-disabled:hover{background:transparent!important}.user-menu-item-with-arrow{position:relative}.user-menu-item-arrow{font-size:18px;color:var(--text-secondary);font-weight:300;margin-left:auto;flex-shrink:0}.user-menu-divider{height:1px;background:var(--border-color);margin:8px 0}@media(max-width:768px){.user-menu-dropdown{bottom:calc(100% + 8px);top:auto;left:12px;right:12px;width:auto;max-width:320px;animation:dropdownSlideUp .2s ease;z-index:10000}}.user-menu-container{z-index:100;overflow:visible}.user-menu-dropdown{z-index:1001}.document-sidebar{width:280px;background:var(--sidebar-bg);border-right:2px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.document-sidebar.collapsed{width:140px}.sidebar-header{display:flex;align-items:center;justify-content:center;padding:16px 20px;border-bottom:2px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.sidebar-logo{display:flex;align-items:center;justify-content:center}.logo-image{height:32px;width:auto;object-fit:contain;transition:filter .3s ease}[data-theme=light] .logo-image{filter:brightness(0) saturate(100%) invert(42%) sepia(93%) saturate(3000%) hue-rotate(230deg) brightness(95%) contrast(95%)}[data-theme=dark] .logo-image{filter:brightness(0) saturate(100%) invert(68%) sepia(70%) saturate(2000%) hue-rotate(215deg) brightness(105%) contrast(100%)}.desktop-toggle-btn{width:36px;height:36px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:20px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .3s ease;margin-left:auto;flex-shrink:0}.desktop-toggle-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color);transform:scale(1.08)}.collapsed-logo{padding:20px 8px 16px;border-bottom:2px solid var(--border-color);background:var(--bg-primary);text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.collapsed-logo svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.collapsed-logo-text{font-size:6px;font-weight:var(--font-semibold);color:#667eea;letter-spacing:.5px;text-transform:uppercase}.collapsed-header{padding:12px 8px;border-bottom:2px solid var(--border-color);background:var(--bg-primary);text-align:center}.collapsed-title{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:20px}.collapsed-title span{font-size:9px;font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.collapsed-nav-buttons{display:flex;flex-direction:column;gap:8px;padding:12px 8px}.collapsed-nav-btn{width:100%;height:38px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:var(--text-secondary)}.collapsed-nav-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:scale(1.05);box-shadow:var(--shadow-sm)}.collapsed-nav-btn.add-btn{background:var(--bg-primary);color:var(--primary-color);border-color:var(--primary-color);font-weight:700}.collapsed-nav-btn.add-btn:hover{background:var(--primary-color);color:#fff;transform:scale(1.05) translateY(-2px);box-shadow:var(--shadow-primary)}.collapsed-nav-btn.settings-btn{color:var(--text-secondary)}.collapsed-nav-btn.settings-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.collapsed-nav-btn.expand-btn:hover{background:var(--hover-bg);border-color:var(--text-secondary)}.collapsed-nav-btn.sort-btn{font-size:11px;font-weight:600;color:var(--text-secondary)}.collapsed-nav-btn.sort-btn:hover{background:var(--hover-bg);border-color:var(--text-secondary);color:var(--text-primary)}.collapsed-document-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 6px}.collapsed-document-item{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:8px 6px;margin-bottom:6px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s;min-height:36px}.collapsed-document-item:hover{background:var(--hover-bg);border-color:var(--primary-color)}.collapsed-document-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:var(--primary-color);box-shadow:0 1px 3px #6366f133}.collapsed-doc-name{flex:1;font-size:11px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.collapsed-badges{display:flex;gap:4px;align-items:center}.collapsed-change-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:2px 4px;background:#ff6b6b;color:#fff;border-radius:9px;font-size:9px;font-weight:700;flex-shrink:0;box-shadow:0 1px 2px #ff6b6b4d}.collapsed-comment-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:2px 4px;background:#764ba2;color:#fff;border-radius:9px;font-size:9px;font-weight:700;flex-shrink:0;box-shadow:0 1px 2px #764ba24d}.view-mode-section{padding:0;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.sidebar-section-header{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;margin:0}.sidebar-section-header.collapsible{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--bg-secondary);border:none;cursor:pointer;transition:background .2s ease}.sidebar-section-header.collapsible:hover{background:var(--bg-hover)}.collapse-icon{font-size:10px;color:var(--text-secondary);transition:transform .2s ease}.view-selector{display:flex;flex-direction:column;gap:4px;padding:0 12px 12px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.view-option{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-size:14px;color:var(--text-primary);width:100%;text-align:left}.view-option:hover{background:var(--bg-hover);border-color:var(--primary-color);transform:translate(2px)}.view-option.selected{background:var(--primary-color);color:#fff;border-color:var(--primary-color);font-weight:500}.view-option.selected:hover{background:var(--primary-hover);transform:translate(0)}.view-radio{font-size:16px;flex-shrink:0;width:20px;text-align:center}.view-label{flex:1}.view-check{font-size:18px;color:#fff;flex-shrink:0}.sidebar-nav-buttons{display:flex;flex-direction:column;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.nav-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;min-height:48px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:15px;font-weight:var(--font-semibold);transition:all .3s ease;text-align:left;color:var(--text-primary)}.nav-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translate(3px);box-shadow:var(--shadow-sm)}.nav-btn-icon{font-size:18px;min-width:24px;text-align:center}.nav-btn-label{flex:1}.nav-btn.sort-btn .nav-btn-icon{font-size:14px}.nav-btn.add-btn{background:var(--bg-primary);color:var(--primary-color);border-color:var(--primary-color);border-width:2px}.nav-btn.add-btn:hover{background:var(--primary-color);color:#fff;transform:translate(3px) translateY(-2px);box-shadow:var(--shadow-primary)}.nav-btn.add-btn .nav-btn-icon{font-size:24px;font-weight:700}.nav-btn.select-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:var(--shadow-primary)}.nav-btn.settings-btn{color:var(--text-primary);border-color:var(--border-color)}.nav-btn.settings-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.bulk-actions-bar{padding:10px 15px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:10px}.selection-info{display:flex;align-items:center;gap:8px}.selection-info input[type=checkbox]{width:16px;height:16px;cursor:pointer}.selection-count{font-size:13px;font-weight:600;color:var(--primary-color)}.bulk-actions{display:flex;gap:6px;flex-wrap:wrap;width:100%}.bulk-download-btn,.bulk-delete-btn,.bulk-compare-btn{flex:1;min-width:70px;padding:5px 8px;font-size:11px;font-weight:600;border:1px solid;border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap;text-align:center}.bulk-compare-btn{background:var(--bg-primary);color:var(--info-color);border-color:var(--info-color)}.bulk-compare-btn:hover{background:var(--info-color);color:#fff}.bulk-download-btn{background:var(--bg-primary);color:var(--success-color);border-color:var(--success-color)}.bulk-download-btn:hover{background:var(--success-color);color:#fff}.bulk-delete-btn{background:var(--bg-primary);color:var(--error-color);border-color:var(--error-color)}.bulk-delete-btn:hover{background:var(--error-color);color:#fff}.document-list-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden}.document-list{flex:1;overflow-y:auto;padding:12px 10px}.mobile-close-menu-btn{display:none}.empty-state{padding:40px 20px;text-align:center;color:var(--text-muted)}.empty-state p{margin:8px 0;font-size:13px}.empty-hint{font-size:12px;color:var(--text-muted)}.document-item{padding:16px 14px;margin-bottom:10px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center;gap:12px}.document-item:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translate(2px);box-shadow:var(--shadow-sm)}.document-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:var(--primary-color);box-shadow:var(--shadow-primary)}.document-item.select-mode{cursor:pointer}.document-item[draggable=true]{cursor:move}.document-item.dragging{opacity:.6;cursor:move;background:linear-gradient(135deg,#667eea1a,#764ba21a)!important;border:2px dashed var(--primary-color)!important;transform:scale(.98);transition:all .2s ease;box-shadow:0 4px 12px #667eea33}.document-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0}.document-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.document-name{font-size:16px;font-weight:600;color:var(--text-primary);cursor:text;-webkit-user-select:none;user-select:none;line-height:1.4;white-space:normal;word-break:break-word;overflow-wrap:break-word;display:block}.document-metadata{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.document-date{font-size:11px;font-weight:500;color:var(--text-secondary);white-space:nowrap;flex-shrink:0;min-width:fit-content}.document-counts{display:flex;align-items:center;gap:6px;flex-shrink:0}.change-count-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#ff6b6b1a;border:2px solid #ff6b6b;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:600;flex-shrink:0}.change-count-badge:hover{background:#ff6b6b;transform:scale(1.1) translateY(-2px);box-shadow:0 4px 12px #ff6b6b66;z-index:10}.change-count-badge .badge-icon{font-size:14px;line-height:1;transition:transform .3s ease;flex-shrink:0}.change-count-badge:hover .badge-icon{transform:rotate(15deg) scale(1.2)}.change-count-badge .badge-number{font-size:13px;font-weight:700;color:#ff6b6b;transition:color .3s ease;min-width:12px;text-align:center}.change-count-badge:hover .badge-number{color:#fff}.comment-count-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#764ba21a;border:2px solid #764ba2;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:600;flex-shrink:0}.comment-count-badge:hover{background:#764ba2;transform:scale(1.1) translateY(-2px);box-shadow:0 4px 12px #764ba266;z-index:10}.comment-count-badge .badge-icon{font-size:14px;line-height:1;transition:transform .3s ease;flex-shrink:0}.comment-count-badge:hover .badge-icon{transform:rotate(-15deg) scale(1.2)}.comment-count-badge .badge-number{font-size:13px;font-weight:700;color:#764ba2;transition:color .3s ease;min-width:12px;text-align:center}.comment-count-badge:hover .badge-number{color:#fff}.refresh-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;background:#34d3991a;border:2px solid #34d399;border-radius:6px;cursor:pointer;transition:all .3s ease;flex-shrink:0}.refresh-badge:hover{background:#34d399;transform:scale(1.1) translateY(-2px);box-shadow:0 4px 12px #34d39966;z-index:10}.refresh-badge .badge-icon{font-size:14px;line-height:1;transition:transform .3s ease;flex-shrink:0}.refresh-badge:hover .badge-icon{transform:rotate(180deg) scale(1.2)}.document-name-input{width:100%;padding:4px 8px;font-size:13px;border:1px solid var(--primary-color);border-radius:3px;outline:none;font-family:inherit}.document-name-input:focus{box-shadow:0 0 0 2px #6366f133}@media(max-width:768px){.nav-btn{min-height:52px;padding:14px 16px;font-size:16px}.nav-btn-icon{font-size:20px;min-width:28px}.collapsed-nav-btn{width:48px;height:48px;font-size:22px}.sidebar-nav-buttons,.collapsed-nav-buttons{gap:10px}}@media(max-width:480px){.nav-btn{min-height:54px;padding:16px;font-size:17px}.nav-btn-icon{font-size:22px}.sidebar-nav-buttons{gap:12px;padding:16px}.document-sidebar{width:300px}.document-item{padding:16px 14px}}@media(min-width:1024px){.document-sidebar{width:300px}}.mobile-close-btn{display:none}@media(max-width:768px){.desktop-toggle-btn{display:none!important}.document-sidebar{position:fixed!important;top:0;left:0;bottom:0;width:85vw!important;max-width:320px!important;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:none;overflow-y:auto}.document-sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #0003}.document-sidebar.collapsed{width:85vw!important;max-width:280px!important;transform:translate(-100%)}.document-sidebar.collapsed.mobile-open{transform:translate(0)}.mobile-close-btn{display:flex;align-items:center;justify-content:center;position:absolute;top:12px;left:calc(100% - 56px);width:48px;height:48px;background:var(--bg-primary);border:3px solid var(--primary-color);border-radius:50%;cursor:pointer;font-size:28px;line-height:1;color:var(--primary-color);z-index:1001;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:300;box-shadow:0 4px 16px #00000040}.mobile-close-btn:hover{background:var(--primary-color);color:#fff;transform:scale(1.1) rotate(90deg);box-shadow:0 6px 24px #6366f180}.mobile-close-btn:active{transform:scale(.95) rotate(90deg)}.sidebar-logo,.collapsed-logo{padding-right:56px;position:relative}.mobile-close-menu-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:18px;background:var(--bg-primary);color:var(--primary-color);border:2px solid var(--primary-color);border-top:2px solid var(--primary-color);font-size:17px;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;flex-shrink:0;box-shadow:0 -4px 12px #0000001a}.mobile-close-menu-btn:hover{background:var(--primary-color);color:#fff;box-shadow:0 -6px 16px #6366f14d}.mobile-close-menu-btn:active{transform:scale(.98)}.sidebar-nav-buttons{padding:16px;gap:12px}.nav-btn{min-height:52px;font-size:16px}.collapsed-nav-buttons{padding:16px 12px;gap:12px}.collapsed-nav-btn{min-height:52px;font-size:24px}.document-list{padding:16px 12px}.document-item{padding:16px;margin-bottom:12px}.bulk-actions-bar{padding:14px 16px}.bulk-actions{gap:8px}.bulk-download-btn,.bulk-delete-btn,.bulk-compare-btn{padding:10px 12px;font-size:13px;min-height:44px}}@media(max-width:480px){.document-sidebar{width:90vw!important;max-width:320px!important}.document-sidebar.collapsed{width:90vw!important}.mobile-close-btn{width:44px;height:44px;font-size:28px;top:10px;left:calc(100% - 54px)}.nav-btn{min-height:54px;font-size:17px}.document-item{padding:18px 16px}.document-name{font-size:15px}}.sidebar-section{border-bottom:1px solid var(--border-color)}.projects-section{padding:.75rem 0}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;font-size:.75rem;font-weight:600;letter-spacing:.05em;color:var(--text-secondary);text-transform:uppercase}.section-title{flex:1}.browse-projects-btn,.clear-filter-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;line-height:1}.browse-projects-btn:hover,.clear-filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.projects-list{display:flex;flex-direction:column;gap:.25rem;padding:0 .5rem}.project-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s;text-align:left;width:100%}.project-item:hover{background:var(--bg-hover);border-color:var(--border-color)}.project-item.active{background:var(--accent-bg);border-color:var(--accent-color);color:var(--accent-color)}.project-icon{font-size:1.2rem;line-height:1;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid transparent;transition:all .2s ease}.project-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-count{font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.project-item.active .project-count{color:var(--accent-color)}.view-all-projects-btn{padding:.5rem .75rem;background:transparent;border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s;text-align:center;width:100%}.view-all-projects-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-style:solid}.documents-section-header{padding:.5rem 0}.browse-projects-empty-btn{margin:.5rem .5rem .75rem;width:calc(100% - 1rem)}.project-group{margin-bottom:.5rem}.project-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;margin:0 .5rem}.project-header:hover{cursor:pointer;opacity:.9}.project-header.active{box-shadow:var(--shadow-sm)}.project-header.unorganized-header{background:var(--bg-secondary);opacity:.8}.project-header.dragging{opacity:.6;cursor:move;background:linear-gradient(135deg,#667eea1a,#764ba21a)!important;border:2px dashed var(--primary-color)!important;transform:scale(.98);transition:all .2s ease;box-shadow:0 4px 12px #667eea33}.project-header.drag-over{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:var(--primary-color);border-style:dashed;border-width:3px;transform:scale(1.02);box-shadow:0 0 0 4px #667eea33}.project-expand-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;font-size:.9rem;transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.project-expand-btn:hover{color:var(--text-primary)}.project-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0;margin-right:.5rem}.expand-icon{display:inline-block;transition:transform .2s ease}.project-info{display:flex;align-items:flex-start;gap:.5rem;flex:1;min-width:0}.project-info .project-icon{font-size:1.2rem;flex-shrink:0;line-height:1.4}.project-details{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.project-name-row{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}.project-info .project-name{flex:1;font-size:.95rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text}.project-info .project-count{font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.project-meta{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem;color:var(--text-secondary);line-height:1.3}.project-description{opacity:.8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-last-edited{opacity:.6;font-size:.7rem}.project-customize-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:.25rem .5rem;font-size:1rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.project-customize-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:scale(1.1)}.project-favorite-btn{background:transparent;border:1px solid transparent;color:var(--text-secondary);cursor:pointer;padding:.25rem .5rem;font-size:1.2rem;border-radius:4px;transition:all .2s ease;flex-shrink:0;line-height:1}.project-favorite-btn:hover{background:var(--hover-bg);border-color:var(--border-color);transform:scale(1.15)}.project-favorite-btn.active{color:#feca57}.project-favorite-btn.active:hover{transform:scale(1.15) rotate(15deg)}.project-name-input{flex:1;padding:.25rem .5rem;font-size:.95rem;font-weight:600;border:2px solid var(--primary-color);border-radius:4px;outline:none;font-family:inherit;background:var(--bg-primary);color:var(--text-primary)}.project-name-input:focus{box-shadow:0 0 0 2px #6366f133}.project-documents{padding:.25rem .5rem .5rem 1.5rem;animation:slideDown .2s ease}.project-documents .document-item{margin-bottom:.25rem;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s ease}.project-documents .document-item:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translate(2px);box-shadow:var(--shadow-sm)}.project-documents .document-item.active{background:var(--bg-secondary);border-color:var(--primary-color);border-left:3px solid var(--primary-color);box-shadow:var(--shadow-md)}.project-documents .document-item.dragging{opacity:.6;background:var(--bg-tertiary);border:2px dashed var(--primary-color);transform:scale(.98);transition:all .2s ease;box-shadow:var(--shadow-primary)}.project-documents .document-item[draggable=true]{cursor:move}.project-documents .document-name{font-size:14px;font-weight:500;color:var(--text-primary)}.project-documents .document-date{font-size:10px;color:var(--text-secondary)}.empty-project-hint{padding:1rem;text-align:center;color:var(--text-muted);font-size:.85rem;font-style:italic}.sidebar-action-buttons{display:flex;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;min-height:40px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:var(--font-semibold);transition:all .2s ease;color:var(--text-primary)}.action-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.action-btn-icon{font-size:16px}.action-btn-label{font-size:12px}.action-btn.select-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:var(--shadow-primary)}.browse-projects-btn-top{width:100%;margin:0}.sidebar-footer{position:absolute;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:2px solid var(--border-color);padding:12px;z-index:10}.footer-settings-btn{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:15px;font-weight:var(--font-semibold);transition:all .2s ease;color:var(--text-primary)}.footer-settings-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.footer-btn-icon{font-size:20px}.footer-btn-label{flex:1;text-align:left}.document-list-wrapper{padding-bottom:80px}@media(max-width:767px){.projects-section{padding:.5rem 0}.project-item{padding:.5rem;font-size:.85rem}.project-icon{font-size:1rem}.section-title{font-size:.7rem}.sidebar-footer{position:fixed;overflow:visible;z-index:100}.sidebar-action-buttons{flex-wrap:wrap}.action-btn{min-height:44px;font-size:14px}}.settings-overlay{position:fixed;inset:0;background-color:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .2s ease-in}.settings-modal{background:var(--modal-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:850px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;border:1px solid var(--border-color-light)}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.settings-header h2{margin:0;font-size:24px;font-weight:var(--font-bold);color:var(--text-primary)}.close-btn{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s ease}.settings-body{display:flex;overflow:hidden;height:600px}.settings-menu{width:200px;background:var(--bg-secondary);border-right:2px solid var(--border-color);display:flex;flex-direction:column;padding:16px 12px;gap:8px;flex-shrink:0}.menu-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-size:15px;font-weight:var(--font-medium);color:var(--text-secondary);transition:all .3s ease;text-align:left}.menu-item:hover{background:var(--hover-bg);color:var(--text-primary);border-color:var(--border-color)}.menu-item.active{background:linear-gradient(135deg,#667eea26,#764ba226);color:var(--primary-color);border-color:var(--primary-color);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.menu-icon{font-size:18px;display:flex;align-items:center;justify-content:center}.menu-label{flex:1}.settings-content{flex:1;overflow-y:auto;padding:28px}.content-header{margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid var(--border-color)}.content-header h3{margin:0 0 8px;font-size:22px;font-weight:var(--font-bold);color:var(--text-primary)}.content-description{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.settings-section{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border-color-light)}.settings-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.section-title{font-size:18px;font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 16px}.theme-section{background:linear-gradient(135deg,#667eea0d,#764ba20d);padding:20px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:16px}.theme-card{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;text-align:left;position:relative;overflow:hidden}.theme-card:hover{border-color:var(--primary-light);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.theme-card.active{border-color:var(--primary-color);box-shadow:var(--shadow-primary);background:linear-gradient(135deg,#667eea14,#764ba214)}.theme-card.active:hover{transform:translateY(-6px);box-shadow:var(--shadow-primary-hover)}.theme-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.theme-card-title{font-size:16px;font-weight:var(--font-bold);color:var(--text-primary);line-height:1.3}.theme-card-badge{background:var(--gradient-1);color:#fff;font-size:11px;font-weight:var(--font-bold);padding:4px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;box-shadow:var(--shadow-sm)}.theme-card-preview{height:60px;border-radius:var(--radius-md);border:2px solid;display:flex;align-items:center;justify-content:center;padding:12px;position:relative;overflow:hidden;transition:all .3s ease}.theme-preview-colors{display:flex;gap:8px;align-items:center;justify-content:center}.theme-preview-colors span{width:32px;height:32px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:all .3s ease}.theme-card:hover .theme-preview-colors span{transform:scale(1.1)}.theme-card-description{font-size:13px;color:var(--text-secondary);line-height:1.5;flex-grow:1}.theme-card-author{font-size:12px;color:var(--text-muted);font-style:italic;margin-top:4px}.settings-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:var(--font-medium);color:var(--text-primary)}.settings-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary-color)}.url-input{width:100%;padding:12px 14px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease}.url-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.url-input:disabled{background-color:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed;opacity:.6}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.add-header-btn{padding:8px 16px;background:var(--gradient-1);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.add-header-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-primary)}.add-header-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.5;box-shadow:none}.headers-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.header-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center}.header-key,.header-value{padding:10px 12px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease}.header-key:focus,.header-value:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.header-key:disabled,.header-value:disabled{background-color:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed;opacity:.6}.remove-header-btn{width:36px;height:36px;padding:0;background-color:#ef44441a;color:var(--error-color);border:2px solid transparent;border-radius:var(--radius-md);font-size:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.remove-header-btn:hover:not(:disabled){background-color:var(--error-color);color:#fff;transform:scale(1.05)}.remove-header-btn:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.4}.empty-state{padding:20px;background-color:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-md);text-align:center;color:var(--text-secondary);font-size:14px;margin-top:12px}.settings-footer{display:flex;justify-content:flex-end;gap:16px;padding:20px 28px;border-top:1px solid var(--border-color);background:linear-gradient(135deg,#667eea05,#764ba205)}.cancel-btn,.save-btn{padding:12px 28px;border-radius:var(--radius-md);font-size:15px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;min-width:100px}.cancel-btn:hover{background-color:var(--hover-bg);border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.save-btn{background:var(--gradient-1);color:#fff;border:none;box-shadow:var(--shadow-sm)}.save-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.info-box.warning{background:#f59e0b1a;border-left-color:var(--warning-color)}.info-box.warning p{margin:8px 0 0;color:var(--text-secondary)}.version-badge-inline{display:inline-flex;align-items:center;gap:8px;background:var(--gradient-1);color:#fff;padding:6px 14px;border-radius:20px;margin-bottom:12px;font-size:13px}.version-badge-inline .version-label{font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;opacity:.9}.version-badge-inline .version-number{font-weight:var(--font-bold);font-family:var(--font-mono)}.whats-new-content{margin-top:24px}.feature-section{padding:24px 0;border-bottom:1px solid var(--border-color)}.feature-section:last-child{border-bottom:none}.feature-heading{font-size:20px;font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 16px;display:flex;align-items:center;gap:10px}.feature-icon-small{font-size:24px}.feature-description-list{list-style:none;padding:0;margin:0}.feature-description-list li{position:relative;padding-left:24px;margin-bottom:12px;font-size:14px;line-height:1.6;color:var(--text-secondary)}.feature-description-list li:before{content:"→";position:absolute;left:0;color:var(--primary-color);font-weight:var(--font-bold)}.feature-description-list li:last-child{margin-bottom:0}.change-history-modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-in}.change-history-modal{background:var(--modal-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:2px solid var(--border-color);width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.change-history-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--border-color);background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.change-history-header h3{margin:0 0 4px;font-size:18px;font-weight:var(--font-semibold);color:var(--text-primary)}.document-title{margin:0;font-size:13px;color:var(--text-secondary);font-family:var(--font-mono)}.close-button{width:32px;height:32px;border:none;background:transparent;font-size:20px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-button:hover{background:var(--hover-bg);color:var(--text-primary)}.change-history-stats{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-primary);border-bottom:2px solid var(--border-color);gap:16px}.stats-left{display:flex;flex-direction:column;gap:4px}.stat-item{font-size:14px;color:var(--text-secondary)}.stat-item strong{color:var(--text-primary);font-weight:var(--font-semibold);font-size:16px}.stats-hint{font-size:12px;color:var(--text-muted);opacity:.8}.restore-all-btn{padding:8px 16px;font-size:13px;font-weight:var(--font-semibold);border:2px solid transparent;background:var(--gradient-1);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.restore-all-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-primary-hover)}.restore-all-btn:active{transform:translateY(0)}.change-history-list{flex:1;overflow-y:auto;padding:16px 20px;background:var(--bg-secondary)}.empty-history{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-history p{margin:8px 0;color:var(--text-muted);font-size:14px}.empty-hint{font-size:12px!important;color:var(--text-muted)!important;opacity:.7}.change-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:10px;transition:all .2s ease}.change-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #6366f11a}.change-path-line{display:flex;align-items:center;gap:10px;margin-bottom:8px}.change-number{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:20px;padding:0 6px;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-semibold);flex-shrink:0}.change-path-text{font-family:var(--font-mono);font-size:13px;color:var(--text-primary);font-weight:var(--font-medium);flex:1;word-break:break-word}.change-value-line{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;padding-left:38px}.change-inline-values{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.value-old{color:#ef4444;font-family:var(--font-mono);font-size:13px;font-weight:var(--font-medium);word-break:break-word}.value-arrow{color:var(--text-muted);font-size:14px;flex-shrink:0}.value-new{color:#10b981;font-family:var(--font-mono);font-size:13px;font-weight:var(--font-medium);word-break:break-word}.restore-change-btn{padding:5px 12px;font-size:12px;font-weight:var(--font-semibold);border:1.5px solid var(--success-color);background:var(--bg-primary);color:var(--success-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;flex-shrink:0;white-space:nowrap}.restore-change-btn:hover{background:var(--success-color);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #10b98133}.restore-change-btn:active{transform:translateY(0)}.change-footer{display:flex;align-items:center;justify-content:space-between;padding-left:38px;gap:12px}.change-timestamp{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.expand-btn{padding:4px 8px;font-size:11px;font-weight:var(--font-medium);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.expand-btn:hover{background:var(--hover-bg);color:var(--text-primary);border-color:var(--primary-color)}.change-expanded-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.expanded-section{background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-color)}.expanded-label{padding:6px 12px;background:var(--bg-primary);font-size:11px;font-weight:var(--font-bold);color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.expanded-value{padding:12px;margin:0;font-family:var(--font-mono);font-size:12px;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;background:var(--bg-secondary)}@media(max-width:768px){.change-history-modal{width:95%;max-height:95vh}.change-history-stats{flex-direction:column;align-items:flex-start;gap:12px}.restore-all-btn{width:100%;justify-content:center}.change-value-line{flex-direction:column;align-items:stretch;gap:8px}.restore-change-btn{width:100%;justify-content:center}.change-footer{flex-direction:column;align-items:flex-start;gap:6px}.expand-btn{width:100%}}@media(max-width:480px){.change-history-header h3{font-size:16px}.document-title,.change-path-text{font-size:12px}.change-inline-values{flex-wrap:wrap}}.comment-input{display:flex;flex-direction:column;gap:8px;width:100%}.comment-textarea{width:100%;padding:8px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-family:inherit;font-size:14px;resize:vertical;min-height:60px;background:var(--bg-primary, #fff);color:var(--text-primary, #333)}.comment-textarea:focus{outline:none;border-color:var(--accent-color, #667eea);box-shadow:0 0 0 2px #667eea1a}.comment-input-actions{display:flex;justify-content:space-between;align-items:center;gap:12px}.comment-hint{font-size:12px;color:var(--text-secondary, #666)}.comment-buttons{display:flex;gap:8px}.comment-cancel-btn,.comment-save-btn{padding:6px 12px;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s}.comment-cancel-btn{background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333)}.comment-cancel-btn:hover{background:var(--bg-tertiary, #e5e5e5)}.comment-save-btn{background:var(--accent-color, #667eea);color:#fff}.comment-save-btn:hover:not(:disabled){background:var(--accent-color-dark, #5568d3)}.comment-save-btn:disabled{opacity:.5;cursor:not-allowed}.comments-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.comments-modal{background:var(--bg-primary, #fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;width:95%;max-width:1200px;height:85vh;display:flex;flex-direction:column;overflow:hidden}.comments-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;border-bottom:2px solid var(--border-color, #e5e5e5)}.comments-header h3{margin:0;font-size:24px;color:var(--text-primary, #333);display:flex;align-items:center;gap:8px}.document-title{margin:4px 0 0;font-size:14px;color:var(--text-secondary, #666);font-weight:400}.comments-stats{display:flex;align-items:center;gap:16px;padding:12px 24px;background:var(--bg-secondary, #f9f9f9);border-bottom:1px solid var(--border-color, #e5e5e5);flex-wrap:wrap;justify-content:space-between}.comments-actions{display:flex;gap:8px;margin-left:auto}.stat-item{font-size:14px;color:var(--text-primary, #333)}.stat-item strong{font-weight:600;color:var(--accent-color, #764ba2)}.stat-secondary{color:var(--text-secondary, #666);font-size:13px}.add-comment-btn,.export-btn{padding:6px 12px;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.add-comment-btn{background:var(--accent-color, #764ba2);color:#fff;box-shadow:0 2px 4px #764ba233}.add-comment-btn:hover{background:var(--accent-color-dark, #5d3a7f);transform:translateY(-1px);box-shadow:0 4px 8px #764ba24d}.export-btn{background:var(--bg-primary, #fff);color:var(--text-primary, #333);border:1px solid var(--border-color, #ddd)}.export-btn:hover{background:var(--bg-tertiary, #e5e5e5);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.comments-filter{display:flex;gap:8px;padding:12px 24px;border-bottom:1px solid var(--border-color, #e5e5e5)}.filter-btn{padding:6px 12px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;color:var(--text-primary, #333)}.filter-btn:hover{background:var(--bg-tertiary, #e5e5e5)}.filter-btn.active{background:var(--accent-color, #764ba2);color:#fff;border-color:var(--accent-color, #764ba2)}.add-comment-section{padding:16px 24px;background:var(--bg-secondary, #f9f9f9);border-bottom:1px solid var(--border-color, #e5e5e5)}.add-comment-section h4{margin:0 0 12px;font-size:14px;color:var(--text-primary, #333)}.comments-list{flex:1;overflow-y:auto;padding:16px 24px}.empty-comments{text-align:center;padding:60px 20px;color:var(--text-secondary, #666)}.empty-comments p{margin:8px 0}.empty-comments p:first-child{font-size:16px;font-weight:500;color:var(--text-primary, #333)}.empty-hint{font-size:14px;color:var(--text-secondary, #999)}.comment-item{background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e5e5);border-radius:8px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}.comment-item:hover{border-color:var(--accent-color, #764ba2);box-shadow:0 2px 8px #764ba21a}.comment-item.selected{border-color:var(--accent-color, #764ba2);box-shadow:0 4px 12px #764ba233;background:var(--bg-highlight, #fafafa)}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.comment-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.comment-number{font-weight:600;color:var(--accent-color, #764ba2);font-size:13px}.comment-timestamp{font-size:12px;color:var(--text-secondary, #666)}.comment-edited{font-size:11px;color:var(--text-secondary, #999);font-style:italic}.comment-actions{display:flex;gap:4px}.navigate-comment-btn,.edit-comment-btn,.delete-comment-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:all .2s;opacity:.6}.navigate-comment-btn:hover,.edit-comment-btn:hover,.delete-comment-btn:hover{opacity:1;background:var(--bg-secondary, #f5f5f5)}.comment-path{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:6px 10px;background:var(--bg-secondary, #f5f5f5);border-radius:4px;font-size:12px}.path-label{font-weight:500;color:var(--text-secondary, #666)}.comment-path code{font-family:Monaco,Menlo,Courier New,monospace;font-size:11px;color:var(--text-primary, #333);background:var(--bg-tertiary, #e5e5e5);padding:2px 6px;border-radius:3px}.comment-text{padding:12px;background:var(--bg-secondary, #f9f9f9);border-radius:6px;font-size:14px;line-height:1.6;color:var(--text-primary, #333);white-space:pre-wrap;word-wrap:break-word}.comment-edit-section{margin-top:8px}.comment-value-snapshot{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color, #e5e5e5)}.value-snapshot-header{font-size:12px;font-weight:500;color:var(--text-secondary, #666);margin-bottom:8px}.value-snapshot-content{background:var(--bg-code, #282c34);color:var(--text-code, #abb2bf);padding:12px;border-radius:6px;font-size:12px;font-family:Monaco,Menlo,Courier New,monospace;overflow-x:auto;max-height:200px;overflow-y:auto;margin:0}.comments-list::-webkit-scrollbar,.value-snapshot-content::-webkit-scrollbar{width:8px;height:8px}.comments-list::-webkit-scrollbar-track,.value-snapshot-content::-webkit-scrollbar-track{background:var(--bg-secondary, #f5f5f5);border-radius:4px}.comments-list::-webkit-scrollbar-thumb,.value-snapshot-content::-webkit-scrollbar-thumb{background:var(--border-color, #ddd);border-radius:4px}.comments-list::-webkit-scrollbar-thumb:hover,.value-snapshot-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.comments-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;border-bottom:1px solid var(--border-color, #e5e5e5);flex-wrap:wrap;gap:12px}.comments-filter,.view-mode-toggle{display:flex;gap:8px}.view-mode-btn{padding:6px 12px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;color:var(--text-primary, #333)}.view-mode-btn:hover{background:var(--bg-tertiary, #e5e5e5)}.view-mode-btn.active{background:var(--accent-color, #764ba2);color:#fff;border-color:var(--accent-color, #764ba2)}.replies-section{margin-top:16px;padding:12px;background:var(--bg-secondary, #f9f9f9);border-left:3px solid var(--accent-color, #764ba2);border-radius:4px}.replies-header{font-size:12px;font-weight:600;color:var(--accent-color, #764ba2);margin-bottom:12px}.reply-item{background:#fff;padding:10px;border-radius:4px;margin-bottom:8px;border:1px solid var(--border-color, #e5e5e5)}.reply-item:last-child{margin-bottom:0}.reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.reply-timestamp{font-size:11px;color:var(--text-secondary, #666)}.reply-edited{font-size:10px;color:var(--text-secondary, #999);font-style:italic;margin-left:6px}.reply-actions{display:flex;gap:4px}.edit-reply-btn,.delete-reply-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:2px 4px;border-radius:3px;transition:all .2s;opacity:.6}.edit-reply-btn:hover,.delete-reply-btn:hover{opacity:1;background:var(--bg-secondary, #f5f5f5)}.reply-text{font-size:13px;line-height:1.5;color:var(--text-primary, #333);padding:6px;background:var(--bg-tertiary, #fafafa);border-radius:3px}.reply-edit-section{margin-top:4px}.reply-input-section{margin-top:12px;padding:12px;background:var(--bg-secondary, #f9f9f9);border-left:3px solid var(--accent-color, #764ba2);border-radius:4px}.reply-button{margin-top:12px;padding:6px 12px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s;color:var(--text-primary, #333);width:100%}.reply-button:hover{background:var(--accent-color, #764ba2);color:#fff;border-color:var(--accent-color, #764ba2)}.comments-table-container{flex:1;overflow:auto;padding:16px 24px}.comments-table{width:100%;border-collapse:collapse;font-size:13px}.comments-table thead{position:sticky;top:0;background:var(--bg-secondary, #f5f5f5);z-index:10}.comments-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-primary, #333);border-bottom:2px solid var(--border-color, #ddd);white-space:nowrap}.comments-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.comments-table th.sortable:hover{background:var(--bg-tertiary, #e5e5e5)}.comments-table tbody tr{border-bottom:1px solid var(--border-color, #e5e5e5);transition:background .2s}.comments-table tbody tr:hover{background:var(--bg-highlight, #fafafa)}.comments-table td{padding:12px 16px;vertical-align:top}.datetime-cell{min-width:160px}.datetime-cell .edited-note{font-size:11px;color:var(--text-secondary, #999);margin-top:4px;font-style:italic}.path-cell{min-width:200px}.path-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.path-badge.document{background:#e3f2fd;color:#1976d2}.path-code{font-family:Monaco,Menlo,Courier New,monospace;font-size:11px;background:var(--bg-secondary, #f5f5f5);padding:2px 6px;border-radius:3px;color:var(--text-primary, #333)}.comment-cell{max-width:400px;word-wrap:break-word}.replies-cell{text-align:center;min-width:80px}.replies-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:2px 6px;background:var(--accent-color, #764ba2);color:#fff;border-radius:12px;font-size:11px;font-weight:700}.no-replies{color:var(--text-secondary, #999)}.actions-cell{min-width:110px;white-space:nowrap}.table-action-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:all .2s;opacity:.6;margin:0 2px;display:inline-block}.table-action-btn:hover{opacity:1;background:var(--bg-secondary, #f5f5f5)}.comments-table-container::-webkit-scrollbar{width:8px;height:8px}.comments-table-container::-webkit-scrollbar-track{background:var(--bg-secondary, #f5f5f5);border-radius:4px}.comments-table-container::-webkit-scrollbar-thumb{background:var(--border-color, #ddd);border-radius:4px}.comments-table-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.comments-report{flex:1;overflow-y:auto;padding:24px 32px;background:var(--bg-primary, #fff);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:var(--text-primary, #333)}.report-header{margin-bottom:24px}.report-header h1{margin:0 0 16px;font-size:28px;color:var(--text-primary, #333);font-weight:600}.report-stats{display:flex;gap:24px;flex-wrap:wrap;font-size:14px;color:var(--text-secondary, #666)}.report-stats span{display:flex;align-items:center;gap:4px}.report-divider{border:none;border-top:2px solid var(--border-color, #e5e5e5);margin:24px 0}.report-toc{margin-bottom:32px}.report-toc h2{margin:0 0 16px;font-size:22px;color:var(--text-primary, #333);font-weight:600}.toc-list{list-style:decimal;padding-left:24px;margin:0}.toc-list li{margin-bottom:16px;line-height:1.4}.toc-list li a{color:var(--accent-color, #764ba2);text-decoration:none;font-weight:500;font-size:15px}.toc-list li a:hover{text-decoration:underline}.toc-list li code{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;background:var(--bg-secondary, #f5f5f5);padding:2px 6px;border-radius:3px;color:var(--text-primary, #333)}.toc-list blockquote{margin:8px 0 0;padding:8px 12px;background:var(--bg-secondary, #f9f9f9);border-left:3px solid var(--border-color, #ddd);font-size:13px;color:var(--text-secondary, #666);font-style:italic}.report-comment{margin-bottom:32px;scroll-margin-top:20px}.report-comment h2{margin:0 0 12px;font-size:20px;color:var(--accent-color, #764ba2);font-weight:600}.report-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;font-size:13px;color:var(--text-secondary, #666)}.report-meta strong{color:var(--text-primary, #333)}.report-meta code{font-family:Monaco,Menlo,Courier New,monospace;font-size:12px;background:var(--bg-secondary, #f5f5f5);padding:2px 6px;border-radius:3px;color:var(--text-primary, #333)}.report-comment-text{margin-bottom:16px}.report-comment-text strong{display:block;margin-bottom:8px;font-size:14px;color:var(--text-primary, #333)}.report-comment-text p{margin:0;padding:12px 16px;background:var(--bg-secondary, #f9f9f9);border-radius:6px;font-size:14px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.report-value-snapshot{margin-bottom:16px}.report-value-snapshot strong{display:block;margin-bottom:8px;font-size:14px;color:var(--text-primary, #333)}.report-value-snapshot pre{margin:0;padding:16px;background:var(--bg-code, #282c34);border-radius:6px;overflow-x:auto;max-height:300px;overflow-y:auto}.report-value-snapshot code{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;color:var(--text-code, #abb2bf);line-height:1.5}.report-replies{margin:16px 0;padding:16px;background:var(--bg-secondary, #f9f9f9);border-left:4px solid var(--accent-color, #764ba2);border-radius:4px}.report-replies h3{margin:0 0 16px;font-size:16px;color:var(--accent-color, #764ba2);font-weight:600}.report-reply{margin-bottom:16px;padding:12px;background:var(--bg-primary, #fff);border-radius:4px;border:1px solid var(--border-color, #e5e5e5)}.report-reply:last-child{margin-bottom:0}.report-reply h4{margin:0 0 8px;font-size:14px;color:var(--text-primary, #333);font-weight:600}.report-reply p{margin:0;font-size:14px;line-height:1.6;color:var(--text-primary, #333)}.report-back-link{margin-top:16px;text-align:right}.report-back-link a{color:var(--accent-color, #764ba2);text-decoration:none;font-size:13px;font-weight:500}.report-back-link a:hover{text-decoration:underline}.comments-report::-webkit-scrollbar{width:8px}.comments-report::-webkit-scrollbar-track{background:var(--bg-secondary, #f5f5f5);border-radius:4px}.comments-report::-webkit-scrollbar-thumb{background:var(--border-color, #ddd);border-radius:4px}.comments-report::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.load-summary-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.load-summary-modal{background:var(--bg-primary, #fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.load-summary-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:2px solid var(--border-color, #e5e5e5)}.load-summary-header h3{margin:0;font-size:22px;color:var(--text-primary, #333);font-weight:600}.close-button{background:none;border:none;font-size:24px;color:var(--text-secondary, #666);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;line-height:1}.close-button:hover{background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333)}.load-summary-content{flex:1;overflow-y:auto;padding:24px}.limit-warning{background:linear-gradient(135deg,#fff5e1,#ffe0e0);border:2px solid #ff9800;border-left:5px solid #c62828;border-radius:8px;padding:16px;margin-bottom:24px;box-shadow:0 2px 8px #c628281a}.limit-warning strong{display:block;font-size:15px;color:#c62828;margin-bottom:8px}.limit-warning p{margin:0;font-size:13px;color:#5d4037;line-height:1.5}.limit-warning strong:first-child{font-size:16px}.summary-section{margin-bottom:24px}.summary-section:last-child{margin-bottom:0}.summary-section h4{margin:0 0 12px;font-size:16px;color:var(--text-primary, #333);font-weight:600}.zip-filename{margin:0;padding:12px 16px;background:var(--bg-secondary, #f5f5f5);border-radius:6px;font-family:Monaco,Menlo,Courier New,monospace;font-size:14px;color:var(--text-primary, #333);word-break:break-all}.summary-stats{display:flex;flex-direction:column;gap:8px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-secondary, #f5f5f5);border-radius:6px;font-size:14px}.stat-item.success{background:#e8f5e9;color:#2e7d32}.stat-item.filtered{background:#fff3e0;color:#e65100}.stat-item.limit-exceeded{background:#ffe0e0;color:#c62828;border-left:3px solid #c62828}.stat-label{font-weight:500}.stat-value{font-weight:700;font-size:16px}.file-list{list-style:none;margin:0;max-height:200px;overflow-y:auto;background:var(--bg-secondary, #f9f9f9);border-radius:6px;padding:8px}.file-list li{padding:8px 12px;margin-bottom:4px;background:var(--bg-primary, #fff);border-radius:4px;font-size:13px;color:var(--text-primary, #333);display:flex;align-items:center;gap:8px;border:1px solid var(--border-color, #e5e5e5)}.file-list li:last-child{margin-bottom:0}.file-list.loaded li{border-left:3px solid #4caf50}.file-list.filtered li{border-left:3px solid #ff9800;opacity:.7}.file-icon{font-size:16px;flex-shrink:0}.load-summary-footer{padding:16px 24px;border-top:1px solid var(--border-color, #e5e5e5);display:flex;justify-content:space-between;gap:12px}.cancel-button{padding:12px 24px;background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333);border:2px solid var(--border-color, #ddd);border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-width:100px}.cancel-button:hover{background:var(--hover-bg, #e8e8e8);border-color:var(--text-secondary, #999);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.accept-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #667eea4d;min-width:150px}.accept-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 12px #667eea66}.accept-button:disabled{background:var(--bg-secondary, #ddd);color:var(--text-muted, #999);cursor:not-allowed;box-shadow:none}.load-summary-content::-webkit-scrollbar,.file-list::-webkit-scrollbar{width:8px}.load-summary-content::-webkit-scrollbar-track,.file-list::-webkit-scrollbar-track{background:var(--bg-secondary, #f5f5f5);border-radius:4px}.load-summary-content::-webkit-scrollbar-thumb,.file-list::-webkit-scrollbar-thumb{background:var(--border-color, #ddd);border-radius:4px}.load-summary-content::-webkit-scrollbar-thumb:hover,.file-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.import-url-overlay{position:fixed;inset:0;background-color:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .2s ease-in;padding:16px}.import-url-modal{background:var(--modal-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;border:1px solid var(--border-color-light)}.import-url-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.import-url-header h2{margin:0;font-size:24px;font-weight:var(--font-bold);color:var(--text-primary)}.import-url-body{overflow-y:auto;padding:28px}.import-url-section{margin-bottom:28px}.import-url-section:last-child{margin-bottom:0}.url-input,.name-input{width:100%;padding:12px 14px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease;font-family:inherit}.url-input{font-family:var(--font-mono)}.url-input:focus,.name-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.url-input:disabled,.name-input:disabled{background-color:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed;opacity:.6}.info-box{padding:18px 20px;background:linear-gradient(135deg,#06b6d41a,#0ea5e91a);border:2px solid rgba(6,182,212,.3);border-radius:var(--radius-lg);font-size:14px;color:var(--text-primary);line-height:1.6}.info-box strong{display:block;margin-bottom:10px;color:var(--info-color);font-weight:var(--font-semibold);font-size:15px}.info-box ul{margin:0;padding-left:20px}.info-box li{margin:4px 0}.import-url-footer{display:flex;justify-content:flex-end;gap:16px;padding:20px 28px;border-top:1px solid var(--border-color);background:linear-gradient(135deg,#667eea05,#764ba205)}.cancel-btn,.import-btn{padding:12px 28px;border-radius:var(--radius-md);font-size:15px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;min-width:100px}.cancel-btn{background-color:var(--bg-primary);color:var(--text-primary);border:2px solid var(--border-color)}.cancel-btn:hover:not(:disabled){background-color:var(--hover-bg);border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.import-btn{background:var(--gradient-1);color:#fff;border:none;box-shadow:var(--shadow-sm)}.import-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.import-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}@media(max-width:768px){.import-url-overlay{padding:8px}.import-url-modal{width:100%;max-width:100%;max-height:95vh}.import-url-header{padding:20px}.import-url-header h2{font-size:20px}.import-url-body{padding:20px}.import-url-footer{padding:16px 20px;gap:12px}.cancel-btn,.import-btn{padding:14px 20px;min-width:90px;min-height:48px}.label-text{font-size:14px}.url-input,.name-input{padding:14px 12px;font-size:16px;min-height:48px}.info-box{padding:16px;font-size:13px}.info-box strong{font-size:14px}}@media(max-width:480px){.import-url-header{padding:16px}.import-url-header h2{font-size:18px}.import-url-body{padding:16px}.import-url-section{margin-bottom:20px}.import-url-footer{flex-direction:column-reverse;padding:12px 16px}.cancel-btn,.import-btn{width:100%;min-height:48px}}.share-overlay{position:fixed;inset:0;background-color:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .2s ease-in;padding:16px}.share-modal{background:var(--modal-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;border:1px solid var(--border-color-light)}.share-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#22c55e1a,#10b9811a);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.share-header h2{margin:0;font-size:24px;font-weight:var(--font-bold);color:var(--text-primary)}.close-btn{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s ease}.close-btn:hover{background-color:var(--hover-bg);color:var(--text-primary);transform:rotate(90deg)}.share-body{overflow-y:auto;padding:28px}.share-section{margin-bottom:28px}.share-section:last-child{margin-bottom:0}.document-info{background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:18px 20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.info-row:not(:last-child){border-bottom:1px solid var(--border-color)}.info-label{font-weight:var(--font-semibold);color:var(--text-secondary);font-size:14px}.info-value{font-weight:var(--font-medium);color:var(--text-primary);font-size:14px;font-family:var(--font-mono)}.security-info-box{padding:18px 20px;background:linear-gradient(135deg,#eab3081a,#fbbf241a);border:2px solid rgba(234,179,8,.3);border-radius:var(--radius-lg);font-size:14px;color:var(--text-primary);line-height:1.6;margin-bottom:28px}.security-info-box strong{display:block;margin-bottom:10px;color:#eab308;font-weight:var(--font-semibold);font-size:15px}.security-info-box ul{margin:0;padding-left:20px}.security-info-box li{margin:6px 0}.security-info-box li strong{display:inline;margin:0;color:var(--text-primary);font-size:14px}.generate-btn{width:100%;padding:14px 28px;border-radius:var(--radius-md);font-size:16px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#22c55e,#10b981);color:#fff;border:none;box-shadow:var(--shadow-md)}.generate-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 20px #22c55e66}.generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.label-text{display:block;font-weight:var(--font-semibold);margin-bottom:12px;color:var(--text-primary);font-size:15px}.share-url-container{display:flex;gap:12px;align-items:stretch}.share-url-input{flex:1;padding:12px 14px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);cursor:text;transition:all .3s ease}.share-url-input:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 3px #22c55e1a}.copy-btn{padding:12px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#22c55e,#10b981);color:#fff;border:none;box-shadow:var(--shadow-sm);white-space:nowrap;min-width:110px}.copy-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #22c55e4d}.copy-btn:active{transform:translateY(0)}.help-text{margin:8px 0 0;font-size:13px;color:var(--text-secondary);line-height:1.5}.warning-message{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border:2px solid rgba(251,191,36,.3);border-radius:var(--radius-md);color:#f59e0b;font-size:14px;font-weight:var(--font-medium);margin-bottom:20px;animation:fadeIn .2s ease-in}.warning-icon{font-size:18px;flex-shrink:0}.error-message{display:flex;align-items:center;gap:10px;padding:14px 16px;background:linear-gradient(135deg,#ef44441a,#dc26261a);border:2px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error-color);font-size:14px;font-weight:var(--font-medium);margin-bottom:20px;animation:fadeIn .2s ease-in}.error-icon{font-size:18px;flex-shrink:0}.usage-box{padding:18px 20px;background:linear-gradient(135deg,#22c55e1a,#10b9811a);border:2px solid rgba(34,197,94,.3);border-radius:var(--radius-lg);font-size:14px;color:var(--text-primary);line-height:1.6}.usage-box strong{display:block;margin-bottom:10px;color:#22c55e;font-weight:var(--font-semibold);font-size:15px}.usage-box ol{margin:0;padding-left:24px}.usage-box li{margin:8px 0}.share-footer{display:flex;justify-content:center;padding:20px 28px;border-top:1px solid var(--border-color);background:linear-gradient(135deg,#22c55e05,#10b98105)}.close-footer-btn{padding:12px 40px;border-radius:var(--radius-md);font-size:15px;font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;background-color:var(--bg-primary);color:var(--text-primary);border:2px solid var(--border-color);min-width:120px}.close-footer-btn:hover{background-color:var(--hover-bg);border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.share-overlay{padding:8px}.share-modal{width:100%;max-width:100%;max-height:95vh}.share-header{padding:20px}.share-header h2{font-size:20px}.share-body{padding:20px}.share-footer{padding:16px 20px}.share-url-container{flex-direction:column}.copy-btn{width:100%;min-height:48px}.generate-btn,.close-footer-btn{min-height:48px}}@media(max-width:480px){.share-header{padding:16px}.share-header h2{font-size:18px}.share-body{padding:16px}.share-section{margin-bottom:20px}.security-info-box,.usage-box{padding:16px;font-size:13px}.security-info-box strong,.usage-box strong{font-size:14px}}.upgrade-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.upgrade-modal-content{background:var(--bg-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:1100px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;border:2px solid var(--border-color)}.upgrade-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px;border-bottom:2px solid var(--border-color);background:var(--sidebar-bg)}.upgrade-modal-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.upgrade-modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.upgrade-modal-close:hover{background:var(--hover-bg);color:var(--text-primary)}.upgrade-modal-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;padding:32px}.upgrade-tier{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;transition:all .2s ease}.upgrade-tier:hover{border-color:var(--accent-color);transform:translateY(-4px);box-shadow:0 12px 32px #00000026}.upgrade-tier-active{border-color:var(--accent-color);background:var(--bg-primary)}.upgrade-tier-badge{position:absolute;top:12px;right:12px;background:var(--accent-color);color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;padding:4px 12px;border-radius:12px;letter-spacing:.5px}.upgrade-tier-badge-popular{background:linear-gradient(135deg,#667eea,#764ba2)}.upgrade-tier-badge-pro{background:linear-gradient(135deg,#f093fb,#f5576c)}.upgrade-tier-icon{font-size:48px;margin-bottom:16px}.upgrade-tier-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.upgrade-tier-price{font-size:32px;font-weight:800;color:var(--text-primary);margin-bottom:8px}.upgrade-tier-period{font-size:16px;font-weight:500;color:var(--text-secondary)}.upgrade-tier-description{font-size:14px;color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.upgrade-tier-features{list-style:none;padding:0;margin:0 0 24px;width:100%}.upgrade-tier-features li{padding:8px 0;font-size:14px;color:var(--text-primary);text-align:left;border-bottom:1px solid var(--border-color)}.upgrade-tier-features li:last-child{border-bottom:none}.upgrade-tier-button{width:100%;padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;background:var(--accent-color);color:#fff;margin-top:auto}.upgrade-tier-button:hover:not(:disabled){background:var(--accent-color-hover);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.upgrade-tier-button:active:not(:disabled){transform:translateY(0)}.upgrade-tier-button:disabled{opacity:.5;cursor:not-allowed}.upgrade-tier-button-active{background:var(--border-color);color:var(--text-secondary)}.upgrade-modal-footer{padding:24px 32px;border-top:2px solid var(--border-color);background:var(--sidebar-bg)}.upgrade-modal-note{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.6;text-align:center}.upgrade-modal-note strong{color:var(--text-primary)}@media(max-width:768px){.upgrade-modal-content{max-height:95vh;margin:10px}.upgrade-modal-header{padding:20px}.upgrade-modal-title{font-size:20px}.upgrade-modal-body{grid-template-columns:1fr;padding:20px;gap:20px}.upgrade-tier{padding:24px 20px}.upgrade-modal-footer{padding:20px}}.upgrade-modal-content::-webkit-scrollbar{width:8px}.upgrade-modal-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.upgrade-modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.upgrade-modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.template-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.template-modal{background:var(--bg-primary, #1a1a1a);border-radius:12px;box-shadow:0 20px 60px #00000080;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}.template-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color, #333);background:var(--bg-secondary, #222)}.template-modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary, #fff);display:flex;align-items:center;gap:.5rem}.template-close-btn{background:transparent;border:none;color:var(--text-secondary, #999);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;line-height:1}.template-close-btn:hover{background:var(--bg-hover, #333);color:var(--text-primary, #fff)}.template-modal-controls{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #333);background:var(--bg-primary, #1a1a1a)}.template-search{margin-bottom:1rem}.template-search-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-primary, #fff);font-size:.95rem;transition:all .2s}.template-search-input:focus{outline:none;border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 3px #4a9eff1a}.template-search-input::placeholder{color:var(--text-secondary, #999)}.template-categories{display:flex;gap:.5rem;flex-wrap:wrap}.template-category-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:20px;color:var(--text-secondary, #999);font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.template-category-btn:hover{background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff)}.template-category-btn.active{background:var(--accent-color, #4a9eff);border-color:var(--accent-color, #4a9eff);color:#fff}.category-icon{font-size:1.1rem;line-height:1}.category-label{font-weight:500}.template-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.template-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.template-card{background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;padding:1.25rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.75rem}.template-card:hover{border-color:var(--accent-color, #4a9eff);transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.template-card-icon{font-size:2.5rem;line-height:1}.template-card-title{margin:0;font-size:1.1rem;color:var(--text-primary, #fff);font-weight:600}.template-card-description{margin:0;font-size:.9rem;color:var(--text-secondary, #999);line-height:1.4;flex:1}.template-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.25rem}.template-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.template-badge-beginner{background:#4caf5033;color:#4caf50}.template-badge-real-world{background:#4a9eff33;color:#4a9eff}.template-badge-complex{background:#9c27b033;color:#9c27b0}.template-badge-testing{background:#ff980033;color:#ff9800}.template-preview-btn{background:transparent;border:1px solid var(--border-color, #333);color:var(--text-secondary, #999);padding:.25rem .75rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.template-preview-btn:hover{background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff);color:var(--text-primary, #fff)}.template-empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #999)}.template-empty-state p{font-size:1rem;margin:0}.template-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color, #333);background:var(--bg-secondary, #222)}.template-count{margin:0;font-size:.85rem;color:var(--text-secondary, #999);text-align:center}.template-preview-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem;animation:fadeIn .2s ease-out}.template-preview-modal{background:var(--bg-primary, #1a1a1a);border-radius:12px;box-shadow:0 20px 60px #0009;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}.template-preview-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color, #333);background:var(--bg-secondary, #222);gap:1rem}.template-preview-header h3{margin:0 0 .5rem;font-size:1.3rem;color:var(--text-primary, #fff);display:flex;align-items:center;gap:.5rem}.preview-icon{font-size:1.5rem}.preview-description{margin:0;font-size:.9rem;color:var(--text-secondary, #999)}.template-preview-content{flex:1;overflow-y:auto;padding:1.5rem;background:var(--bg-primary, #1a1a1a)}.template-preview-code{margin:0;padding:1rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;overflow-x:auto;font-family:Fira Code,Consolas,Monaco,monospace;font-size:.9rem;line-height:1.6;color:var(--text-primary, #fff)}.template-preview-code code{color:inherit}.template-preview-footer{display:flex;align-items:center;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color, #333);background:var(--bg-secondary, #222)}.template-btn-secondary,.template-btn-primary{padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.template-btn-secondary{background:transparent;color:var(--text-secondary, #999);border:1px solid var(--border-color, #333)}.template-btn-secondary:hover{background:var(--bg-hover, #333);color:var(--text-primary, #fff)}.template-btn-primary{background:var(--accent-color, #4a9eff);color:#fff;border:1px solid var(--accent-color, #4a9eff)}.template-btn-primary:hover{background:#3d8ce6;border-color:#3d8ce6;transform:translateY(-1px);box-shadow:0 4px 12px #4a9eff4d}@media(max-width:639px){.template-modal-overlay{padding:0;align-items:flex-end}.template-modal{max-height:95vh;border-radius:12px 12px 0 0;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.template-modal-header h2{font-size:1.25rem}.template-modal-controls{padding:1rem}.template-categories{gap:.4rem}.template-category-btn{flex:1;justify-content:center;min-width:0}.category-label{display:none}.category-icon{font-size:1.3rem}.template-category-btn.active .category-label{display:inline}.template-modal-content{padding:1rem}.template-grid{grid-template-columns:1fr;gap:.75rem}.template-card{padding:1rem}.template-card-icon{font-size:2rem}.template-card-title{font-size:1rem}.template-card-description{font-size:.85rem}.template-preview-overlay{padding:0;align-items:flex-end}.template-preview-modal{max-height:95vh;border-radius:12px 12px 0 0}.template-preview-header{padding:1rem}.template-preview-header h3{font-size:1.1rem}.template-preview-content{padding:1rem}.template-preview-code{font-size:.8rem;padding:.75rem}.template-preview-footer{padding:1rem;flex-direction:column-reverse}.template-btn-secondary,.template-btn-primary{width:100%;padding:.875rem}}@media(min-width:640px)and (max-width:1023px){.template-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.template-categories{justify-content:center}.category-label{display:inline}}@media(min-width:1024px){.template-grid{grid-template-columns:repeat(3,1fr)}.template-modal{max-width:1200px}.category-label{display:inline}}@media(min-width:1400px){.template-grid{grid-template-columns:repeat(4,1fr)}.template-modal{max-width:1400px}}:root{--bg-primary: #1a1a1a;--bg-secondary: #222;--bg-hover: #333;--border-color: #333;--text-primary: #fff;--text-secondary: #999;--accent-color: #4a9eff}.light-theme{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-hover: #e0e0e0;--border-color: #ddd;--text-primary: #1a1a1a;--text-secondary: #666;--accent-color: #2196f3}.template-modal-content::-webkit-scrollbar,.template-preview-content::-webkit-scrollbar{width:8px}.template-modal-content::-webkit-scrollbar-track,.template-preview-content::-webkit-scrollbar-track{background:var(--bg-secondary, #222)}.template-modal-content::-webkit-scrollbar-thumb,.template-preview-content::-webkit-scrollbar-thumb{background:var(--border-color, #333);border-radius:4px}.template-modal-content::-webkit-scrollbar-thumb:hover,.template-preview-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.project-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.project-modal{background:var(--bg-primary, #1a1a1a);border-radius:12px;box-shadow:0 20px 60px #00000080;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.project-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color, #333);background:var(--bg-secondary, #222)}.project-modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary, #fff);display:flex;align-items:center;gap:.5rem}.project-close-btn{background:transparent;border:none;color:var(--text-secondary, #999);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;line-height:1}.project-close-btn:hover{background:var(--bg-hover, #333);color:var(--text-primary, #fff)}.project-modal-controls{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #333);background:var(--bg-primary, #1a1a1a)}.project-search{margin-bottom:1rem}.project-search-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-primary, #fff);font-size:.95rem;transition:all .2s}.project-search-input:focus{outline:none;border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 3px #4a9eff1a}.project-search-input::placeholder{color:var(--text-secondary, #999)}.project-filters{display:flex;gap:.5rem;flex-wrap:wrap}.project-filter-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:20px;color:var(--text-secondary, #999);font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.project-filter-btn:hover{background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff)}.project-filter-btn.active{background:var(--accent-color, #4a9eff);border-color:var(--accent-color, #4a9eff);color:#fff}.project-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.project-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.project-card{background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;padding:1.25rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.75rem;position:relative}.project-card:hover{border-color:var(--accent-color, #4a9eff);transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.project-card-icon{font-size:2.5rem;line-height:1}.project-card-title{margin:0;font-size:1.1rem;color:var(--text-primary, #fff);font-weight:600}.project-card-description{margin:0;font-size:.9rem;color:var(--text-secondary, #999);line-height:1.4;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.25rem;font-size:.85rem;color:var(--text-secondary, #999)}.project-doc-count{display:flex;align-items:center;gap:.25rem}.project-updated{color:var(--text-secondary, #999)}.project-favorite-badge{position:absolute;top:.75rem;right:.75rem;font-size:1.2rem;line-height:1;background:transparent;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;z-index:2}.project-favorite-badge:hover{background:#ffffff1a;transform:scale(1.15)}.project-edit-badge{position:absolute;top:.75rem;right:2.5rem;font-size:1rem;line-height:1;background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease;z-index:2;opacity:.7}.project-edit-badge:hover{background:#667eea33;opacity:1;transform:scale(1.1)}.project-empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #999)}.project-empty-state p{font-size:1rem;margin:.5rem 0}.empty-hint{font-size:.9rem;color:var(--text-secondary, #999)}.project-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color, #333);background:var(--bg-secondary, #222);display:flex;align-items:center;justify-content:space-between}.project-count{margin:0;font-size:.85rem;color:var(--text-secondary, #999)}.project-create-btn{padding:.75rem 1.5rem;background:var(--accent-color, #4a9eff);border:1px solid var(--accent-color, #4a9eff);border-radius:8px;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.project-create-btn:hover{background:#3d8ce6;border-color:#3d8ce6;transform:translateY(-1px);box-shadow:0 4px 12px #4a9eff4d}.project-create-form{padding:1.5rem;overflow-y:auto;flex:1}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary, #fff);font-size:.9rem;font-weight:500}.form-input,.form-textarea{width:100%;padding:.75rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-primary, #fff);font-size:.95rem;font-family:inherit;transition:all .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 3px #4a9eff1a}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-secondary, #999)}.form-textarea{resize:vertical;min-height:80px}.icon-picker{display:flex;flex-direction:column;gap:.75rem}.icon-preview{font-size:3rem;text-align:center;padding:1rem;background:var(--bg-secondary, #222);border:2px dashed var(--border-color, #333);border-radius:8px;line-height:1}.icon-suggestions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.icon-suggestion{font-size:2rem;padding:.5rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;cursor:pointer;transition:all .2s;line-height:1}.icon-suggestion:hover{background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff);transform:scale(1.1)}.icon-suggestion.selected{background:var(--accent-color, #4a9eff);border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 3px #4a9eff33}.icon-input{width:100%;padding:.75rem;background:var(--bg-secondary, #222);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-primary, #fff);font-size:1.5rem;text-align:center;transition:all .2s}.icon-input:focus{outline:none;border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 3px #4a9eff1a}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-color, #333)}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:transparent;color:var(--text-secondary, #999);border:1px solid var(--border-color, #333)}.btn-secondary:hover{background:var(--bg-hover, #333);color:var(--text-primary, #fff)}.btn-primary{background:var(--accent-color, #4a9eff);color:#fff;border:1px solid var(--accent-color, #4a9eff)}.btn-primary:hover:not(:disabled){background:#3d8ce6;border-color:#3d8ce6;transform:translateY(-1px);box-shadow:0 4px 12px #4a9eff4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.project-name-with-icon{display:flex;align-items:center;gap:12px}.selected-icon-preview{width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:28px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);transition:all .3s ease}.project-name-with-icon .form-input{flex:1}.section-label{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;display:block}.form-hint{font-size:.875rem;color:var(--text-secondary);margin:.5rem 0 1rem}.color-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:12px;margin-top:1rem}.color-swatch{width:60px;height:60px;border-radius:12px;border:3px solid transparent;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 2px 8px #0003}.color-swatch:hover{transform:scale(1.1);box-shadow:0 4px 16px #0000004d}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 3px #fff3,0 4px 16px #0000004d;transform:scale(1.05)}.color-checkmark{color:#fff;font-weight:700;font-size:20px;text-shadow:0 0 4px rgba(0,0,0,.5)}.no-color-icon{color:var(--text-secondary);font-size:24px}.icon-search-input{width:100%;padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;margin:1rem 0;transition:all .2s ease}.icon-search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.icon-search-input::placeholder{color:var(--text-secondary)}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:12px;max-height:400px;overflow-y:auto;padding:4px;margin-top:1rem}.icon-option{width:70px;height:70px;display:flex;align-items:center;justify-content:center;font-size:40px;background:var(--bg-secondary);border:3px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease;padding:0}.icon-option:hover{background:var(--bg-hover);border-color:var(--primary-color);transform:scale(1.15);box-shadow:0 4px 16px #667eea4d;z-index:1}.icon-option.selected{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea33,0 4px 16px #667eea66;transform:scale(1.1)}.icon-search-empty{grid-column:1 / -1;text-align:center;padding:2rem;color:var(--text-secondary)}.icon-search-empty p{margin:.5rem 0}.empty-hint{font-size:.875rem;opacity:.7}@media(max-width:639px){.project-modal-overlay{padding:0;align-items:flex-end}.project-modal{max-height:95vh;border-radius:12px 12px 0 0;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.project-modal-header h2{font-size:1.25rem}.project-modal-controls{padding:1rem}.project-filters{gap:.4rem}.project-filter-btn{flex:1;justify-content:center;min-width:0;padding:.5rem .75rem;font-size:.85rem}.project-modal-content{padding:1rem}.project-grid{grid-template-columns:1fr;gap:.75rem}.project-card{padding:1rem}.project-card-icon{font-size:2rem}.project-card-title{font-size:1rem}.project-card-description{font-size:.85rem}.project-modal-footer{flex-direction:column;gap:1rem;align-items:stretch}.project-create-btn{width:100%}.project-create-form{padding:1rem}.form-actions{flex-direction:column-reverse;gap:.75rem}.btn-secondary,.btn-primary{width:100%}.icon-suggestions{gap:.4rem}.icon-suggestion{font-size:1.5rem;padding:.4rem}}@media(min-width:640px)and (max-width:1023px){.project-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.project-filters{justify-content:center}}@media(min-width:1024px){.project-grid{grid-template-columns:repeat(3,1fr)}.project-modal{max-width:1200px}}@media(min-width:1400px){.project-grid{grid-template-columns:repeat(4,1fr)}.project-modal{max-width:1400px}}.project-modal-content::-webkit-scrollbar,.project-create-form::-webkit-scrollbar{width:8px}.project-modal-content::-webkit-scrollbar-track,.project-create-form::-webkit-scrollbar-track{background:var(--bg-secondary, #222)}.project-modal-content::-webkit-scrollbar-thumb,.project-create-form::-webkit-scrollbar-thumb{background:var(--border-color, #333);border-radius:4px}.project-modal-content::-webkit-scrollbar-thumb:hover,.project-create-form::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #999)}.whats-new-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.whats-new-modal{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-width:1100px;width:100%;max-height:90vh;display:flex;flex-direction:row;animation:slideUp .4s cubic-bezier(.68,-.55,.265,1.55);overflow:hidden}.version-sidebar{width:220px;background:var(--bg-secondary);border-right:2px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.version-sidebar-header{padding:20px;font-size:14px;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.version-list{flex:1;overflow-y:auto;padding:8px}.version-item{width:100%;padding:12px 16px;margin-bottom:4px;background:transparent;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all .2s ease;display:flex;flex-direction:column;gap:4px}.version-item:hover{background:var(--bg-primary);border-color:var(--border-color)}.version-item.active{background:var(--primary-color);border-color:var(--primary-color)}.version-item.active .version-item-number,.version-item.active .version-item-name{color:#fff}.version-item-number{font-size:14px;font-weight:var(--font-bold);font-family:var(--font-mono);color:var(--text-primary)}.version-item-name{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-item-date{font-size:10px;color:var(--text-muted);margin-top:2px}.version-item.active .version-item-date{color:#fffc}.whats-new-main{flex:1;display:flex;flex-direction:column;overflow:hidden}@keyframes slideUp{0%{transform:translateY(50px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.whats-new-header{background:var(--gradient-1);padding:40px 40px 30px;color:#fff;position:relative}.whats-new-header-content{max-width:700px}.version-badge{display:inline-flex;align-items:center;gap:8px;background:#fff3;padding:6px 14px;border-radius:20px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.version-label{font-size:12px;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:1px;opacity:.9}.version-number{font-size:14px;font-weight:var(--font-bold);font-family:var(--font-mono)}.release-name{font-size:36px;font-weight:var(--font-bold);margin:0 0 8px;line-height:1.2}.release-date{font-size:14px;margin:0;opacity:.9}.whats-new-close-btn{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.whats-new-close-btn:hover{background:#ffffff4d;transform:scale(1.1) rotate(90deg);border-color:#ffffff80}.whats-new-content{flex:1;overflow-y:auto;padding:40px}.features-intro{text-align:center;margin-bottom:40px}.features-intro-text{font-size:18px;color:var(--text-secondary);margin:0;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.feature-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:24px;transition:all .3s ease;animation:fadeInUp .5s ease both}.feature-card:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 24px #667eea26}.feature-icon{font-size:32px;margin-bottom:12px}.feature-title{font-size:20px;font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 16px}.feature-list{list-style:none;padding:0;margin:0}.feature-item{position:relative;padding-left:24px;margin-bottom:12px;font-size:14px;line-height:1.6;color:var(--text-secondary)}.feature-item:before{content:"→";position:absolute;left:0;color:var(--primary-color);font-weight:var(--font-bold)}.feature-item:last-child{margin-bottom:0}.whats-new-footer{padding:24px 40px;background:var(--bg-secondary);border-top:2px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:20px}.whats-new-cta-btn{padding:14px 32px;background:var(--gradient-1);color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:var(--font-semibold);cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 4px 12px #667eea4d}.whats-new-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.whats-new-cta-btn:active{transform:translateY(0)}.cta-arrow{font-size:18px;transition:transform .3s ease}.whats-new-cta-btn:hover .cta-arrow{transform:translate(4px)}.whats-new-hint{font-size:13px;color:var(--text-muted);margin:0}@media(max-width:768px){.whats-new-modal{max-height:95vh;margin:10px;flex-direction:column}.version-sidebar{width:100%;border-right:none;border-bottom:2px solid var(--border-color);max-height:150px}.version-sidebar-header{padding:16px 20px}.version-list{padding:8px;display:flex;flex-direction:row;gap:8px;overflow-x:auto}.version-item{flex-shrink:0;min-width:140px}.whats-new-header{padding:30px 24px 24px}.release-name{font-size:28px}.whats-new-content{padding:24px}.features-grid{grid-template-columns:1fr;gap:20px}.feature-card{padding:20px}.whats-new-footer{padding:20px 24px;flex-direction:column;text-align:center}.whats-new-cta-btn{width:100%;justify-content:center}}@media(max-width:480px){.whats-new-header{padding:24px 20px 20px}.release-name{font-size:24px}.whats-new-content{padding:20px}.feature-card{padding:16px}.feature-title{font-size:18px}.whats-new-close-btn{width:36px;height:36px;font-size:20px;top:16px;right:16px}}.app{display:flex;height:100vh;width:100vw;max-width:100vw;background:var(--bg-primary);position:relative;overflow:hidden}.main-content{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:0;max-width:100%}.tabs{display:flex;align-items:center;gap:4px;padding:0;background:var(--bg-tertiary);flex-shrink:0}.tab{padding:14px 28px;border:none;background:var(--bg-secondary);cursor:pointer;font-size:15px;font-weight:var(--font-semibold);color:var(--text-secondary);transition:all .3s ease;border-top:3px solid transparent;border-bottom:3px solid transparent;position:relative}.tab:hover{background:var(--hover-bg);color:var(--text-primary)}.tab.active{background:var(--bg-primary);color:var(--primary-color);border-bottom:3px solid var(--primary-color);box-shadow:0 -2px 8px #6366f11a}.tab-indicators{display:flex;align-items:center;gap:10px;margin-left:auto;padding:0 16px;background:var(--bg-secondary)}.unsaved-indicator{color:var(--warning-color);font-size:22px;animation:pulse 2s infinite;filter:drop-shadow(0 0 4px rgba(245,158,11,.5))}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.icon-btn{width:36px;height:36px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-size:18px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .3s ease;padding:0}.icon-btn:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.icon-btn:active:not(:disabled){transform:translateY(0)}.icon-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(1)}.tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.drag-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#667eeaf2,#764ba2f2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:fadeIn .2s ease-in}.drag-overlay-close{position:absolute;top:24px;right:24px;width:48px;height:48px;background:#fff3;border:2px solid rgba(255,255,255,.4);border-radius:50%;color:#fff;font-size:32px;font-weight:300;line-height:1;cursor:pointer;pointer-events:all;transition:all .2s;display:flex;align-items:center;justify-content:center}.drag-overlay-close:hover{background:#ffffff4d;border-color:#fff9;transform:scale(1.1)}.drag-message{text-align:center;color:#fff;font-size:28px;font-weight:var(--font-bold);display:flex;flex-direction:column;align-items:center;gap:20px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.drag-icons{display:flex;gap:24px;align-items:center}.drag-icon{font-size:72px;animation:bounce .6s ease-in-out infinite alternate;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.drag-icon:nth-child(2){animation-delay:.15s}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-15px)}}.drag-message p{margin:0;font-size:20px;font-weight:var(--font-semibold)}.drag-hint{font-size:14px!important;font-weight:var(--font-regular)!important;opacity:.8;margin-top:-8px!important}.mobile-hamburger-btn,.sidebar-backdrop{display:none}.fab-add-document{position:absolute;bottom:30px;right:30px;width:56px;height:56px;border-radius:50%;background:var(--primary-color);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #6366f166;transition:all .3s ease;z-index:100}.fab-add-document:hover{background:var(--primary-hover);transform:scale(1.1) rotate(90deg);box-shadow:0 6px 20px #6366f199}.fab-add-document:active{transform:scale(.95) rotate(90deg)}.fab-icon{font-size:28px;font-weight:300;line-height:1}@media(min-width:769px){.view-mode-section{display:none!important}}@media(min-width:481px)and (max-width:768px){.mobile-hamburger-btn{display:flex;align-items:center;justify-content:center;padding:0;width:48px;height:48px;border:none;background:var(--bg-secondary);color:var(--text-primary);font-size:24px;cursor:pointer;transition:all .3s ease;flex-shrink:0;border-right:2px solid var(--border-color)}.mobile-hamburger-btn:hover{background:var(--primary-color);color:#fff}.mobile-hamburger-btn:active{transform:scale(.95)}.tab{display:flex!important;padding:12px 16px;font-size:14px;flex-shrink:0;min-width:fit-content;min-height:48px}.mobile-view-title{display:none}.view-mode-section{display:none!important}.tabs{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:0}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}@media(max-width:480px){.mobile-hamburger-btn{display:flex;align-items:center;justify-content:center;padding:0;width:48px;height:48px;border:none;background:var(--bg-secondary);color:var(--text-primary);font-size:24px;cursor:pointer;transition:all .3s ease;flex-shrink:0;border-right:2px solid var(--border-color)}.mobile-hamburger-btn:hover{background:var(--primary-color);color:#fff}.mobile-hamburger-btn:active{transform:scale(.95)}.mobile-view-title{display:flex;align-items:center;padding:0 16px;font-size:18px;font-weight:600;color:var(--text-primary);flex:1;min-width:0}.tab{display:none!important}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}@media(max-width:768px){.tabs{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:0}.tab-indicators{flex-shrink:0;padding:0 12px}.icon-btn{width:44px;height:44px;font-size:20px}.drag-message{font-size:22px;padding:20px}.drag-icon{font-size:56px}.drag-message p{font-size:18px}.drag-overlay-close{top:16px;right:16px;width:44px;height:44px;font-size:28px}}@media(max-width:480px){.tab{padding:12px 16px;font-size:13px}.tab-indicators{padding:0 8px}.unsaved-indicator{font-size:18px}.icon-btn{width:40px;height:40px;font-size:18px}.drag-message{font-size:18px}.drag-icon{font-size:48px}.drag-message p{font-size:16px}}.login-page{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);overflow:auto;padding:1rem}.login-container{width:100%;max-width:500px;padding:2rem;margin-top:auto;margin-bottom:auto}.login-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:3rem 2.5rem;box-shadow:0 8px 32px #0000001a;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:2rem}.login-logo img{height:64px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}.login-title{font-size:2rem;font-weight:700;text-align:center;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.02em}.login-subtitle{font-size:1rem;text-align:center;color:var(--text-secondary);margin:0 0 2rem;line-height:1.5}.login-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;padding:1.5rem;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color)}.feature{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.9rem}.feature-icon{font-size:1.25rem;flex-shrink:0}.feature-text{line-height:1.4}.login-error{display:flex;align-items:center;gap:.5rem;padding:1rem;margin-bottom:1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.9rem}.error-icon{flex-shrink:0}.error-text{flex:1}.login-button{width:100%;padding:1rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 4px 16px #667eea4d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.button-icon{font-size:1.25rem}.button-loading{display:flex;align-items:center;gap:.75rem}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{text-align:center;margin-top:1.5rem;font-size:.85rem;color:var(--text-tertiary);line-height:1.4}@media(max-width:768px){.login-page{align-items:flex-start;justify-content:flex-start;padding:.5rem .5rem 1rem;min-height:100vh;height:auto}.login-container{padding:0;margin-top:0;margin-bottom:0}.login-content{padding:1.25rem 1rem;border-radius:12px}.login-logo{margin-bottom:.75rem}.login-logo img{height:36px}.login-title{font-size:1.4rem;margin-bottom:.25rem}.login-subtitle{font-size:.85rem;margin-bottom:1rem}.login-features{padding:.75rem;gap:.5rem;margin-bottom:1rem}.feature{font-size:.8rem;gap:.5rem}.feature-icon{font-size:1rem}.login-button{padding:.875rem 1.5rem;font-size:.95rem}.login-footer{margin-top:1rem;font-size:.75rem;line-height:1.3}}@media(max-width:400px){.login-page{padding:.25rem}.login-content{padding:1rem .875rem}.login-logo img{height:32px}.login-title{font-size:1.3rem}.login-subtitle{font-size:.8rem}.login-features{padding:.625rem}.feature{font-size:.75rem}}@media(prefers-color-scheme:dark){.login-content{box-shadow:0 8px 32px #0000004d}}.auth-loading-container,.auth-error-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.auth-loading-content,.auth-error-content{text-align:center;padding:2rem}.auth-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--accent-color, #667eea);border-radius:50%;margin:0 auto 1.5rem;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-loading-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.auth-loading-subtitle{font-size:1rem;color:var(--text-secondary);margin:0}.auth-error-icon{font-size:4rem;margin-bottom:1rem}.auth-error-title{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.auth-error-message{font-size:1rem;color:var(--text-secondary);margin:0 0 2rem;max-width:500px}.auth-error-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #667eea4d}.auth-error-button:hover{transform:translateY(-2px);box-shadow:0 6px 24px #667eea66}.auth-error-button:active{transform:translateY(0)}.auth-loading-container,.auth-error-container{animation:fadeIn .3s ease-out}:root,[data-theme=light]{--primary-color: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary-color: #ec4899;--bg-primary: #ffffff;--bg-secondary: #fafbfc;--bg-tertiary: #f5f6f7;--card-bg: #ffffff;--sidebar-bg: #ffffff;--toolbar-bg: #fafbfc;--modal-bg: #ffffff;--hover-bg: #f5f6f7;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-inverse: #ffffff;--border-color: #dee2e6;--border-color-light: #e5e7eb;--border-color-hover: #6366f1;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #dc3545;--info-color: #06b6d4;--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-3: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .2);--shadow-primary: 0 10px 30px rgba(102, 126, 234, .3);--shadow-primary-hover: 0 15px 35px rgba(102, 126, 234, .4);--json-bg: #ffffff;--json-text: #1f2937;--json-string: #059669;--json-number: #2563eb;--json-boolean: #2563eb;--json-null: #6b7280;--json-key: #d97706;--overlay-bg: rgba(0, 0, 0, .5)}[data-theme=dark]{--primary-color: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary-color: #ec4899;--bg-primary: #0f172a;--bg-secondary: #020617;--bg-tertiary: #1e293b;--card-bg: #1e293b;--sidebar-bg: #1e293b;--toolbar-bg: #1e293b;--modal-bg: #1e293b;--hover-bg: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--text-inverse: #0f172a;--border-color: rgba(148, 163, 184, .2);--border-color-light: rgba(148, 163, 184, .1);--border-color-hover: #6366f1;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--info-color: #06b6d4;--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-3: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .5);--shadow-primary: 0 10px 30px rgba(102, 126, 234, .4);--shadow-primary-hover: 0 15px 35px rgba(102, 126, 234, .4);--json-bg: #020617;--json-text: #a5d6ff;--json-string: #7ee787;--json-number: #79c0ff;--json-boolean: #79c0ff;--json-null: #94a3b8;--json-key: #ffa657;--overlay-bg: rgba(0, 0, 0, .7)}*:not(.json-textarea):not(.json-textarea *):not(.json-textarea-input):not(.json-textarea-input *):not(pre):not(code):not(span[class*=token]){transition:background-color .3s ease,color .3s ease,border-color .3s ease}*:not(.no-transition):not(.json-textarea):not(.json-textarea *):not(.json-textarea-input):not(.json-textarea-input *):not(pre):not(code):not(span[class*=token]){transition-property:background-color,color,border-color,box-shadow;transition-duration:.3s;transition-timing-function:ease}button,a,.tab,.nav-btn{transition:all .3s ease}:root{--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Monaco", "Menlo", "Ubuntu Mono", "Consolas", "source-code-pro", monospace;--font-light: 300;--font-regular: 400;--font-semibold: 600;--font-bold: 700;--font-black: 900;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 2.5rem;--space-8: 3rem;--space-9: 4rem;--space-10: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-default: .3s ease;--transition-slow: .6s ease}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-secondary);color:var(--text-primary);overflow:hidden;position:fixed;width:100%;height:100%}code{font-family:var(--font-mono)}#root{width:100%;height:100%;overflow:hidden}
