*,:before,:after{box-sizing:border-box}:root{--bg-color:#0f172a;--sidebar-bg:#1e293b;--panel-bg:#334155;--panel-bg-hover:#475569;--border-color:#334155;--border-light:#475569;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-color:#3b82f6;--accent-hover:#60a5fa;--accent-glow:#3b82f680;--danger-color:#ef4444;--success-color:#10b981;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--font-family:"Inter", system-ui, -apple-system, sans-serif;font-family:var(--font-family);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}a{color:var(--accent-color);font-weight:500;text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}html,body{height:100%}body{background-color:var(--bg-color);min-width:320px;margin:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:var(--radius-md);background-color:var(--panel-bg);color:var(--text-primary);cursor:pointer;border:1px solid #0000;padding:.6em 1.2em;font-family:inherit;font-size:.95em;font-weight:500;transition:all .2s}button:hover{background-color:var(--panel-bg-hover);border-color:var(--border-light)}button:focus,button:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f666}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-color:var(--panel-bg);border-radius:var(--radius-lg);border:2px solid var(--bg-color)}::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}.spline-editor{flex-direction:column;gap:0;height:100%;display:flex}.se-toolbar{background:var(--panel-bg,#1e1e2e);border-bottom:1px solid #ffffff14;flex-wrap:wrap;align-items:center;gap:16px;padding:8px 12px;display:flex}.se-glyph-picker,.se-curve-picker{align-items:center;gap:6px;display:flex}.se-options{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.se-glyph-picker label,.se-curve-picker label,.se-iter{color:var(--text-secondary,#aaa);font-size:.85em}.se-glyph-picker select{background:var(--sidebar-bg,#252535);color:var(--text-primary,#eee);border-radius:var(--radius-sm,4px);border:1px solid #ffffff1f;padding:3px 8px;font-size:1em}.se-curve-btn{background:var(--sidebar-bg,#252535);color:var(--text-secondary,#aaa);border-radius:var(--radius-sm,4px);cursor:pointer;border:1px solid #ffffff1f;padding:2px 8px;font-size:.85em}.se-curve-btn.active{background:var(--accent-color,#3b82f6);color:#fff;border-color:var(--accent-color,#3b82f6)}.se-toggle{color:var(--text-secondary,#aaa);cursor:pointer;align-items:center;gap:4px;font-size:.85em;display:flex}.se-toggle input[type=checkbox]{accent-color:var(--accent-color,#3b82f6)}.se-iter input{background:var(--sidebar-bg,#252535);width:60px;color:var(--text-primary,#eee);border-radius:var(--radius-sm,4px);border:1px solid #ffffff1f;margin-left:4px;padding:2px 6px;font-size:.85em}.se-main{flex:1;min-height:0;display:flex;overflow:hidden}.se-canvas-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.se-canvas{background:var(--bg-color,#0f0f1a);cursor:crosshair;touch-action:none;flex:1;min-width:0;min-height:0}.se-table-panel{background:var(--panel-bg,#1e1e2e);border-left:1px solid #ffffff14;flex-direction:column;width:480px;min-width:340px;display:flex;overflow:hidden}.se-table-header{color:var(--text-primary,#eee);border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.9em;font-weight:600;display:flex}.se-btn-sm{background:var(--accent-color,#3b82f6);color:#fff;border-radius:var(--radius-sm,4px);cursor:pointer;border:none;padding:3px 10px;font-size:.8em}.se-btn-sm:hover{background:var(--accent-hover,#2563eb)}.se-table-scroll{flex:1;min-height:0;overflow:auto}.se-table{border-collapse:collapse;width:100%;font-size:.8em}.se-table th{background:var(--panel-bg,#1e1e2e);color:var(--text-muted,#888);text-align:left;z-index:1;border-bottom:1px solid #ffffff1a;padding:4px 6px;font-weight:500;position:sticky;top:0}.se-table td{color:var(--text-primary,#eee);border-bottom:1px solid #ffffff0a;padding:2px 4px}.se-table tr:hover{background:#ffffff08}.se-table tr.selected{background:#3b82f626}.se-table input[type=number]{width:55px;color:var(--text-primary,#eee);font-family:inherit;font-size:inherit;background:0 0;border:1px solid #0000;border-radius:3px;padding:1px 4px}.se-table input[type=number]:focus{background:var(--sidebar-bg,#252535);border-color:var(--accent-color,#3b82f6);outline:none}.se-table select{color:var(--text-primary,#eee);font-size:inherit;background:0 0;border:1px solid #0000;border-radius:3px;padding:1px 2px}.se-table select:focus{background:var(--sidebar-bg,#252535);border-color:var(--accent-color,#3b82f6);outline:none}.se-idx{color:var(--text-muted,#888);width:20px;font-size:.9em}.se-btn-del{color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.1em;line-height:1}.se-btn-del:hover{color:var(--danger-color,#ef4444)}.se-bezier-output{border-top:1px solid #ffffff14;padding:0}.se-bezier-output summary{color:var(--text-secondary,#aaa);cursor:pointer;padding:8px 12px;font-size:.85em}.se-bezier-output .se-table-scroll{max-height:200px}.se-table-readonly td{color:var(--text-muted,#888);font-variant-numeric:tabular-nums}.se-canvas path{vector-effect:non-scaling-stroke}.se-drag-handle-th{width:14px;padding:0 2px}.se-drag-handle{cursor:grab;color:var(--text-muted,#666);text-align:center;-webkit-user-select:none;user-select:none;touch-action:none;padding:0 4px;font-size:1em}.se-drag-handle:hover{color:var(--text-primary,#eee)}.se-drag-over{outline:1px solid var(--accent-color,#3b82f6);background:#3b82f640!important}.se-auto-cell-td{white-space:nowrap;padding:1px 2px}.se-auto-cell{align-items:center;gap:2px;display:flex}.se-auto-cell input[type=number]{flex:1;width:58px;min-width:50px}.se-auto-btn{color:var(--text-secondary,#aaa);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff47;border-radius:3px;flex-shrink:0;padding:0 4px;font-size:.75em;line-height:1.4}.se-auto-btn:hover:not(:disabled){color:var(--accent-color,#3b82f6);border-color:var(--accent-color,#3b82f6);background:#3b82f61f}.se-auto-btn:disabled{opacity:.25;cursor:default}.se-preset-select{background:var(--sidebar-bg,#252535);color:var(--text-primary,#eee);cursor:pointer;border:1px solid #ffffff47;border-radius:3px;flex-shrink:0;width:34px;padding:0 2px;font-size:.8em}.se-auto-active{color:#7eb8ff;cursor:pointer;text-align:center;background:#3b82f633;border:1px solid #63a0ffb3;border-radius:3px;width:100%;padding:1px 5px;font-size:.75em;font-weight:600}.se-auto-active:hover{border-color:var(--accent-color,#3b82f6);color:#fff;background:#3b82f659}.se-label-input{width:42px;color:var(--text-secondary,#aaa);font-family:inherit;font-size:inherit;background:0 0;border:1px solid #0000;border-radius:3px;padding:1px 3px}.se-label-input:focus{background:var(--sidebar-bg,#252535);border-color:var(--accent-color,#3b82f6);color:var(--text-primary,#eee);outline:none}.se-label-input::placeholder{color:var(--text-muted,#555)}.se-undo-btns{gap:3px;display:flex}.se-undo-btns .se-btn-sm{padding:3px 7px}.se-undo-btns .se-btn-sm:disabled{opacity:.35;cursor:default;background:var(--sidebar-bg,#252535);color:var(--text-muted,#888);border:1px solid #ffffff1a}.se-curvature-graph{background:var(--panel-bg,#1e1e2e);border-top:1px solid #ffffff14;flex-shrink:0;width:100%;height:80px;display:block}@media (width<=700px){.se-main{flex-direction:column}.se-canvas-area{flex:1 1 0;min-height:0}.se-table-panel{border-top:1px solid #ffffff14;border-left:none;flex:none;width:100%;min-width:0;max-height:40vh}}#root{text-align:center;width:100%;height:100%;margin:0;padding:0;overflow:hidden}.container{background-color:var(--bg-color);flex-direction:row;gap:0;width:100%;height:100%;display:flex;position:relative}.sidebar{border-right:1px solid var(--border-color);text-align:left;background:var(--sidebar-bg);width:auto;min-width:280px;max-width:400px;height:100%;color:var(--text-primary);flex:none;padding:24px;overflow-y:auto}.sidebar-title{filter:invert();opacity:.9;width:100%;margin-bottom:-10px}.sidebar h2{color:var(--text-primary);margin-top:0;margin-bottom:24px;font-size:1.25rem;font-weight:600}.controls-list{flex-direction:column;gap:16px;display:flex}.category-group{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#ffffff08;padding:12px}.category-header{cursor:pointer;color:var(--text-primary);-webkit-user-select:none;user-select:none;align-items:center;margin-bottom:12px;font-weight:600;transition:color .2s;display:flex}.category-header:hover{color:var(--accent-hover)}.category-content{flex-direction:column;gap:16px;display:flex}.control-group{flex-direction:column;align-items:flex-start;font-size:.85rem;display:flex}.control-group label{text-align:left;width:100%;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.control-input{justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.value-display{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:36px;font-size:.85em}.slider-container{flex-shrink:1;align-items:center;width:100%;display:flex}.range-wrapper{align-items:center;width:100%;height:24px;display:flex;position:relative}.modern-slider{appearance:none;z-index:2;cursor:pointer;background:0 0;width:100%;margin:0;position:relative}.modern-slider:focus{outline:none}.modern-slider::-webkit-slider-runnable-track{background:var(--panel-bg-hover);border:none;border-radius:3px;width:100%;height:6px}.modern-slider::-webkit-slider-thumb{-webkit-appearance:none;border:2px solid var(--accent-color);background:#fff;border-radius:50%;width:16px;height:16px;margin-top:-5px;transition:transform .1s;box-shadow:0 1px 3px #0000004d}.modern-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider-track-fill{background:var(--accent-color);z-index:1;pointer-events:none;border-radius:3px;height:6px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.toggle-switch{cursor:pointer;display:inline-block}.toggle-switch input{appearance:none;background:var(--panel-bg-hover);cursor:pointer;border-radius:20px;outline:none;width:36px;height:20px;margin:0;transition:background .3s;position:relative}.toggle-switch input:checked{background:var(--success-color)}.toggle-switch input:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.toggle-switch input:checked:after{transform:translate(16px)}.main{scrollbar-gutter:stable;flex-direction:column;flex:1;gap:20px;height:100%;padding:24px;display:flex;overflow-y:auto}.input-area{align-items:stretch;gap:16px;display:flex;position:relative}.input-wrapper{flex:1;position:relative}.input-area.with-defs .input-wrapper{flex:0 0 50%;width:50%}.input-area textarea{box-sizing:border-box;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--panel-bg);width:100%;height:100%;color:var(--text-primary);resize:vertical;padding:16px;font-size:2em;transition:border-color .2s,box-shadow .2s}.input-area textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.glyph-defs-panel{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);width:50%;color:var(--text-secondary);box-sizing:border-box;white-space:pre-wrap;height:auto;max-height:200px;padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em;overflow-y:auto}.glyph-defs-panel h3{color:var(--text-primary);border-bottom:1px solid var(--border-light);justify-content:space-between;margin-top:0;margin-bottom:.75em;padding-bottom:8px;font-size:1em;display:flex}.text-reset-button{border-radius:var(--radius-sm);color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;border:none;justify-content:center;align-items:center;padding:6px;display:flex;position:absolute;top:8px;right:8px}.text-reset-button:hover{background:#0009}.preview{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.preview-content{flex:1;padding:10px;position:relative;overflow:auto}.zoom-controls{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);z-index:10;background:#1e293bd9;border:1px solid #ffffff26;gap:4px;padding:6px;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 4px 12px #0000004d}.zoom-controls button{border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex}.zoom-controls button:hover{background:#ffffff1a}.svg-container{justify-content:center;width:100%;min-height:100%;display:flex}.svg-container svg{width:100%;height:auto;display:block}.top-bar{justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.tabs{background:var(--sidebar-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:4px;display:flex}.tab-button{cursor:pointer;border-radius:var(--radius-md);color:var(--text-secondary);background:0 0;border:none;padding:8px 16px;font-size:.95rem;font-weight:500;transition:all .2s}.tab-button:hover{color:var(--text-primary)}.tab-button.active{background:var(--panel-bg);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.proof-chips{align-items:center;gap:6px;margin-left:12px;display:flex}.proof-chip{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:4px 14px;font-size:.8em;font-weight:500;transition:background .15s,color .15s,border-color .15s}.proof-chip:hover:not(.selected){background:var(--panel-bg)}.proof-chip.selected{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.diff-config{white-space:nowrap;align-items:center;gap:8px;margin-left:12px;font-size:.85em;display:flex}.diff-config select{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--panel-bg);color:var(--text-primary);padding:4px 8px;font-size:1em}.diff-config input[type=number]{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--panel-bg);width:70px;color:var(--text-primary);padding:4px 6px;font-size:1em}.diff-label-a{color:#e05252;font-weight:600}.diff-label-b{color:#5c7cfa;font-weight:600}.proof-book-title{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;align-self:center;max-width:300px;margin-left:10px;font-size:.75em;font-style:italic;overflow:hidden}.toolbar{gap:8px;display:flex}.icon-button{background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.icon-button:hover{background-color:var(--panel-bg);color:var(--text-primary);border-color:var(--border-light)}.material-symbols-outlined{font-size:20px}.tweens-grid{flex-direction:column;gap:24px;width:100%;padding:16px;display:flex;overflow-x:auto}.tween-row h4{color:#000;font-size:1.1em;font-weight:600;position:sticky;left:0}.tween-variations{gap:16px;width:max-content;display:flex}.tweens-grid::-webkit-scrollbar{height:10px}.tweens-grid::-webkit-scrollbar-track{background:var(--bg-color)}.tweens-grid::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:5px}.tween-item{border-radius:var(--radius-md);text-align:center;color:#000;background:#fff;border:1px solid #e2e8f0;min-width:160px;padding:12px;box-shadow:0 1px 2px #0000000d}.tween-item svg{width:100%;height:auto}.glyph-legend{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-md);z-index:2000;text-align:left;color:var(--text-primary);touch-action:none;background:#1e293bd9;border:1px solid #ffffff1a;flex-direction:column;gap:10px;padding:16px;font-size:.9em;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.legend-item{align-items:center;gap:10px;display:flex}.legend-item input[type=checkbox]{appearance:none;border:2px solid var(--border-light);background:var(--sidebar-bg);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:16px;height:16px;margin:0;transition:all .2s;display:flex}.legend-item input[type=checkbox]:checked{background:var(--accent-color);border-color:var(--accent-color)}.legend-item input[type=checkbox]:checked:after{content:"✓";color:#fff;font-size:10px;font-weight:700}.swatch{border-radius:3px;width:14px;height:14px;display:inline-block}.swatch.blue{background-color:#3b82f6}.swatch.green{background-color:#10b981}.swatch.orange{background-color:#f59e0b}.swatch.grey{background-color:#94a3b8}.swatch.lightBlue{background-color:#7dd3fc}.swatch.lightGreen{background-color:#6ee7b7}.swatch.circle{border-radius:50%}.hide-spiro .spiro-layer,.hide-spline2 .spline2-layer,.hide-dspline .dspline-layer,.hide-guides .guides-layer,.hide-knots .knots-layer,.hide-comb .comb-layer,.hide-tangents .tangent-layer,.hide-labels .labels-layer{display:none}.progress-bar-container{z-index:1000;background-color:#0000;width:100%;height:3px;position:absolute;top:0;left:0;overflow:hidden}.progress-bar-indeterminate{background-color:var(--accent-color);transform-origin:0%;opacity:.8;width:100%;height:100%;animation:1.5s ease-in-out infinite indeterminate}.progress-bar-determinate{background-color:var(--accent-color);height:100%;transition:width .1s linear}@keyframes indeterminate{0%{transform:translate(-100%)scaleX(.2)}50%{transform:translate(0%)scaleX(.5)}to{transform:translate(100%)scaleX(.2)}}@media (width<=768px){.sidebar{z-index:1000;border-right:1px solid var(--border-color);background:var(--sidebar-bg);width:64px;min-width:64px;padding:24px 12px;transition:width .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;position:absolute;top:0;bottom:0;left:0;overflow-x:hidden}.sidebar:hover,.sidebar:focus-within{width:300px;box-shadow:10px 0 30px #00000080}.sidebar h2,.sidebar .sidebar-title,.sidebar .category-header .category-title,.sidebar .control-group label,.sidebar .value-display,.sidebar .category-header span:not(.material-symbols-outlined){opacity:0;white-space:nowrap;pointer-events:none;transition:opacity .2s}.sidebar:hover h2,.sidebar:hover .sidebar-title,.sidebar:hover .category-header .category-title,.sidebar:hover .control-group label,.sidebar:hover .value-display,.sidebar:hover .category-header span{opacity:1;pointer-events:auto}.sidebar .category-header{justify-content:center;padding:0}.sidebar:hover .category-header{justify-content:flex-start;padding-left:0}.sidebar .material-symbols-outlined{font-size:24px}.main{margin-left:64px;padding:16px}.input-area{flex-direction:column}.input-area.with-defs .input-wrapper,.glyph-defs-panel{flex:auto;width:100%}.glyph-defs-panel{max-height:300px}.top-bar{flex-direction:column;align-items:flex-start;gap:12px}.tabs{width:100%;padding-bottom:4px;overflow-x:auto}.tab-button{white-space:nowrap;padding:8px 12px}.glyph-legend{padding:10px;font-size:.8em;bottom:16px;right:16px}.preview-content{padding:5px}.zoom-controls{top:8px;right:8px}}.preview-content.spline-mode{flex-direction:column;padding:0;display:flex;overflow:hidden}
