.property-updated{background-color:#e6fffa!important;border:2px solid #38b2ac!important;animation:propertyUpdate 2s ease-in-out}@keyframes propertyUpdate{0%{background-color:#fef5e7;border-color:#f6ad55}50%{background-color:#e6fffa;border-color:#38b2ac}to{background-color:#e6fffa;border-color:#38b2ac}}body{display:flex;gap:20px;align-items:flex-start;padding:20px}.container{flex:1;max-width:none;margin:0}.main-content{margin-bottom:20px}.xml-panel{width:100%}.status-info-panel{width:300px;flex-shrink:0;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;height:fit-content;max-height:600px;overflow:hidden;position:sticky;top:20px}.status-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 20px;border-radius:12px 12px 0 0}.status-header h3{margin:0;font-size:1.1rem;font-weight:600}.status-content{padding:16px 20px;border-bottom:1px solid #e5e7eb}.status-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.status-item:last-child{border-bottom:none}.status-label{font-size:.9rem;font-weight:500;color:#6b7280}.status-value{font-size:.85rem;font-weight:600;padding:4px 8px;border-radius:12px;text-align:center;min-width:100px}.status-value.relay-server{background:#eff6ff;color:#1d4ed8;font-size:.75rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px;text-align:left;display:block}.status-value.connected{background:#d1fae5;color:#065f46}.status-value.disconnected{background:#fee2e2;color:#991b1b}.status-value.connecting{background:#fef3c7;color:#92400e}.doc-name{font-size:.8rem;color:#374151;background:#f8fafc;padding:4px 8px;border-radius:4px;border:1px solid #e2e8f0;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.users-section{padding:16px 20px}.users-section h4{font-size:.95rem;font-weight:600;color:#374151;margin:0 0 12px;padding-bottom:6px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:8px}.user-count-badge{font-size:.8rem;font-weight:700;color:#3b82f6;background:#eff6ff;padding:4px 8px;border-radius:12px;border:1px solid #dbeafe;min-width:24px;text-align:center}.users-list{max-height:180px;overflow-y:auto}.user-item{display:flex;align-items:center;padding:8px 10px;margin-bottom:6px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0;border-left:3px solid #3b82f6;transition:all .2s ease}.user-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translate(2px)}.user-item:last-child{margin-bottom:0}.user-item.user-is-summarizer{border-left-color:#059669;background:#ecfdf5}.summarizer-badge{display:inline-block;margin-left:6px;padding:2px 6px;font-size:.65rem;font-weight:700;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,#059669,#10b981);border-radius:4px;vertical-align:middle}.summarizer-active{color:#059669;font-weight:600}.summarizer-pending{color:#94a3b8}.user-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.8rem;margin-right:8px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.user-info{flex:1;display:flex;flex-direction:column}.user-name{font-weight:600;color:#374151;font-size:.85rem}.user-status{font-size:.75rem;color:#10b981;margin-top:2px}.user-you{background:#eff6ff;border-left-color:#3b82f6}.user-you .user-name:after{content:" (You)";color:#3b82f6;font-size:.8rem;font-weight:500}.no-users{text-align:center;padding:20px 12px;color:#9ca3af;font-style:italic;font-size:.85rem;background:#f9fafb;border-radius:6px;border:1px dashed #d1d5db}.xml-viewer{max-height:1000px!important;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px;padding:15px;background:#fafafa}.xml-node{margin:5px 0;padding:8px;border-radius:4px;background:#fff;border:1px solid #e0e0e0;cursor:pointer;transition:all .2s ease}.xml-node:hover{background:#f8f9fa;border-color:#007bff;transform:translate(2px)}.xml-node.selected{background:#e3f2fd;border-color:#2196f3;box-shadow:0 2px 4px #2196f333}.node-tag{font-weight:600;color:#1976d2;font-family:Courier New,monospace;font-size:14px}.node-text{color:#333;font-style:italic;margin-left:20px;font-family:Courier New,monospace;background:#f0f0f0;padding:4px 8px;border-radius:3px;display:inline-block}.node-children{margin-left:20px;border-left:2px solid #e0e0e0;padding-left:15px;margin-top:8px}.property-editor{display:flex;gap:10px;margin-bottom:15px;align-items:center}.property-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s ease}.property-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.property-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.xml-actions{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.document-status{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.document-status.loaded{background:#d4edda;color:#155724}.document-status.not-loaded{background:#f8d7da;color:#721c24}.document-status.loading{background:#d1ecf1;color:#0c5460}.xml-panel{position:relative}.xml-panel .xml-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.xml-panel .xml-header h3{margin:0;flex:1;min-width:200px}#property-info{padding:10px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef;font-size:14px;min-height:40px;display:flex;align-items:center}.xml-actions .btn{position:relative;overflow:hidden}.xml-actions .btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.xml-actions .btn:hover:before{left:100%}.xml-viewer .loading{display:flex;align-items:center;justify-content:center;min-height:100px;color:#6c757d;font-style:italic}.xml-viewer .loading:after{content:"";width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-left:10px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.xml-viewer .error,.xml-viewer .success{margin:10px 0;padding:12px;border-radius:4px;font-size:14px;animation:slideIn .3s ease}.xml-viewer .error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.xml-viewer .success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){body{flex-direction:column;padding:10px}.status-info-panel{width:100%;order:-1;max-height:none;position:static}.xml-actions{flex-direction:column}.xml-actions .btn{width:100%}.property-editor,.xml-panel .xml-header{flex-direction:column;align-items:stretch}.node-children{margin-left:10px;padding-left:10px}.node-text{margin-left:10px}}@media (prefers-color-scheme: dark){.xml-viewer{background:#2d3748;border-color:#4a5568}.xml-node{background:#4a5568;border-color:#718096;color:#e2e8f0}.xml-node:hover{background:#2d3748;border-color:#63b3ed}.xml-node.selected{background:#2b6cb0;border-color:#63b3ed}.node-tag{color:#63b3ed}.node-text{background:#2d3748;color:#e2e8f0}.node-children{border-color:#4a5568}#property-info{background:#2d3748;border-color:#4a5568;color:#e2e8f0}}.sheetsets-container{margin:10px 0}.sheetsets-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px;border-radius:8px;margin-bottom:15px;box-shadow:0 4px 6px #0000001a}.sheetsets-header h3{margin:0;font-size:1.2em;font-weight:600}.sheetset-label{background:#f7fafc;border:2px solid #e2e8f0;border-radius:6px;padding:8px 12px;margin:10px 0 5px;font-weight:600;color:#2d3748;font-size:.9em;text-transform:uppercase;letter-spacing:.5px}.dark-theme .sheetset-label{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.sheet-names-container{margin:10px 0}.sheet-names-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px;border-radius:8px;margin-bottom:15px;box-shadow:0 4px 6px #0000001a}.sheet-names-header h3{margin:0;font-size:1.2em;font-weight:600}.sheet-set-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin:15px 0;box-shadow:0 2px 4px #0000000d;overflow:hidden}.sheet-set-header{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;padding:15px 20px;cursor:pointer;transition:all .2s ease}.sheet-set-header:hover{background:linear-gradient(135deg,#3182ce,#2c5282)}.sheet-name-content{display:flex;justify-content:space-between;align-items:center}.sheet-name{font-weight:600;color:#fff;font-size:1.1em}.sheet-index{background:#fff3;color:#fff;padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:500}.subsets-container{padding:15px 20px;background:#f7fafc;border-top:1px solid #e2e8f0;max-height:550px;overflow-y:auto;overflow-x:hidden}.subsets-header{margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.subsets-header h5{margin:0;color:#2d3748;font-size:1em;font-weight:600}.subset-name-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s ease;cursor:pointer;margin:8px 0 8px 20px;overflow:hidden}.subset-name-item:hover{border-color:#4299e1;box-shadow:0 2px 8px #4299e126;transform:translateY(-1px)}.subset-header{padding:12px 15px;background:#f8f9fa;border-bottom:1px solid #e2e8f0}.subset-name-content{display:flex;justify-content:space-between;align-items:center}.subset-name{font-weight:600;color:#2d3748;font-size:.95em}.subset-index{background:#edf2f7;color:#4a5568;padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:500}.sheets-container{padding:10px 15px;background:#f7fafc;max-height:550px;overflow-y:auto;overflow-x:hidden}.sheets-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.sheets-header h6{margin:0;color:#4a5568;font-size:.85em;font-weight:600}.sheet-title-item{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:8px 12px;transition:all .2s ease;cursor:pointer;margin:6px 0 6px 20px}.sheet-title-item:hover{border-color:#4299e1;box-shadow:0 1px 4px #4299e11a;transform:translateY(-1px)}.sheet-title-content{display:flex;justify-content:space-between;align-items:center}.sheet-title{font-weight:500;color:#2d3748;font-size:.9em}.sheet-index{background:#edf2f7;color:#4a5568;padding:2px 6px;border-radius:8px;font-size:.75em;font-weight:500}.no-sheets{text-align:center;color:#a0aec0;font-style:italic;padding:15px;background:#f7fafc;border-radius:4px;margin:8px 0;font-size:.85em}.no-subsets{text-align:center;color:#718096;font-style:italic;padding:20px;background:#f7fafc;border-radius:6px;margin:10px 0}@media (prefers-color-scheme: dark){.sheet-set-container{background:#2d3748;border-color:#4a5568}.sheet-set-header{background:linear-gradient(135deg,#2b6cb0,#2c5282)}.sheet-set-header:hover{background:linear-gradient(135deg,#2c5282,#1a365d)}.subsets-container{background:#1a202c;border-color:#4a5568}.subsets-header h5{color:#e2e8f0}.subsets-header{border-color:#4a5568}.subset-name-item{background:#2d3748;border-color:#4a5568}.subset-name-item:hover{border-color:#63b3ed;box-shadow:0 2px 8px #63b3ed26}.subset-header{background:#1a202c;border-color:#4a5568}.subset-name{color:#e2e8f0}.subset-index{background:#4a5568;color:#a0aec0}.sheets-container{background:#1a202c}.sheets-header h6{color:#a0aec0}.sheets-header{border-color:#4a5568}.sheet-title-item{background:#2d3748;border-color:#4a5568}.sheet-title-item:hover{border-color:#63b3ed;box-shadow:0 1px 4px #63b3ed1a}.sheet-title{color:#e2e8f0}.sheet-index{background:#4a5568;color:#a0aec0}.no-sheets,.no-subsets{color:#a0aec0;background:#1a202c}}.subsets-container::-webkit-scrollbar,.sheets-container::-webkit-scrollbar{width:8px}.subsets-container::-webkit-scrollbar-track,.sheets-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.subsets-container::-webkit-scrollbar-thumb,.sheets-container::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.subsets-container::-webkit-scrollbar-thumb:hover,.sheets-container::-webkit-scrollbar-thumb:hover{background:#a0aec0}.collapsible-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.collapsible-header:hover{background-color:#63b3ed1a}.collapsible-icon{margin-left:8px;font-size:14px;transition:transform .2s ease;color:#718096;min-width:16px;text-align:center;flex-shrink:0}.collapsible-icon.expanded{transform:rotate(90deg)}.collapsible-content{overflow:hidden;transition:max-height .3s ease,opacity .2s ease}.collapsible-content.collapsed{max-height:0;opacity:0}.collapsible-content.expanded{max-height:1000px;opacity:1}.custom-properties-container{margin-top:8px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0;overflow:hidden}.custom-properties-header{background:#edf2f7;padding:8px 12px;border-bottom:1px solid #e2e8f0}.custom-properties-header h6{margin:0;font-size:12px;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.5px}.properties-list{padding:8px}.property-item{display:flex;align-items:center;padding:4px 0;border-bottom:1px solid #f1f5f9}.property-item:last-child{border-bottom:none}.property-content{display:flex;align-items:center;width:100%;gap:8px}.property-name{font-weight:500;color:#2d3748;min-width:120px;font-size:12px}.property-value{color:#4a5568;font-size:12px;background:#f7fafc;padding:2px 6px;border-radius:3px;border:1px solid #e2e8f0;flex:1;cursor:pointer;transition:all .2s ease;min-height:20px;display:flex;align-items:center}.property-value:hover{background:#edf2f7;border-color:#cbd5e0}.no-properties,.no-custom-properties{padding:12px;text-align:center;color:#a0aec0;font-size:12px;font-style:italic;background:#f7fafc}@media (prefers-color-scheme: dark){.custom-properties-container{background:#2d3748;border-color:#4a5568}.custom-properties-header{background:#4a5568;border-color:#718096}.custom-properties-header h6{color:#a0aec0}.property-item{border-color:#4a5568}.property-name{color:#e2e8f0}.property-value{color:#a0aec0;background:#1a202c;border-color:#4a5568}.property-value:hover{background:#2d3748;border-color:#718096}.no-properties,.no-custom-properties{color:#a0aec0;background:#1a202c}.collapsible-header:hover{background-color:#63b3ed33}.collapsible-icon{color:#a0aec0}.subsets-container::-webkit-scrollbar-track,.sheets-container::-webkit-scrollbar-track{background:#2d3748}.subsets-container::-webkit-scrollbar-thumb,.sheets-container::-webkit-scrollbar-thumb{background:#4a5568}.subsets-container::-webkit-scrollbar-thumb:hover,.sheets-container::-webkit-scrollbar-thumb:hover{background:#718096}}.typing-indicators-overlay{position:absolute;inset:0;pointer-events:none;z-index:20;overflow:visible}.typing-marker{position:absolute;transform:translate(-1px);display:flex;flex-direction:column;align-items:flex-start;gap:2px}.typing-caret{width:2px;min-height:14px;border-radius:1px;animation:typingCaretBlink 1s ease-in-out infinite;box-shadow:0 0 0 1px #fff9}@keyframes typingCaretBlink{0%,45%{opacity:1}50%,95%{opacity:.35}to{opacity:1}}.typing-label{font-size:10px;font-weight:600;line-height:1.1;padding:2px 5px;border-radius:4px;background:#fffffff2;border:1px solid currentColor;box-shadow:0 1px 3px #0000001f;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}
