*{box-sizing:border-box;margin:0;padding:0}html,body{color:#fff;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;overflow:hidden}.container{flex-direction:column;width:100vw;height:100vh;display:flex}header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#0000004d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 2rem;display:flex}h1{background:linear-gradient(90deg,#00d4ff,#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:600}.controls{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}button{cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#2563eb 100%)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed66}.btn-secondary{color:#fff;background:#ffffff1a;border:1px solid #fff3}.btn-secondary:hover{background:#fff3}select{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:.5rem 1rem;font-size:.875rem}select option{color:#fff;background:#16213e}main{flex:1;position:relative;overflow:hidden}#visualization,#visualization svg{width:100%;height:100%}#loading{color:#ffffffb3;font-size:1.25rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#loading.hidden{display:none}.info-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#000000b3;border:1px solid #ffffff1a;border-radius:12px;max-width:300px;padding:1rem;font-size:.875rem;position:fixed;bottom:1rem;left:1rem}.info-panel h3{color:#00d4ff;margin-bottom:.5rem}.stats{gap:1rem;margin-top:.5rem;display:flex}.stat{text-align:center}.stat-value{color:#7c3aed;font-size:1.25rem;font-weight:600}.stat-label{color:#fff9;font-size:.75rem}.legend{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#000000b3;border:1px solid #ffffff1a;border-radius:12px;padding:1rem;font-size:.75rem;position:fixed;top:5rem;right:1rem}.legend h4{color:#00d4ff;margin-bottom:.5rem}.legend-item{align-items:center;gap:.5rem;margin:.25rem 0;display:flex}.legend-color{border-radius:50%;width:12px;height:12px}.tooltip{color:#fff;pointer-events:none;opacity:0;z-index:1000;background:#000000e6;border:1px solid #fff3;border-radius:8px;max-width:350px;padding:.75rem 1rem;font-size:.875rem;transition:opacity .2s;position:fixed}.tooltip.visible{opacity:1}.tooltip-title{color:#00d4ff;margin-bottom:.25rem;font-weight:600}.tooltip-text{color:#fffc}.node circle{cursor:pointer;stroke-width:2px;transition:all .2s}.node circle:hover{stroke-width:3px;filter:brightness(1.2)}.node text{fill:#ffffffe6;pointer-events:none;font-size:10px}.link{fill:none;stroke:#fff3;stroke-width:1px}@media (width<=768px){header{padding:.75rem 1rem}h1{font-size:1.25rem}.info-panel,.legend{max-width:calc(50% - 1.5rem);padding:.75rem;font-size:.75rem}.legend{top:auto;bottom:1rem;right:1rem}.info-panel{bottom:1rem;left:1rem}}
