:root{--page-bg:#f7f4ee;--page-bg-strong:#efe6d8;--panel-bg:#fffcf7d1;--panel-stroke:#3947581a;--ink-strong:#1f2a37;--ink-soft:#556170;--ink-muted:#6f7c8d;--accent-strong:#0b7f90;--shadow:0 20px 45px #1f2a3714, 0 6px 20px #1f2a370f;--font-body:"Avenir Next", "Segoe UI", "Helvetica Neue", sans-serif;--font-display:"Iowan Old Style", "Palatino Linotype", "Book Antiqua", serif;--font-mono:"SFMono-Regular", "Consolas", "Liberation Mono", monospace;--branch-width:4px;--branch-width-main:8px;--branch-width-sub:4px;font-family:var(--font-body);color:var(--ink-strong);background:radial-gradient(circle at top left, #2bb3c729, transparent 24%), radial-gradient(circle at 85% 20%, #126b1f24, transparent 22%), linear-gradient(180deg, var(--page-bg), var(--page-bg-strong));font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{min-height:100%}body{min-height:100vh;margin:0}body:before{content:"";pointer-events:none;background-image:linear-gradient(#1f2a3706 1px,#0000 1px),linear-gradient(90deg,#1f2a3706 1px,#0000 1px);background-size:36px 36px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000a6,#0000 88%);mask-image:linear-gradient(#000000a6,#0000 88%)}button,input,textarea,select{font:inherit}code{font-family:var(--font-mono)}#root{min-height:100svh}.app-shell{box-sizing:border-box;gap:0;width:100vw;min-height:100svh;padding:0;display:grid;overflow:hidden}.app-shell__header{gap:.75rem;max-width:58rem;display:grid}.app-shell__eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--accent-strong);margin:0;font-size:.8rem;font-weight:700}.app-shell__header h1{font-family:var(--font-display);letter-spacing:-.05em;color:var(--ink-strong);margin:0;font-size:clamp(2.4rem,4vw,4.4rem);line-height:.95}.app-shell__intro{max-width:46rem;color:var(--ink-soft);margin:0;font-size:1rem;line-height:1.65}.app-shell__intro code{background:#ffffffb3;border:1px solid #0795a826;border-radius:999px;padding:.16rem .45rem;font-size:.92em}@media (width<=720px){.app-shell{padding:0}.app-shell__header{gap:.55rem}}.mindmap{gap:0;width:100vw;height:100svh;display:grid}.mindmap__meta{justify-content:flex-end;display:flex}.mindmap__hint{color:var(--ink-muted);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffa8;border:1px solid #39475814;border-radius:999px;margin:0;padding:.4rem .8rem;font-size:.88rem}.mindmap__viewport{border:1px solid var(--panel-stroke);background:radial-gradient(circle at top left, #2bb3c71a, transparent 26%), radial-gradient(circle at bottom right, #126b1f1a, transparent 22%), var(--panel-bg);width:100%;height:100%;min-height:100svh;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:0;position:relative;overflow:hidden}.mindmap__controls{z-index:4;gap:.5rem;display:grid;position:absolute;top:1rem;right:1rem}.mindmap__control-button{width:2.8rem;height:2.8rem;color:var(--ink-strong);cursor:pointer;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffd6;border:1px solid #3947581f;border-radius:.95rem;font-size:1.45rem;font-weight:700;line-height:1;transition:transform .14s,background .14s,box-shadow .14s;box-shadow:0 10px 24px #1f2a3717}.mindmap__control-button:hover,.mindmap__control-button:focus-visible{background:#fffffff5;outline:none;transform:translateY(-1px);box-shadow:0 14px 28px #1f2a371f}.mindmap__reset-view{z-index:8;color:#fff;letter-spacing:.01em;cursor:pointer;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#1f2a37e6;border:1px solid #39475824;border-radius:999px;min-width:8.5rem;padding:.82rem 1rem;font-size:.94rem;font-weight:700;transition:transform .16s,opacity .16s,box-shadow .16s;position:fixed;bottom:clamp(1rem,2vw,1.5rem);right:clamp(1rem,2vw,1.5rem);box-shadow:0 18px 34px #1f2a372e}.mindmap__reset-view:hover,.mindmap__reset-view:focus-visible{opacity:.96;outline:none;transform:translateY(-2px)scale(1.01);box-shadow:0 22px 40px #1f2a3738}.mindmap__viewport .react-transform-wrapper,.mindmap__viewport .react-transform-component{width:100%!important;height:100%!important}.mindmap__viewport .react-transform-component{touch-action:none}.mindmap__svg{width:100%;height:100%;display:block;overflow:visible}.branch{stroke:var(--branch-color);stroke-width:var(--branch-width,4px);stroke-linecap:round;stroke-linejoin:round;opacity:.92;pointer-events:none}.branch.is-drawing,.branch.is-exiting{will-change:opacity, stroke-dashoffset}.mindmap__branch-group{outline:none}.mindmap__branch-group .branch.is-interactive{pointer-events:none}.mindmap__branch-hitarea{stroke:#0000;stroke-width:24px;pointer-events:stroke;cursor:pointer}.mindmap__branch-group:hover .branch.is-interactive,.mindmap__branch-group:focus-visible .branch.is-interactive{opacity:1;filter:saturate(1.04)}.node{stroke:var(--branch-color);stroke-width:var(--node-stroke-width,2px);fill:color-mix(in srgb, var(--branch-color) 18%, white);transition:transform .16s,fill .16s,stroke .16s}.node--root{fill:#1f2a37f0;stroke:#1f2a37f0}.label{fill:var(--ink-strong);font-size:var(--label-size,15px);letter-spacing:-.02em;paint-order:stroke;stroke:#fffcf7d9;stroke-width:8px;stroke-linejoin:round;pointer-events:none;font-weight:600}.label.level-1{font-size:var(--label-size-main,17px);font-weight:700}.label.level-3,.label.level-4{font-size:var(--label-size-small,14px)}.mindmap-link{cursor:pointer}.mindmap-link-icon{opacity:1}.mindmap-link-icon circle{fill:#ffffffeb;stroke:color-mix(in srgb, var(--branch-color) 72%, white);stroke-width:1px}.mindmap-link-icon path{fill:none;stroke:var(--branch-color);stroke-width:1px;stroke-linecap:round;stroke-linejoin:round}.mindmap-link:hover .mindmap-link-icon,.mindmap-link:focus-visible .mindmap-link-icon{opacity:.82}.node--root+.label{fill:#fff;stroke:#0000;font-family:var(--font-display);letter-spacing:-.04em;font-size:clamp(1.1rem,1.6vw,1.5rem);font-weight:700}.mindmap__node-group{outline:none}.mindmap__node-group.is-entering,.mindmap__node-group.is-exiting{will-change:transform, opacity}.mindmap__node-group.is-exiting{pointer-events:none}.mindmap__node-group.is-interactive{cursor:pointer}.mindmap__node-group.is-interactive:hover .node,.mindmap__node-group.is-interactive:focus-visible .node{fill:color-mix(in srgb, var(--branch-color) 28%, white)}.mindmap__node-group.is-interactive:hover .label,.mindmap__node-group.is-interactive:focus-visible .label{fill:color-mix(in srgb, var(--branch-color) 65%, #0f172a)}.mindmap__node-group.is-interactive:focus-visible .node{stroke-width:calc(var(--node-stroke-width,2px) + 1px)}.mindmap__node-group.is-collapsed .node:not(.node--root){fill:color-mix(in srgb, var(--branch-color) 12%, white)}.mindmap__toggle-ring{fill:#ffffffe0;stroke:var(--branch-color);stroke-width:1px}.mindmap__toggle-icon{fill:none;stroke:var(--branch-color);stroke-width:1px;stroke-linecap:round}@media (width<=900px){.mindmap__viewport{border-radius:0;min-height:100svh}.mindmap__meta{justify-content:flex-start}}@media (width<=640px){.mindmap__controls{gap:.4rem;top:.75rem;right:.75rem}.mindmap__reset-view{min-width:7.5rem;padding:.72rem .9rem;font-size:.88rem;bottom:.75rem;right:.75rem}.mindmap__control-button{border-radius:.8rem;width:2.5rem;height:2.5rem;font-size:1.25rem}.mindmap__hint{font-size:.82rem}.label{--label-size:14px;--label-size-main:16px;--label-size-small:13px}}
