:root{--bg-primary:#0a0e17;--bg-secondary:#111827;--bg-surface:#111827d9;--bg-glass:#0f172abf;--border-glass:#6366f133;--border-hover:#6366f166;--accent-primary:#6366f1;--accent-primary-glow:#6366f14d;--accent-cyan:#06b6d4;--accent-cyan-glow:#06b6d44d;--accent-green:#10b981;--accent-red:#ef4444;--accent-orange:#f59e0b;--accent-pink:#ec4899;--accent-purple:#8b5cf6;--force-gravity:#ef4444;--force-normal:#3b82f6;--force-friction:#10b981;--force-parallel:#f59e0b;--force-net:#ec4899;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#a5b4fc;--panel-padding:16px;--panel-radius:16px;--gap:12px;--font-main:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}.icon{stroke-width:2px;width:20px;height:20px}.icon-sm{stroke-width:2px;vertical-align:-2px;width:14px;height:14px;display:inline-block}.icon-xs{stroke-width:2px;vertical-align:-1px;width:12px;height:12px;display:inline-block}#app{width:100%;height:100%;position:relative}#game-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}#game-container canvas{display:block;width:100%!important;height:100%!important}#ui-overlay{z-index:10;pointer-events:none;flex-direction:column;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}#ui-overlay>*{pointer-events:auto}.toast-notification{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--accent-cyan);color:#fff;z-index:9999;background:#0f172ae6;border-radius:30px;padding:10px 24px;font-size:.85rem;font-weight:500;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideDownToast;position:fixed;top:70px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #06b6d44d}@keyframes slideDownToast{0%{opacity:0;top:0}to{opacity:1;top:70px}}#top-bar{-webkit-backdrop-filter:none;backdrop-filter:none;z-index:100;pointer-events:none;background:0 0;border-bottom:none;justify-content:space-between;align-items:center;height:auto;padding:16px 24px;display:flex;position:absolute;top:0;left:0;right:0}.top-bar-left{-webkit-backdrop-filter:blur(16px);pointer-events:auto;background:#0f172abf;border:1px solid #ffffff14;border-radius:14px;align-items:center;gap:10px;padding:8px 16px;display:flex;box-shadow:0 10px 30px #0006,0 0 0 1px #6366f11a}.top-bar-left .logo{filter:drop-shadow(0 0 8px var(--accent-cyan-glow));font-size:1.4rem}.top-bar-left h1{background:linear-gradient(135deg, var(--text-primary), var(--accent-cyan));-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:.95rem;font-weight:700}.badge{background:linear-gradient(135deg, var(--accent-primary), var(--accent-cyan));color:#fff;text-transform:uppercase;letter-spacing:.1em;border-radius:20px;padding:2px 8px;font-size:.55rem;font-weight:700}.mobile-menu-toggle{color:#f1f5f9;cursor:pointer;background:0 0;border:none;padding:4px;display:none}.top-bar-center{-webkit-backdrop-filter:blur(16px);pointer-events:auto;background:#0f172abf;border:1px solid #ffffff14;border-radius:16px;align-items:center;gap:4px;padding:4px;display:flex;box-shadow:0 12px 36px #00000080,0 0 0 1px #6366f126}.nav-btn{color:var(--text-secondary);font-family:var(--font-main);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-radius:9px;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;font-weight:500;display:flex}.nav-btn:hover{color:var(--text-primary);background:#ffffff0d}.nav-btn.active{color:#fff;background:linear-gradient(135deg, var(--accent-primary), var(--accent-purple));box-shadow:0 2px 12px var(--accent-primary-glow)}.nav-btn .nav-icon{font-size:.9rem}.fps{font-family:var(--font-mono);color:var(--accent-green);background:#10b9811a;border:1px solid #10b98133;border-radius:8px;padding:3px 10px;font-size:.7rem}.glass-panel{background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-glass);border-radius:var(--panel-radius);transition:border-color var(--transition-normal);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d}.glass-panel:hover{border-color:var(--border-hover)}.panel-header{padding:12px var(--panel-padding);border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex}.panel-header h2{color:var(--text-primary);letter-spacing:-.01em;font-size:.8rem;font-weight:600}.panel-toggle{width:24px;height:24px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;justify-content:center;align-items:center;font-size:.8rem;display:flex}.panel-toggle:hover{color:var(--text-primary);background:#ffffff1a}.panel-content{padding:var(--panel-padding);max-height:calc(100vh - 180px);overflow-y:auto}.panel-content::-webkit-scrollbar{width:4px}.panel-content::-webkit-scrollbar-track{background:0 0}.panel-content::-webkit-scrollbar-thumb{background:var(--border-glass);border-radius:4px}#control-panel{z-index:20;width:280px;max-height:calc(100vh - 80px);animation:slideInRight var(--transition-slow) ease-out;position:absolute;top:64px;right:12px}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.control-group{margin-bottom:14px}.control-group:last-child{margin-bottom:0}.control-label{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.control-label span{color:var(--text-secondary);font-size:.75rem;font-weight:500}.control-value{font-family:var(--font-mono);color:var(--accent-cyan);background:#06b6d41a;border-radius:6px;padding:1px 8px;font-size:.75rem;font-weight:600}input[type=range]{appearance:none;background:linear-gradient(90deg, var(--accent-primary), var(--accent-cyan));cursor:pointer;width:100%;height:6px;transition:all var(--transition-fast);border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{appearance:none;border:2px solid var(--accent-primary);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);background:#fff;border-radius:50%;box-shadow:0 2px 8px #6366f166}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 16px #6366f199}input[type=range]::-moz-range-thumb{border:2px solid var(--accent-primary);cursor:pointer;background:#fff;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 8px #6366f166}.material-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.material-btn{color:var(--text-secondary);font-family:var(--font-main);cursor:pointer;transition:all var(--transition-fast);text-align:center;background:#ffffff08;border:1px solid #ffffff1a;border-radius:10px;padding:8px 10px;font-size:.7rem;font-weight:500}.material-btn:hover{border-color:var(--accent-primary);color:var(--text-primary);background:#6366f114}.material-btn.active{border-color:var(--accent-primary);color:#fff;box-shadow:0 2px 8px var(--accent-primary-glow);background:linear-gradient(135deg,#6366f126,#06b6d41a)}.material-btn .material-icon{margin-bottom:2px;font-size:1.1rem;display:block}.material-btn .material-mu{font-family:var(--font-mono);color:var(--text-muted);font-size:.6rem}.material-btn.active .material-mu{color:var(--accent-cyan)}.panel-actions{padding:12px var(--panel-padding);border-top:1px solid #ffffff0d;flex-wrap:wrap;gap:6px;display:flex}.action-btn{min-width:70px;font-family:var(--font-main);cursor:pointer;transition:all var(--transition-fast);letter-spacing:.01em;border:none;border-radius:10px;flex:1;padding:8px 12px;font-size:.72rem;font-weight:600}.play-btn{color:#fff;background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 12px #10b9814d}.play-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #10b98180}.pause-btn{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 12px #f59e0b4d}.pause-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #f59e0b80}.reset-btn{color:var(--accent-red);background:#ef444426;border:1px solid #ef444433}.reset-btn:hover{background:#ef444440;transform:translateY(-1px)}.step-btn{color:var(--accent-primary);background:#6366f126;border:1px solid #6366f133}.step-btn:hover{background:#6366f140;transform:translateY(-1px)}#formula-panel{z-index:20;width:380px;max-height:320px;animation:slideInUp var(--transition-slow) ease-out;position:absolute;bottom:12px;left:12px}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.formula-row{border-bottom:1px solid #ffffff08;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.formula-row:last-child{border-bottom:none}.formula-name{color:var(--text-muted);min-width:70px;font-size:.7rem;font-weight:500}.formula-expr{text-align:center;flex:1;font-size:.85rem}.formula-value{font-family:var(--font-mono);color:var(--accent-cyan);text-align:right;background:#06b6d414;border-radius:6px;min-width:70px;padding:2px 10px;font-size:.72rem;font-weight:600}.katex{color:var(--text-primary);font-size:.9em!important}#data-panel{z-index:20;width:320px;max-height:350px;animation:slideInUp var(--transition-slow) ease-out;position:absolute;bottom:12px;right:12px}#live-values{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.live-value-card{text-align:center;background:#ffffff08;border:1px solid #ffffff0d;border-radius:10px;padding:8px 10px}.live-value-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:.6rem}.live-value-number{font-family:var(--font-mono);letter-spacing:-.02em;font-size:1rem;font-weight:700}.live-value-unit{color:var(--text-muted);margin-left:2px;font-size:.6rem}#energy-chart{border-radius:8px;width:100%!important;height:160px!important}.hidden{display:none!important}.panel.collapsed .panel-content,.panel.collapsed .panel-actions{display:none}.panel.collapsed{max-height:44px;overflow:hidden}@media (width<=1200px){#formula-panel{width:320px}#control-panel{width:250px}}@media (width<=900px){.top-bar-center{display:none}#formula-panel,#data-panel{width:calc(50% - 18px)}#control-panel{width:220px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes glow{0%,to{box-shadow:0 0 8px var(--accent-primary-glow)}50%{box-shadow:0 0 20px var(--accent-primary-glow)}}.simulating .play-btn{animation:1.5s infinite pulse}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)translate(5px,5px)}to{opacity:1;transform:scale(1)translate(5px,5px)}}.context-menu-btn:hover{color:#fff!important;background:#ffffff14!important}.context-menu-btn-danger:hover{color:#f87171!important;background:#ef444426!important}@keyframes slideInLeft{0%{opacity:0;transform:translate(-40px)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes slideInTopNav{0%{opacity:0;transform:translate(-50%,-40px)scale(.95)}to{opacity:1;transform:translate(-50%)scale(1)}}@keyframes slideInRightPanel{0%{opacity:0;transform:translate(50px)scale(.98)}to{opacity:1;transform:translate(0)scale(1)}}.top-bar-left{animation:.65s cubic-bezier(.16,1,.3,1) forwards slideInLeft}.top-bar-center{animation:.65s cubic-bezier(.16,1,.3,1) forwards slideInTopNav}.panel.glass-panel{animation:.65s cubic-bezier(.16,1,.3,1) forwards slideInRightPanel}.loading-screen{z-index:10000;background:radial-gradient(circle,#0f172a 0%,#020617 100%);flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;left:0;overflow:hidden}.loading-screen.fade-out{opacity:0;pointer-events:none;transform:scale(1.05)}.loading-grid{opacity:.85;pointer-events:none;background-image:linear-gradient(#6366f108 1px,#0000 1px),linear-gradient(90deg,#6366f108 1px,#0000 1px);background-position:50%;background-size:40px 40px;width:100%;height:100%;position:absolute;top:0;left:0}.loading-glow-orb{pointer-events:none;filter:blur(50px);background:radial-gradient(circle,#6366f11f 0%,#0000 70%);width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-logo-box{justify-content:center;align-items:center;margin-bottom:24px;display:flex;position:relative}.loading-orbit{box-sizing:border-box;border:1.5px dashed #6366f138;border-radius:50%;position:absolute}.loading-orbit:after{content:"";z-index:5;border-radius:50%;width:10px;height:10px;position:absolute;top:0;left:50%;transform:translate(-50%,-50%)}.loading-orbit-1{width:200px;height:200px;animation:7s linear infinite spinOrbit1}.loading-orbit-1:after{background:#3b82f6;box-shadow:0 0 10px #3b82f6,0 0 20px #818cf8}.loading-orbit-2{width:200px;height:200px;animation:5s linear infinite spinOrbit2}.loading-orbit-2:after{background:#ec4899;box-shadow:0 0 10px #ec4899,0 0 20px #f43f5e}.loading-orbit-3{width:200px;height:200px;animation:9s linear infinite spinOrbit3}.loading-orbit-3:after{background:#10b981;box-shadow:0 0 10px #10b981,0 0 20px #34d399}.loading-center-atom{color:#818cf8;filter:drop-shadow(0 0 24px #6366f1bf);z-index:10;font-size:80px;animation:1.8s ease-in-out infinite pulseAtom}.loading-brand{text-align:center;z-index:10;margin-bottom:32px}.loading-title{color:#fff;letter-spacing:-.02em;background:linear-gradient(135deg,#fff 40%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:28px;font-weight:800}.loading-subtitle{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;font-size:13px}.loading-bar-container{background:#ffffff0f;border-radius:99px;width:200px;height:4px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:inset 0 1px 1px #00000080}.loading-bar-fill{background:linear-gradient(90deg,#6366f1,#3b82f6,#06b6d4);border-radius:99px;height:100%;transition:width .15s ease-out;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 0 12px #6366f1cc}.loading-percentage{font-family:var(--font-mono);color:#818cf8;margin-bottom:8px;font-size:14px;font-weight:700}.loading-status-text{color:#64748b;min-height:16px;font-size:11px;font-weight:500}@keyframes spinOrbit1{0%{transform:rotateX(70deg)rotateY(20deg)rotate(0)}to{transform:rotateX(70deg)rotateY(20deg)rotate(360deg)}}@keyframes spinOrbit2{0%{transform:rotateX(30deg)rotateY(70deg)rotate(360deg)}to{transform:rotateX(30deg)rotateY(70deg)rotate(0)}}@keyframes spinOrbit3{0%{transform:rotateX(45deg)rotateY(-45deg)rotate(0)}to{transform:rotateX(45deg)rotateY(-45deg)rotate(360deg)}}@keyframes pulseAtom{0%,to{filter:drop-shadow(0 0 20px #6366f1b3);transform:scale(1)}50%{filter:drop-shadow(0 0 35px #6366f1f2);transform:scale(1.12)}}.loading-svg-nucleus-single{filter:drop-shadow(0 0 6px #6366f1cc)drop-shadow(0 0 12px #818cf866);animation:4s linear infinite rotateSingleNucleus}.loading-nucleus-spark-orbit{animation:1.6s linear infinite spinNucleusSpark}@keyframes rotateSingleNucleus{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spinNucleusSpark{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.miro-toolbar-btn{position:relative}.miro-toolbar-btn.active{box-shadow:0 0 12px #6366f159}.miro-toolbar-btn.simulating{animation:2s infinite pulse-border-red}@keyframes pulse-border-red{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.miro-left-container{z-index:100;pointer-events:none;align-items:flex-start;gap:12px;display:flex;position:absolute;top:50%;left:24px;transform:translateY(-50%)}.miro-toolbar{-webkit-backdrop-filter:blur(24px);pointer-events:auto;background:#0f172abf;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;flex-shrink:0;align-items:center;gap:12px;width:52px;height:fit-content;padding:12px 0;display:flex;box-shadow:0 10px 30px #0006}.miro-toolbar-divider{background:#ffffff14;flex-shrink:0;width:24px;height:1px}.miro-content-board{-webkit-backdrop-filter:blur(30px);pointer-events:auto;background:#0f172ad9;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;width:290px;max-height:85vh;animation:.5s cubic-bezier(.16,1,.3,1) forwards slideInLeft;display:flex;overflow-y:auto;box-shadow:0 10px 40px #00000080}.miro-content-board::-webkit-scrollbar{width:6px}.miro-content-board::-webkit-scrollbar-track{background:0 0}.miro-content-board::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}@media (width<=768px){.miro-left-container{flex-direction:column-reverse;align-items:center;width:100%;top:auto;bottom:16px;left:50%;transform:translate(-50%)}.miro-toolbar{flex-direction:row;justify-content:flex-start;width:auto;max-width:95vw;height:56px;padding:0 12px;overflow-x:auto}.miro-toolbar::-webkit-scrollbar{display:none}.miro-toolbar{-ms-overflow-style:none;scrollbar-width:none}.miro-toolbar-divider{width:1px;height:24px}.miro-content-board{width:95vw;max-height:60vh;padding:16px;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideInUp}}.miro-right-panel{-webkit-backdrop-filter:blur(30px);pointer-events:auto;z-index:100;background:#0f172ae0;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;width:280px;max-height:calc(100vh - 100px);animation:.4s cubic-bezier(.16,1,.3,1) forwards slideInRight;display:flex;position:fixed;top:76px;right:16px;overflow:hidden;box-shadow:0 10px 40px #00000080}.miro-right-panel .panel-content{flex:1;overflow-y:auto}.miro-right-panel .panel-content::-webkit-scrollbar{width:4px}.miro-right-panel .panel-content::-webkit-scrollbar-track{background:0 0}.miro-right-panel .panel-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.charge-row-btn:hover{background:#ffffff1f!important}.charge-delete-btn:hover{background:#ef444440!important}@media (width<=768px){.miro-right-panel{display:none!important}}.miro-content-board .panel-header h2{letter-spacing:.05em;color:#cbd5e1;font-size:12px;font-weight:700}.material-btn{color:#94a3b8;cursor:pointer;text-align:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}.material-btn:hover{color:#fff;background:#ffffff0f;border-color:#ffffff26}.material-btn.active{color:#a5b4fc;background:#6366f126;border-color:#6366f1;box-shadow:0 0 10px #6366f126}.coord-input{transition:all .15s}.coord-input:hover{border-color:#ffffff40!important}.coord-input.active{box-shadow:0 0 10px #6366f140}.dashboard-grid{z-index:1;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;width:100%;max-width:800px;padding:0 20px;display:grid}.dashboard-header-container{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:12px;margin-bottom:48px;display:flex}.dashboard-title{letter-spacing:-1px;background:linear-gradient(135deg,#f1f5f9 0%,#94a3b8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:42px;font-weight:800}.dashboard-subtitle{color:#64748b;margin:0;font-size:16px;font-weight:500}.dashboard-icon{width:44px;height:44px}.dashboard-card{text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #ffffff0d;border-radius:16px;flex-direction:column;align-items:center;width:100%;max-width:320px;margin:0 auto;padding:24px 20px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}@media (width<=768px){.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;padding:0 12px}.dashboard-card{padding:16px 12px}.dashboard-header-container{margin-bottom:32px}.dashboard-title{letter-spacing:-.5px;font-size:26px}.dashboard-subtitle{padding:0 20px;font-size:14px}.dashboard-icon{width:32px;height:32px}#top-bar{justify-content:center;padding:16px 12px}.top-bar-left{justify-content:center;width:100%;padding:8px 36px 8px 12px;position:relative}.top-bar-left h1{font-size:.85rem}.mobile-menu-toggle{justify-content:center;align-items:center;display:flex;position:absolute;right:8px}.top-bar-center{z-index:1000;background:#0f172af2;border-radius:12px;flex-direction:column;width:auto;padding:8px;display:none;position:absolute;top:64px;left:12px;right:12px;transform:none;box-shadow:0 10px 40px #000c}.top-bar-center.mobile-open{animation:.2s cubic-bezier(.16,1,.3,1) forwards slideDownToast;display:flex}.nav-btn{justify-content:flex-start;width:100%;padding:12px 16px}}
