: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}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}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}}.canvas-container{width:100%;height:100%;position:relative;overflow:hidden;background:#fafafa;border:1px solid #e0e0e0}.diagram-canvas{cursor:crosshair;background:radial-gradient(circle,#e8e8e8 1px,transparent 1px);background-size:20px 20px;touch-action:none}.diagram-canvas.select-mode{cursor:default}.node{transition:transform .1s ease}.node:hover{filter:brightness(1.1)}.node.selected{filter:drop-shadow(0 0 5px rgba(33,150,243,.5))}.edge-path{transition:stroke .2s ease}.edge-path:hover{stroke-width:3px}.edge-label{pointer-events:none;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.node.vocabulary ellipse{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.node.practice rect{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.node.test path{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.node.operate rect{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}
