.visualization-container{background:#fff;border-radius:8px;padding:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden;height:100%;display:flex;flex-direction:column}.visualization-container svg{display:block;margin:0 auto;background:#fafafa;border-radius:8px;flex:1;width:100%;height:100%}.app{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden;padding:10px;box-sizing:border-box}.header{text-align:center;color:#fff;margin-bottom:10px;flex-shrink:0}.header h1{font-size:1.5rem;margin-bottom:5px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.subtitle{font-size:.9rem;opacity:.9}.controls{background:#fff;border-radius:8px;padding:10px 15px;margin-bottom:10px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:15px;flex-wrap:wrap;flex-shrink:0}.input-group{display:flex;align-items:center;gap:8px}.input-group label{font-weight:600;color:#333;font-size:.9rem}.input-group input{padding:6px 10px;border:2px solid #667eea;border-radius:6px;font-size:.9rem;width:70px;outline:none;transition:border-color .3s}.input-group input:focus{border-color:#764ba2}.step-controls{display:flex;gap:8px}.step-controls button{padding:6px 15px;border:none;border-radius:6px;background:#667eea;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s;font-weight:600}.step-controls button:hover:not(:disabled){background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.step-controls button:disabled{background:#ccc;cursor:not-allowed;transform:none}.step-info{margin-left:auto;font-weight:600;color:#667eea;font-size:.95rem}.main-content{display:flex;gap:10px;flex:1;overflow:hidden;min-height:0}.sidebar{width:300px;flex-shrink:0;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.result-panel{flex-shrink:0}.result-card{background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 4px #0000001a;text-align:center}.result-value{font-size:1rem;color:#333;margin-bottom:0}.result-value strong{color:#764ba2;font-size:1.3rem}.explanation-panel{flex:1;min-height:0}.explanation-card{background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 4px #0000001a;height:100%;overflow-y:auto}.explanation-card h3{margin:0 0 10px;color:#667eea;font-size:1rem;border-bottom:2px solid #f0f0f0;padding-bottom:8px}.explanation-text{color:#333;line-height:1.6;font-size:.85rem}.explanation-text p{margin:4px 0}.explanation-text code{background:#f5f5f5;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;color:#e83e8c}.visualization-wrapper{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}@media (max-width: 1200px){.sidebar{width:250px}}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;max-height:200px}.controls{flex-direction:column;align-items:stretch}.step-info{margin-left:0;text-align:center}}*{margin:0;padding:0;box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{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;background:linear-gradient(135deg,#667eea,#764ba2);color:#333}#root{width:100%;height:100%;overflow:hidden}
