*{margin:0;padding:0;box-sizing:border-box}.app{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.header{max-width:1400px;margin:0 auto 20px;background:#fff;padding:40px;border-radius:16px 16px 0 0;box-shadow:0 20px 60px #0000004d;text-align:center}.header h1{font-size:2.5em;margin-bottom:10px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.header p{font-size:1.1em;color:#6c757d}.controls{max-width:1400px;margin:0 auto;background:#f8f9fa;padding:25px 30px;display:flex;gap:20px;flex-wrap:wrap;align-items:center;border-left:1px solid white;border-right:1px solid white;box-shadow:0 20px 60px #0000004d}.control-group{display:flex;align-items:center;gap:10px}.control-group label{font-weight:600;color:#495057;font-size:.95em}.control-group.checkbox label{cursor:pointer;display:flex;align-items:center;gap:8px}.controls select{padding:8px 16px;border:2px solid #dee2e6;border-radius:6px;font-size:.95em;background:#fff;cursor:pointer;transition:all .2s}.controls select:hover{border-color:#667eea}.controls input[type=checkbox]{width:18px;height:18px;cursor:pointer}.graph-container{max-width:1400px;margin:0 auto;background:#fff;padding:30px;min-height:600px;display:flex;align-items:center;justify-content:center;border-left:1px solid white;border-right:1px solid white;box-shadow:0 20px 60px #0000004d}.info-panel{max-width:1400px;margin:0 auto;padding:25px 30px;background:#f8f9fa;border-radius:0 0 16px 16px;border-left:1px solid white;border-right:1px solid white;border-bottom:1px solid white;box-shadow:0 20px 60px #0000004d}.info-panel h3{color:#495057;margin-bottom:15px;font-size:1.3em}.info-panel ul{list-style:none;line-height:1.8;color:#6c757d;margin-bottom:20px}.info-panel li:before{content:"▸ ";color:#667eea;font-weight:700;margin-right:8px}.status,.selected-block{margin-top:12px;padding:12px 16px;background:#fff;border-left:4px solid #667eea;border-radius:4px;font-size:.95em;color:#495057}.selected-block{border-left-color:#28a745}@media(max-width:768px){.header h1{font-size:1.8em}.controls{flex-direction:column;align-items:stretch}.control-group{justify-content:space-between}.graph-container{min-height:400px}.graph-container blocks-graph{height:400px!important}}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
