:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{min-width:320px}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app{height:100vh;width:100vw;display:flex;flex-direction:column;overflow:hidden;background:linear-gradient(160deg,#0f172a,#1e293b,#0f172a);color:#e2e8f0}.app-header{flex-shrink:0;padding:.5rem 1rem;text-align:center;border-bottom:1px solid #334155}.app-header h1{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#a78bfa,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{margin:.15rem 0 0;font-size:.8rem;color:#94a3b8}.mode-tabs{flex-shrink:0;display:flex;gap:0;padding:0 1rem;border-bottom:1px solid #334155}.mode-tabs button{padding:.6rem 1.2rem;background:transparent;border:none;color:#94a3b8;font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.mode-tabs button:hover{color:#e2e8f0}.mode-tabs button.active{color:#a78bfa;border-bottom-color:#a78bfa}.controls{flex-shrink:0;padding:.5rem 1rem}.control-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.control-row.archetype-row{gap:.75rem}.search-bar{position:relative;min-width:280px}.search-input,.archetype-input{width:100%;min-width:260px;padding:.6rem 1rem;font-size:1rem;border:1px solid #475569;border-radius:8px;background:#1e293b;color:#e2e8f0}.search-input:focus,.archetype-input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa33}.search-loading{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.8rem;color:#94a3b8}.search-results{position:absolute;top:100%;left:0;right:0;margin:0;padding:0;list-style:none;background:#1e293b;border:1px solid #475569;border-radius:8px;max-height:280px;overflow-y:auto;z-index:20;box-shadow:0 10px 25px #0006}.search-result-item{width:100%;padding:.5rem 1rem;text-align:left;background:none;border:none;color:#e2e8f0;cursor:pointer;font-size:.95rem}.search-result-item:hover{background:#334155}.archetype-input{max-width:220px}.build-btn{padding:.6rem 1.2rem;background:#7c3aed;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer}.build-btn:hover:not(:disabled){background:#6d28d9}.build-btn:disabled{opacity:.6;cursor:not-allowed}.hint{font-size:.85rem;color:#94a3b8;margin:0}.error-banner{flex-shrink:0;margin:0 1rem .5rem;padding:.5rem 1rem;background:#ef444426;border:1px solid #ef4444;border-radius:8px;color:#fca5a5}.loading-overlay{position:fixed;inset:0;background:#0f172acc;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#a78bfa;z-index:50}.main-content{flex:1;display:flex;min-height:0;overflow:hidden;position:relative}.bubble-graph{flex:1;min-height:0;position:relative;width:100%;height:100%}.bubble-graph canvas{display:block;width:100%!important;height:100%!important}.bubble-graph.empty{display:flex;align-items:center;justify-content:center}.empty-state{font-size:1rem;color:#64748b;text-align:center;max-width:360px}.card-detail{width:320px;flex-shrink:0;background:#1e293b;border-left:1px solid #334155;overflow-y:auto;padding:1rem}.card-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.card-detail-header h3{margin:0;font-size:1.1rem;line-height:1.3}.close-btn{background:none;border:none;color:#94a3b8;font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .25rem}.close-btn:hover{color:#e2e8f0}.card-detail-body{font-size:.9rem}.card-detail-image{width:100%;border-radius:8px;margin-bottom:.75rem}.card-type{font-weight:600;color:#a78bfa;margin:0 0 .25rem}.card-race,.card-attr,.card-archetype{margin:.25rem 0;color:#94a3b8}.card-desc-section{margin-top:1rem}.card-desc-label{font-size:.8rem;color:#94a3b8;margin:0 0 .5rem}.card-desc-clauses{list-style:none;margin:0;padding:0}.card-desc-clause-wrap{margin-bottom:.5rem}.card-desc-clause{display:block;width:100%;padding:.5rem .6rem;text-align:left;font-size:.85rem;line-height:1.4;color:#cbd5e1;background:#334155;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}.card-desc-clause:hover{background:#475569}.card-desc-clause.active{border-color:#fbbf24;background:#475569}.card-desc-clause-labels{display:block;font-size:.75rem;color:#94a3b8;margin-top:.2rem;margin-left:.25rem}.card-desc-clear{margin-top:.75rem;padding:.4rem .75rem;font-size:.8rem;background:transparent;border:1px solid #64748b;color:#94a3b8;border-radius:6px;cursor:pointer}.card-desc-clear:hover{border-color:#94a3b8;color:#e2e8f0}.card-desc{margin-top:1rem;line-height:1.5;color:#cbd5e1;white-space:pre-wrap}.link-legend{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;padding:.4rem 1rem;font-size:.75rem;color:#94a3b8;border-top:1px solid #334155}.link-legend-title{font-weight:600;color:#cbd5e1;margin-right:.25rem}.link-legend-item{display:inline-flex;align-items:center;gap:.35rem}.link-legend-swatch{display:inline-block;width:12px;height:4px;border-radius:2px;flex-shrink:0}.app-footer{flex-shrink:0;padding:.4rem 1rem;font-size:.75rem;color:#64748b;border-top:1px solid #334155}.app-footer a{color:#60a5fa}.app-footer a:hover{text-decoration:underline}
