*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#1a1a2e;color:#e0e0e0}#app{display:flex;flex-direction:column;height:100vh}header{padding:1rem;background:#16213e;border-bottom:1px solid #0f3460}main{display:flex;flex:1;overflow:hidden}#controls{width:280px;padding:1rem;background:#16213e;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;scrollbar-width:thin;scrollbar-color:#0f3460 transparent}#controls::-webkit-scrollbar{width:6px}#controls::-webkit-scrollbar-track{background:transparent}#controls::-webkit-scrollbar-thumb{background:#0f3460;border-radius:3px}#controls::-webkit-scrollbar-thumb:hover{background:#1a4a80}.control-group{display:flex;flex-direction:column;gap:.25rem}.control-group label{font-size:.85rem;color:#b0b0c4}.control-group input[type=text],.control-group input[type=number]{background:#0f0f23;border:1px solid #0f3460;border-radius:4px;color:#e0e0e0;padding:.5rem;font-family:monospace;font-size:.95rem}.control-group input:focus{outline:none;border-color:#e94560}.input-error{border-color:#f44!important;background:#2a0f0f!important}.input-hint{font-size:.7rem;color:#e0e0e0;font-family:monospace;line-height:1.3}.mode-toggle{display:flex;gap:0;border-radius:4px;overflow:hidden;border:1px solid #0f3460}.mode-btn{flex:1;padding:.4rem .5rem;font-size:.85rem;background:#0f0f23;color:#b0b0c4;border:none;cursor:pointer}.mode-btn.active{background:#e94560;color:#fff}#field-controls,#solution-controls{display:flex;flex-direction:column;gap:.75rem}#solve-btn{background:#e94560;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.95rem;cursor:pointer;margin-top:.5rem}#solve-btn:hover{background:#c73650}#curves-panel{margin-top:.5rem;border-top:1px solid #0f3460;padding-top:.5rem}.curves-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.curves-header span{font-size:.85rem;color:#b0b0c4}#clear-curves-btn{background:none;border:1px solid #0f3460;border-radius:3px;color:#b0b0c4;font-size:.75rem;padding:.15rem .4rem;cursor:pointer}#clear-curves-btn:hover{color:#e94560;border-color:#e94560}.curve-option{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:#b0b0c4;cursor:pointer;margin-bottom:.3rem}.curve-option input[type=checkbox]{accent-color:#e94560}#add-curve-row{display:flex;gap:.3rem;margin-bottom:.4rem}#add-curve-row input{flex:1;min-width:0;background:#0f0f23;border:1px solid #0f3460;border-radius:4px;color:#e0e0e0;padding:.35rem .4rem;font-family:monospace;font-size:.8rem}#add-curve-row input:focus{outline:none;border-color:#e94560}#add-curve-btn{background:#0f3460;color:silver;border:none;border-radius:4px;padding:.35rem .5rem;font-size:.75rem;cursor:pointer;white-space:nowrap}#add-curve-btn:hover{background:#1a4a80;color:#fff}#curves-list{display:flex;flex-direction:column;gap:.25rem;max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#0f3460 transparent}#curves-list::-webkit-scrollbar{width:6px}#curves-list::-webkit-scrollbar-track{background:transparent}#curves-list::-webkit-scrollbar-thumb{background:#0f3460;border-radius:3px}#curves-list::-webkit-scrollbar-thumb:hover{background:#1a4a80}.curve-item{display:flex;align-items:center;gap:.4rem;padding:.25rem .4rem;background:#0f0f23;border-radius:3px;font-size:.8rem;font-family:monospace}.curve-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}.curve-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:silver}.curve-remove{background:none;border:none;color:#909090;cursor:pointer;font-size:.9rem;padding:0 .2rem;line-height:1}.curve-remove:hover{color:#e94560}#viewport{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem}#plot{width:100%;height:100%;background:#0f0f23;border:1px solid #0f3460;border-radius:4px;cursor:crosshair}
