:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.sidebar{background:var(--panel-bg);border-right:1px solid var(--panel-border);width:260px;color:var(--panel-fg);flex-direction:column;gap:20px;padding:16px;display:flex;overflow-y:auto}.sidebar h3{margin:0 0 6px;font-size:14px}.sidebar .label{text-transform:uppercase;opacity:.7;font-size:11px}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.kanji-node{background:var(--node-bg);border:1px solid var(--node-border);color:var(--node-fg);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-family:Noto Serif JP,Hiragino Mincho ProN,serif;font-size:16px;display:inline-flex}.kanji-node[data-kind=BC],.kanji-node[data-kind=BT]{background:var(--node-bg-radical)}.kanji-node .literal{font-size:18px;line-height:1}.kanji-node .badge{border-radius:999px;padding:2px 6px;font-family:Inter,system-ui,sans-serif;font-size:10px;line-height:1}.kanji-node .badge.jlpt-N5{color:#1a5e2f;background:#d8f5d3}.kanji-node .badge.jlpt-N4{color:#1a3f5e;background:#d3e5f5}.kanji-node .badge.jlpt-N3{color:#1c5e5f;background:#cef0f5}.kanji-node .badge.jlpt-N2{color:#5e1a5e;background:#f7d3f5}.kanji-node .badge.jlpt-N1{color:#5e4e1a;background:#f7eed3}.kanji-node .badge.kind{color:var(--node-fg);background:#00000018}.toolbar{z-index:10;flex-direction:column;gap:6px;display:flex;position:absolute;top:12px;right:12px}.toolbar button{background:var(--panel-bg);border:1px solid var(--panel-border);width:36px;height:36px;color:var(--panel-fg);cursor:pointer;border-radius:8px;font-size:12px}.toolbar button.danger{color:#fff;background:#d33;border-color:#a22}.toolbar button.theme{color:#fff;background:#222;border-color:#444}.toolbar button.primary{color:#fff;background:#1c6cf3;border-color:#1455c4}.stroke-order{background:var(--panel-bg-alt);border-radius:8px;justify-content:center;padding:12px;display:flex}.stroke-order svg{width:140px;height:140px}.stroke-order svg path{fill:none;stroke:var(--panel-fg);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1000;stroke-dashoffset:1000px;animation:1.2s forwards stroke-draw}.stroke-order svg path:nth-child(n+2){animation-delay:1.2s}.stroke-order svg path:nth-child(n+3){animation-delay:2.4s}.stroke-order svg path:nth-child(n+4){animation-delay:3.6s}.stroke-order svg path:nth-child(n+5){animation-delay:4.8s}@keyframes stroke-draw{to{stroke-dashoffset:0}}.detail-panel{background:var(--panel-bg);border-left:1px solid var(--panel-border);width:360px;color:var(--panel-fg);flex-direction:column;gap:16px;padding:16px 20px;display:flex;position:absolute;top:0;bottom:0;right:0;overflow-y:auto}.detail-panel header{align-items:center;gap:8px;display:flex}.detail-panel header h2{margin:0;font-family:Noto Serif JP,serif;font-size:36px;line-height:1}.detail-panel .close{border:1px solid var(--panel-border);color:inherit;cursor:pointer;background:0 0;border-radius:6px;margin-left:auto;padding:4px 8px}.detail-panel section h4{text-transform:uppercase;opacity:.7;margin:0 0 6px;font-size:12px}.detail-panel .jlpt-badge{color:#1a5e2f;background:#d8f5d3;border-radius:999px;padding:3px 8px;font-size:10px}:root{--bg:#1f1f2e;--panel-bg:#2a2a3a;--panel-bg-alt:#353548;--panel-fg:#eaeaf2;--panel-border:#3c3c52;--node-bg:#fff;--node-bg-radical:#f8d7d7;--node-border:#c4c4d0;--node-fg:#1a1a26}:root.light{--bg:#f6f6fa;--panel-bg:#fff;--panel-bg-alt:#eef0f7;--panel-fg:#1c1c2a;--panel-border:#d3d5e0;--node-bg:#fff;--node-bg-radical:#f8d7d7;--node-border:#b3b3c0;--node-fg:#1a1a26}html,body,#root{background:var(--bg);height:100%;color:var(--panel-fg);margin:0;padding:0;font-family:Inter,system-ui,sans-serif}.app{grid-template-columns:240px 1fr;height:100vh;display:grid;position:relative}.graph-area{position:relative;overflow:hidden}.app.fullscreen{grid-template-columns:0 1fr}.app.fullscreen .sidebar{display:none}@media (width<=900px){.app{grid-template-columns:200px 1fr}}@media (width<=640px){.app{grid-template-rows:auto 1fr;grid-template-columns:1fr}.sidebar{max-height:40vh;width:auto!important}.detail-panel{max-width:100vw;width:100%!important}}
