*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}button,input{font-family:inherit}.language-select{position:relative;margin-bottom:1rem}.search-label{display:block;font-size:.875rem;font-weight:500;color:#475569;margin-bottom:.5rem}.optional-badge{display:inline-block;margin-left:.5rem;font-size:.75rem;color:#94a3b8;background-color:#f1f5f9;padding:.125rem .375rem;border-radius:4px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.625rem 2.5rem .625rem .75rem;font-size:.95rem;border:1px solid #cbd5e1;border-radius:6px;background-color:#fff;transition:all .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input:disabled{background-color:#f8fafc;cursor:not-allowed;color:#94a3b8}.search-input.has-selection{border-color:#3b82f6;background-color:#eff6ff}.clear-button{position:absolute;right:.5rem;background:none;border:none;color:#94a3b8;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:50%;display:flex;align-items:center;justify-content:center}.clear-button:hover{color:#ef4444;background-color:#fee2e2}.suggestions-list{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:.25rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;max-height:250px;overflow-y:auto;list-style:none;padding:.25rem 0}.lang-option{padding:.5rem .75rem;cursor:pointer;font-size:.95rem;color:#334155;transition:background-color .1s}.lang-option:hover,.lang-option.highlighted{background-color:#f1f5f9;color:#0f172a}.suggestions-list.no-results{padding:.75rem;text-align:center;color:#64748b;font-size:.875rem}*{box-sizing:border-box}:root{--primary: #3b82f6;--primary-dark: #2563eb;--secondary: #10b981;--accent: #f59e0b;--bg: #f8fafc;--bg-card: #ffffff;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: 8px;--radius-lg: 12px}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}#root,.app{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:2rem;text-align:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff}.app-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.app-header .subtitle{margin:0;opacity:.9;font-size:1.1rem}.app-header a{color:#fff;text-decoration:underline}.load-section{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.load-prompt{text-align:center;max-width:500px}.info-card{background:var(--bg-card);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-bottom:2rem;text-align:left}.info-card h2{margin:0 0 1rem;color:var(--primary)}.info-card ul{margin:1rem 0;padding-left:1.5rem}.info-card li{margin:.5rem 0}.data-note{margin-top:1rem;padding:1rem;background:#fef3c7;border-radius:var(--radius);color:#92400e;font-size:.9rem}.load-button{background:var(--primary);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}.load-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.loading-indicator{text-align:center;width:100%;max-width:400px}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%);border-radius:4px;transition:width .3s ease}.progress-message{color:var(--text-muted);margin:.5rem 0}.progress-percent{font-size:1.5rem;font-weight:700;color:var(--primary);margin:0}.error-message{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:1rem 1.5rem;border-radius:var(--radius);display:flex;align-items:center;gap:1rem;z-index:100}.error-message p{margin:0}.error-message button{background:#991b1b;color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer}.main-content{flex:1;display:flex;flex-direction:column;max-width:1400px;margin:0 auto;width:100%;padding:1.5rem}.search-panel{background:var(--bg-card);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1.5rem}.search-inputs{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap}.search-connector{display:flex;align-items:center;justify-content:center;padding-bottom:.5rem}.connector-icon{font-size:1.5rem;color:var(--text-muted)}.term-search{flex:1;min-width:250px;position:relative}.search-label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text)}.search-input-wrapper{position:relative}.search-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--border);border-radius:var(--radius);outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--primary)}.search-input.has-selection{border-color:var(--secondary);background:#f0fdf4}.search-input:disabled{background:#f1f5f9;cursor:not-allowed}.clear-button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--text-muted);color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center}.clear-button:hover{background:var(--text)}.search-spinner{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.suggestions-list.no-results{padding:1rem;text-align:center;color:var(--text-muted)}.suggestions-list.no-results p{margin:0}.error-card{border-left:4px solid #ef4444}.error-card h2{color:#ef4444}.error-card code{background:#f1f5f9;padding:.2rem .4rem;border-radius:4px;font-size:.9rem}.suggestions-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);margin:4px 0 0;padding:0;list-style:none;max-height:300px;overflow-y:auto;z-index:50}.suggestion-item{padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-bottom:1px solid var(--border)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.highlighted{background:#f1f5f9}.suggestion-term{font-weight:500}.suggestion-lang{font-size:.85rem;color:var(--text-muted);background:#e2e8f0;padding:.2rem .5rem;border-radius:4px}.stats-bar{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.9rem;justify-content:center;flex-wrap:wrap}.visualization-panel{flex:1;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);min-height:500px;position:relative;display:flex;flex-direction:column}.empty-state,.partial-state,.no-connection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3,.no-connection h3{margin:0 0 .5rem;color:var(--text)}.empty-state p,.no-connection p,.partial-state p{color:var(--text-muted);max-width:400px}.example-queries{margin-top:2rem;text-align:left;background:#f1f5f9;padding:1.5rem;border-radius:var(--radius)}.example-queries h4{margin:0 0 1rem;color:var(--text-muted)}.example-queries ul{margin:0;padding-left:1.5rem}.example-queries li{margin:.5rem 0}.searching-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg)}.searching-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-section{flex:1;display:flex;flex-direction:column;padding:1.5rem}.lca-info{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.lca-info h3{margin:0 0 .75rem;color:var(--accent)}.lca-details{display:flex;flex-direction:column;gap:.5rem}.lca-term{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.lca-label{font-weight:600;color:var(--text-muted)}.lca-value{font-size:1.25rem;font-weight:700;color:var(--accent)}.lca-lang{color:var(--text-muted)}.lca-distances{display:flex;gap:.5rem;color:var(--text-muted);font-size:.9rem;flex-wrap:wrap}.other-ancestors{margin-top:1rem}.other-ancestors summary{cursor:pointer;color:var(--primary);font-weight:500}.other-ancestors ul{margin-top:.5rem;padding-left:1.5rem}.other-ancestors li{margin:.25rem 0;color:var(--text-muted)}.tree-container{flex:1;min-height:400px;position:relative}.tree-container svg{width:100%;height:100%;min-height:400px}.tree-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.tree-tooltip{position:absolute;background:var(--text);color:#fff;padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem;pointer-events:none;opacity:0;transition:opacity .2s;z-index:100;max-width:200px}.legend{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.legend h4{margin:0 0 .75rem;color:var(--text-muted);font-size:.9rem}.legend-items{display:flex;gap:1.5rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.legend-dot{width:16px;height:16px;border-radius:50%}.legend-tip{margin-top:.5rem;font-size:.8rem;color:var(--text-muted)}.app-footer{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.9rem;border-top:1px solid var(--border);background:var(--bg-card)}.app-footer a{color:var(--primary)}.query-templates,.template-selector{margin-bottom:1rem}.selector-label{display:block;font-weight:600;margin-bottom:.75rem;color:var(--text)}.template-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.template-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1rem;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;min-width:90px}.template-btn:hover{border-color:var(--primary);background:#f0f9ff}.template-btn.active{border-color:var(--primary);background:#dbeafe}.template-btn:disabled{opacity:.5;cursor:not-allowed}.template-icon{font-size:1.5rem}.template-name{font-size:.75rem;font-weight:500;text-align:center}.template-form{padding:1rem;background:var(--bg);border-radius:var(--radius);margin-top:1rem}.template-description{margin:0 0 1rem;color:var(--text-muted);font-size:.9rem}.template-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.template-input{min-width:0}.number-input{display:flex;flex-direction:column}.number-input input{padding:.75rem 1rem;font-size:1rem;border:2px solid var(--border);border-radius:var(--radius);outline:none;transition:border-color .2s;width:100%}.number-input input:focus{border-color:var(--primary)}.language-select{position:relative}.optional-badge{font-size:.75rem;color:var(--text-muted);font-weight:400;margin-left:.5rem}.lang-option{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border)}.lang-option:last-child{border-bottom:none}.lang-option:hover,.lang-option.highlighted{background:#f1f5f9}.query-actions{display:flex;justify-content:center;margin:1.5rem 0 1rem}.search-button{background:var(--primary);color:#fff;border:none;padding:.875rem 2.5rem;font-size:1rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}.search-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.search-button:disabled{opacity:.5;cursor:not-allowed}.result-summary{padding:1rem 1.5rem;border-radius:var(--radius);margin-bottom:1rem}.result-summary.success{background:#ecfdf5;border-left:4px solid #10b981}.result-summary.info{background:#f0f9ff;border-left:4px solid #3b82f6}.result-summary.error{background:#fef2f2;border-left:4px solid #ef4444}.result-summary h3{margin:0 0 .5rem;font-size:1rem}.summary-details{display:flex;flex-wrap:wrap;gap:1rem}.summary-item{display:flex;gap:.5rem}.summary-label{color:var(--text-muted)}.summary-value{font-weight:600}.legend-panel{background:var(--bg-card);padding:1rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-top:1rem}.legend-panel h4{margin:0 0 .75rem;color:var(--text-muted);font-size:.9rem}@media(max-width:768px){.app-header h1{font-size:1.75rem}.search-inputs{flex-direction:column}.search-connector{padding:.5rem 0}.connector-icon{transform:rotate(90deg)}.term-search{min-width:100%}.lca-distances{flex-direction:column;gap:.25rem}.lca-distances span:nth-child(2){display:none}.legend-items{flex-direction:column;gap:.5rem}}
