*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1a1a1a;--bg-secondary: #252525;--bg-tertiary: #303030;--canvas-bg: #1a1a1a;--accent-primary: #00d4ff;--accent-secondary: #0099ff;--accent-warning: #ffaa00;--text-primary: #f5f5f5;--text-secondary: #d0d0d0;--text-dim: #a0a0a0;--border-color: #404040;--separator-color: #00d4ff}:root[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--canvas-bg: #d8d8d8;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-dim: #777777;--border-color: #d0d0d0;--separator-color: #00aacc}@media(prefers-color-scheme:light){:root:not([data-theme]){--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--canvas-bg: #d8d8d8;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-dim: #777777;--border-color: #d0d0d0;--separator-color: #00aacc}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden;line-height:1.6}#app{display:flex;height:100vh;width:100vw}.resizer{position:relative;background:var(--separator-color);opacity:.3;transition:opacity .2s ease;z-index:100}.resizer:hover{opacity:.8}.resizer.resizing{opacity:1}.resizer-horizontal{cursor:ew-resize;width:4px;min-width:4px}.resizer-vertical{cursor:ns-resize;height:4px;min-height:4px}#controls{width:320px;min-width:250px;max-width:600px;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:1.5rem;overflow-y:auto;box-shadow:2px 0 10px #00000080}#controls::-webkit-scrollbar{width:8px}#controls::-webkit-scrollbar-track{background:var(--bg-primary)}#controls::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}#controls::-webkit-scrollbar-thumb:hover{background:#555}.header{margin-bottom:2rem;text-align:center;position:relative}#theme-toggle{position:absolute;top:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border-color);width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;transition:all .3s ease;padding:0}#theme-toggle:hover{background:var(--accent-primary);color:var(--bg-primary);transform:rotate(180deg) scale(1.1)}.header-links{display:flex;justify-content:center;align-items:center;gap:.7rem;margin-top:.8rem}.header-link,#restart-tutorial-btn{display:flex;align-items:center;justify-content:center;padding:.4rem;border-radius:4px;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;border:1px solid transparent;width:34px;height:34px;cursor:pointer;background:none;box-shadow:none;outline:none;font-family:inherit}.header-link:hover,#restart-tutorial-btn:hover{color:var(--accent-primary);background:var(--bg-tertiary);border-color:var(--border-color);transform:translateY(-1px)}.header-link svg,.header-link img,#restart-tutorial-btn svg{flex-shrink:0;display:block}.header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.header .subtitle{color:var(--text-secondary);font-size:.9rem;font-weight:300}.control-group{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.control-group:last-child{border-bottom:none}.control-group h3{font-size:.9rem;margin-bottom:.7rem;color:var(--accent-primary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.control-group h4{font-size:.85rem;color:var(--accent-primary);margin-top:.75rem;margin-bottom:.4rem;font-weight:500;display:flex;align-items:center;gap:.4rem}.info-tooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:.95rem;height:.95rem;border-radius:50%;background:transparent;border:1px solid var(--text-dim);color:var(--text-dim);font-size:.6rem;font-weight:600;cursor:help;transition:all .2s ease;flex-shrink:0}.info-tooltip:hover{background:var(--text-dim);color:var(--bg-primary);transform:scale(1.15)}.floating-tooltip{position:fixed;background:var(--bg-tertiary);border:1px solid var(--border-color);padding:.5rem .7rem;border-radius:4px;font-size:.75rem;font-weight:400;color:var(--text-secondary);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10000;box-shadow:0 2px 8px #0000004d}.floating-tooltip.show{opacity:1}.config-icon-btn{position:relative}.config-icon-btn svg{display:block;transition:all .2s ease}.config-icon-btn:hover svg{transform:scale(1.1)}button{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;margin:.25rem 0;width:100%;transition:all .2s ease;box-shadow:0 2px 4px #0003}button:hover{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 8px #00d4ff4d}button:active{transform:translateY(0);box-shadow:0 1px 2px #0000004d}button:disabled{background:var(--border-color);cursor:not-allowed;transform:none;opacity:.5}.btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--accent-secondary);color:var(--bg-primary);border-color:var(--accent-secondary)}input[type=number],select{width:100%;padding:.5rem .7rem;margin:.25rem 0;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;font-size:.85rem;font-family:inherit;transition:all .15s ease}input[type=number]:focus,select:focus{outline:none;border-color:var(--accent-primary);background-color:#00d4ff0d}input[type=number].invalid{border-color:#f44;background-color:#ff44441a}input[type=number].invalid:focus{border-color:#f44;background-color:#ff444426}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2300d4ff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;padding-right:2rem}select:hover{border-color:var(--accent-primary);background-color:#00d4ff08}.input-row{display:flex;gap:.5rem;margin-top:.4rem;margin-bottom:.4rem}.input-col{flex:1;display:flex;flex-direction:column}.input-label{font-size:.75rem!important;color:var(--text-dim)!important;margin:0 0 .2rem!important;font-weight:500!important}.input-compact{padding:.4rem .5rem!important;font-size:.85rem!important;text-align:center}input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--border-color);border-radius:4px;position:relative;transition:all .2s ease}input[type=checkbox]:checked{background-color:var(--accent-primary);border-color:var(--accent-primary)}input[type=checkbox]:checked:after{content:"✓";position:absolute;color:var(--bg-primary);font-size:14px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}label{display:block;margin-top:.5rem;margin-bottom:.2rem;font-size:.8rem;color:var(--text-secondary);font-weight:400}#main-content{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary)}#canvas-container{flex:2;min-height:300px;position:relative;background:var(--canvas-bg)}#three-canvas{width:100%;height:100%;display:block}#stats-overlay{position:absolute;top:12px;right:12px;background:var(--bg-secondary);border:1px solid var(--border-color);padding:.4rem .6rem;border-radius:4px;font-family:Courier New,monospace;font-size:.7rem;color:var(--text-secondary);box-shadow:0 2px 4px #00000026;z-index:10}.stat-item{margin:.15rem 0;line-height:1.2}#canvas-controls{position:absolute;bottom:16px;left:16px;display:flex;gap:.5rem;z-index:10}.canvas-btn{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:.525rem .7rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:2.8rem;width:2.8rem;height:2.8rem;display:flex;align-items:center;justify-content:center}.canvas-btn:hover{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 8px #00d4ff66}.canvas-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000004d}.canvas-btn-icon{background:var(--accent-warning);color:var(--bg-primary)}.canvas-btn-icon:hover{background:var(--accent-warning);opacity:.9}#help-overlay{position:absolute;bottom:16px;right:16px;z-index:10}#help-toggle{width:2rem;height:2rem;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);font-size:.85rem;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0003;padding:0}#help-toggle:hover{background:var(--accent-primary);color:var(--bg-primary);transform:scale(1.1)}.help-content{position:absolute;bottom:100%;right:0;margin-bottom:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);padding:.75rem;border-radius:6px;min-width:220px;box-shadow:0 4px 8px #0003;opacity:0;pointer-events:none;transform:translateY(10px);transition:all .2s ease}#help-overlay:hover .help-content{opacity:1;pointer-events:auto;transform:translateY(0)}.help-content h3{font-size:.85rem;color:var(--text-primary);margin-bottom:.5rem}.help-content ul{list-style:none;font-size:.75rem;line-height:1.4;color:var(--text-primary)}.help-content li{margin-bottom:.3rem;color:var(--text-primary)}.help-content strong{color:var(--text-primary);font-weight:600}#plots-container{flex:1;min-height:200px;display:flex;gap:1rem;padding:1rem;background-color:var(--bg-secondary)}.plot{flex:1;background-color:var(--bg-tertiary);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000004d;border:1px solid var(--border-color)}#loading-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,var(--bg-primary) 0%,#1a1a2e 100%);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:1;transition:opacity .5s ease;pointer-events:none}#loading-screen.hidden{opacity:0}.loading-content{text-align:center}.spinner{width:60px;height:60px;border:4px solid rgba(0,255,136,.1);border-top:4px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body.resizing{-webkit-user-select:none;user-select:none}#notification-banner{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-100px);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:500;box-shadow:0 4px 12px #0000004d;z-index:1000;opacity:0;transition:all .3s ease;pointer-events:none}#notification-banner.show{transform:translate(-50%) translateY(0);opacity:1}.loading-content h2{color:var(--accent-primary);margin-bottom:.5rem;font-size:1.5rem}.loading-content p{color:var(--text-secondary);font-size:.9rem}#status-display{background:var(--bg-tertiary);padding:1rem;border-radius:6px;border:1px solid var(--border-color)}#status-display div{margin:.3rem 0;color:var(--text-secondary)}#status-display span{color:var(--accent-primary);font-weight:600}@media(max-width:900px){#controls{width:280px}#help-overlay{display:none}}@media(max-width:768px){#app{flex-direction:column}#controls{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-color)}#canvas-container{min-height:300px}#plots-container{min-height:200px;overflow-x:auto}}.preset-description{font-size:.75rem;color:var(--text-dim);margin-top:.4rem;line-height:1.4;font-style:italic}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.control-group{animation:fadeIn .3s ease forwards}body.loaded #loading-screen{display:none}#onboarding-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000040;z-index:20000;display:none;pointer-events:none}#onboarding-overlay.show{display:block}.onboarding-spotlight{position:absolute;border:3px solid var(--accent-primary);border-radius:8px;box-shadow:0 0 0 9999px #00000040,0 0 20px var(--accent-primary);pointer-events:none;transition:all .5s ease;z-index:20001}.onboarding-arrow{position:absolute;font-size:3rem;color:var(--accent-primary);z-index:20002;pointer-events:none;filter:drop-shadow(0 0 10px var(--accent-primary))}.onboarding-arrow.left{animation:oscillateLeft 1.5s ease-in-out infinite}.onboarding-arrow.down{animation:oscillateDown 1.5s ease-in-out infinite}@keyframes oscillateLeft{0%,to{transform:translate(0)}50%{transform:translate(-15px)}}@keyframes oscillateDown{0%,to{transform:translateY(0)}50%{transform:translateY(15px)}}.onboarding-tooltip{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);border:2px solid var(--accent-primary);color:var(--text-primary);padding:1.25rem 1.75rem;border-radius:12px;font-size:1rem;max-width:320px;min-width:280px;z-index:20003;pointer-events:auto;box-shadow:0 4px 12px #00d4ff4d;display:flex;flex-direction:column;gap:.75rem}.onboarding-tooltip h3{margin:0;color:var(--accent-primary);font-size:1.25rem;text-align:center}.onboarding-tooltip p{margin:0;line-height:1.5;color:var(--text-secondary);font-size:1rem}.onboarding-skip{background:transparent;border:1px solid var(--border-color);color:var(--text-dim);padding:.5rem 1rem;cursor:pointer;font-size:.9rem;pointer-events:auto;transition:all .2s ease;border-radius:6px;margin-top:.5rem;align-self:center}.onboarding-skip:hover{color:var(--text-primary);border-color:var(--text-dim);background:#ffffff0d}
