#svg-container{position:fixed;border:2px solid #ccc;margin:20px auto;padding:10px;background:rgba(0,0,0,0);--plot-top: 100px;width:min(100vw - 40px,(100vh - 40px)*1.4285714);height:calc(100vh - 40px);max-width:calc((100vh - 40px)*1.4285714);max-height:calc(100vh - 40px)}#svg-container>svg{position:absolute;left:10px;top:10px;max-height:calc(100% - 20px);max-width:calc(100% - 20px)}.plot-layout{position:absolute;top:var(--plot-top, 120px);left:10px;right:10px;bottom:0;display:flex;gap:16px;align-items:flex-start;z-index:1000;pointer-events:none}.plot-layout>*{pointer-events:auto}.plot-column{flex:1 1 auto;min-width:0;width:100%;display:flex;flex-direction:column;gap:0;align-self:stretch;margin:0}.plotly-container{flex:1;min-height:0;background:rgba(0,0,0,0) !important;border-radius:14px;box-shadow:none;padding:0;overflow:hidden}#plotly-root,#plotly-root .js-plotly-plot,#plotly-root .plot-container,#plotly-root .svg-container,#plotly-root .main-svg{background:rgba(0,0,0,0) !important}#plotly-root{width:100%;height:100%}.plotly-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:#555;font-size:1rem;font-weight:500}.landing-summary{background:hsla(0,0%,100%,.95);border-radius:10px;padding:6px 12px;margin:0;font-size:.95rem;color:#0b2240;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,.08)}.slider-stack{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1 1 auto;pointer-events:auto;max-width:1100px;margin-left:auto;margin-right:auto;text-align:center}.slider-stack .control-bar{justify-content:center}.slider-stack .slider-group{flex:0 0 auto}.mode-buttons{display:flex;gap:8px;justify-content:center;pointer-events:auto;position:fixed;top:8px;left:50%;z-index:1100}body{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;height:100vh;background-color:rgba(0,0,0,0);width:100%;font-family:sans-serif;font-weight:400;font-size:18px;margin-top:10px;overflow:hidden;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.button-container{display:flex;margin-top:10px;justify-content:flex-start}.button-container .btn{margin-right:10px}.timer-display{font-size:24px;margin-bottom:10px;text-align:center;width:150px}.icon-container{position:absolute;top:10px;left:20px;right:20px;display:flex;flex-direction:row;align-items:flex-start;justify-content:flex-start;gap:20px;flex-wrap:wrap;z-index:1001;pointer-events:none}.button-column{width:auto;pointer-events:auto}#control-bar{flex:1;width:100%;min-width:0;margin:0;align-self:flex-start}.control-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;pointer-events:auto;margin:0;width:100%}.control-bar.slider-controls>.slider-group{flex:1 1 320px;min-width:320px;max-width:640px;display:flex;align-items:center;gap:6px;padding:8px;background-color:#fff;border-radius:4px;order:1}@media(max-width: 520px){.control-bar.slider-controls>.slider-group{flex-basis:100%;min-width:100%;max-width:100%}}.control-group{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:6px;order:0}.control-group--select{flex:0 0 auto;min-width:200px}.control-group--select select{width:100%;max-width:180px;font-size:1rem;padding:6px 8px}.control-bar.slider-controls .slider-group label{font-size:.95rem;font-weight:400;white-space:nowrap;color:#000}.control-bar.slider-controls .slider-group input[type=range]{flex:1 1 auto;min-width:0;max-width:none;width:100% !important;-webkit-appearance:none;appearance:none;background:rgba(0,0,0,0);margin:0}.control-bar.slider-controls input[type=range]::-webkit-slider-runnable-track{height:4px;background:#a9a9a9;border-radius:2px}.control-bar.slider-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#90ee90;border-radius:50%;border:.5px solid #333;margin-top:-6px;cursor:pointer}.control-bar.slider-controls input[type=range]::-moz-range-track{height:4px;background:#a9a9a9;border-radius:2px}.control-bar.slider-controls input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#90ee90;border-radius:50%;border:.5px solid #333;cursor:pointer}.control-bar.slider-controls .slider-group span{display:inline-block;min-width:32px;text-align:center;font-size:.95rem;font-weight:400;color:#000}.slider-value-container{min-width:40px;text-align:center}.slider-value{font-weight:600;font-size:.95rem;color:#000}.slider-group--height label,.slider-group--height .math-label,.slider-value--height,.slider-group--radius label,.slider-group--radius .math-label,.slider-value--radius,.slider-group--x label,.slider-value--x,.slider-group--y label,.slider-value--y{color:#000}.radio-group{flex:0 0 auto;min-width:0;display:flex;flex-direction:column;gap:6px;order:10;margin-left:auto}.radio-group .radio-label{font-size:1.05rem;font-weight:500;text-transform:capitalize}.radio-group .radio-options{display:flex;gap:12px;flex-wrap:wrap;font-size:1.05rem}.radio-group label{font-size:1.05rem;font-weight:400;display:flex;align-items:center;gap:4px;margin:0;text-transform:lowercase}.slider-checkbox{display:flex;align-items:center;gap:8px;font-weight:400;font-size:1.05rem;white-space:nowrap;pointer-events:auto}.slider-checkbox--stacked{margin-top:8px;width:100%;background:hsla(0,0%,100%,.95);border-radius:10px;padding:8px 10px;box-shadow:0 4px 12px rgba(0,0,0,.12);justify-content:flex-start}.slider-checkbox--stacked span{text-align:center;display:inline-block;width:100%}.math-label{font-style:italic;font-weight:600}.math-label sub{font-size:.75em}.math-label sup{font-size:.7em}#curve-tooltip{position:absolute;pointer-events:none;background:#fff;border:2px solid #1f1f1f;border-radius:4px;padding:4px 8px;font-size:13px;font-weight:600;color:#111;opacity:0;transition:opacity 120ms ease-in-out;box-shadow:0 2px 8px rgba(0,0,0,.2);z-index:1500}#curve-tooltip.curve-tooltip--visible{opacity:1}#lengthValue,#elevationValue{width:30px}.icon-container>*{align-self:flex-start;pointer-events:auto}.icon-container .form{position:absolute;top:0;left:100px;display:flex;flex-direction:column;gap:4px;width:242px;margin:0;padding:0;z-index:1002}.icon-container .form label.form-label{margin-bottom:2px;line-height:1.2}.icon-container .form .form-select{width:100%}.weight-control{position:relative;z-index:1003;display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 12px;align-self:stretch;width:100%;max-width:220px;background-color:hsla(0,0%,100%,.9);border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);pointer-events:auto;transition:opacity 150ms ease-in-out;font-size:15px}.weight-control--hidden{display:none}.weight-control__label{margin:0;font-size:15px;font-weight:400;text-align:center;line-height:1.2}.weight-control__stepper{display:flex;align-items:center;gap:12px;font-size:15px}.weight-control__step{width:36px;height:32px;border:1px solid #888;border-radius:8px;background-color:#f5f5f5;font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background-color 120ms ease-in-out,transform 120ms ease-in-out}.weight-control__step:hover{background-color:#e0e0e0}.weight-control__step:active{transform:translateY(1px)}.weight-control__value{min-width:80px;text-align:center;font-size:15px;font-weight:700}.weight-control__inject{width:100%;border:none;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:400;color:#fff;background-color:#228b22;cursor:pointer;box-shadow:0 3px 6px rgba(0,0,0,.2);transition:background-color 120ms ease-in-out,transform 120ms ease-in-out,box-shadow 120ms ease-in-out}.weight-control__inject:hover{background-color:#1a6e1a;box-shadow:0 4px 10px rgba(0,0,0,.25)}.weight-control__inject:active{transform:translateY(1px)}.weight-control__inject--disabled{background-color:#e1e1e1;color:#666;cursor:default;box-shadow:none;pointer-events:none}@media(max-width: 600px){body{padding:10px}.button-container{width:100%;flex-direction:column;align-items:center}.button{width:80%;margin:10px 0}.slider-container{grid-template-columns:1fr;grid-gap:15px}.canvas{width:100%}}svg text{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}
