:root{--bg: #0D0D1A;--fg: #FFFFFF;--muted: #2D1B4E;--accent-1: #FF3AF2;--accent-2: #00F5D4;--accent-3: #FFE600;--accent-4: #FF6B35;--accent-5: #7B2FFF;--stress-low: #4ADE80;--stress-medium: #FFE600;--stress-high: #FF6B35;--stress-critical: #FF3AF2;--font-heading: "Outfit", sans-serif;--font-body: "DM Sans", sans-serif;--panel-width: 280px;--panel-padding: 24px;--gap: 16px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg);color:var(--fg);overflow:hidden;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,var(--accent-1) 1px,transparent 1px);background-size:40px 40px;opacity:.08;pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(0,245,212,.03) 20px,rgba(0,245,212,.03) 40px);pointer-events:none;z-index:0}#app{display:grid;grid-template-columns:var(--panel-width) 1fr var(--panel-width);grid-template-rows:100vh;gap:0;position:relative;z-index:1}#left-panel,#right-panel{background:#2d1b4ed9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--panel-padding);overflow-y:auto;border:4px solid var(--accent-1);position:relative}#left-panel{border-right-width:4px;border-left:none;border-top:none;border-bottom:none}#right-panel{border-left-width:4px;border-right:none;border-top:none;border-bottom:none;border-color:var(--accent-2)}#left-panel:before,#right-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 20%,rgba(255,58,242,.1) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(0,245,212,.1) 0%,transparent 50%);pointer-events:none}.logo{font-family:var(--font-heading);font-size:28px;font-weight:900;line-height:1;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:32px;text-shadow:2px 2px 0 var(--accent-5),4px 4px 0 var(--accent-1)}.logo span{color:var(--accent-2);display:block}.panel-section{margin-bottom:28px;position:relative}.panel-section h2{font-family:var(--font-heading);font-size:12px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-3);margin-bottom:16px;padding-bottom:8px;border-bottom:2px dashed var(--accent-5)}.mode-buttons,.material-buttons{display:flex;flex-direction:column;gap:8px}.mode-btn,.material-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:#0d0d1a99;border:3px solid var(--accent-5);border-radius:12px;color:var(--fg);font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease-out;text-align:left}.material-btn{align-items:flex-start;padding:12px 14px}.material-text{display:flex;flex-direction:column;gap:4px}.material-name{font-weight:700;font-size:14px}.material-desc{font-size:11px;font-weight:400;color:#fff9;line-height:1.3}.material-btn.active .material-desc{color:#fffc}.mode-btn:hover,.material-btn:hover{transform:translate(4px);border-color:var(--accent-2);box-shadow:0 0 20px #00f5d44d,4px 4px 0 var(--accent-1)}.mode-btn.active,.material-btn.active{background:linear-gradient(135deg,var(--accent-1),var(--accent-5));border-color:var(--accent-3);box-shadow:0 0 30px #ff3af266,6px 6px 0 var(--accent-3)}.mode-icon{font-size:18px;width:24px;text-align:center}.material-preview{width:32px;height:8px;border-radius:4px;flex-shrink:0;margin-top:4px}.beam-preview{background:var(--accent-2)}.spring-preview{background:repeating-linear-gradient(90deg,var(--accent-3) 0px,var(--accent-3) 4px,transparent 4px,transparent 8px)}.cable-preview{background:var(--accent-4);height:3px}.sim-controls{display:flex;gap:12px}.sim-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:linear-gradient(135deg,var(--accent-2),var(--accent-5));border:4px solid var(--accent-3);border-radius:9999px;color:var(--bg);font-family:var(--font-heading);font-size:14px;font-weight:800;letter-spacing:.1em;cursor:pointer;transition:all .2s ease-out;box-shadow:0 0 20px #00f5d466,4px 4px 0 var(--accent-1)}.sim-btn:hover{transform:scale(1.05);box-shadow:0 0 30px #00f5d499,6px 6px 0 var(--accent-1)}.sim-btn:active{transform:scale(.98);box-shadow:0 0 15px #00f5d44d,2px 2px 0 var(--accent-1)}.sim-btn.secondary{background:transparent;border-style:dashed;color:var(--fg)}.sim-btn.secondary:hover{background:var(--accent-4);color:var(--bg)}.sim-btn.running{background:linear-gradient(135deg,var(--accent-4),var(--accent-1))}.sim-btn.running .play-icon:before{content:"⏸"}#canvas-container{position:relative;background:var(--bg);overflow:hidden;display:flex;flex-direction:column}#physics-canvas{display:block;width:100%;flex:1}#canvas-overlay{position:absolute;bottom:80px;left:50%;transform:translate(-50%);pointer-events:none}.hint{display:inline-block;padding:12px 24px;background:#2d1b4ee6;border:2px solid var(--accent-5);border-radius:9999px;font-size:13px;font-weight:500;color:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}#bottom-bar{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#2d1b4ef2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:3px solid var(--accent-3);z-index:10}.bottom-stats{display:flex;gap:32px}.stat-item{display:flex;align-items:center;gap:10px}.stat-item .stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff9}.stat-item .stat-value{font-family:var(--font-heading);font-weight:800;font-size:18px;color:var(--accent-2);min-width:32px}.stress-legend-inline{display:flex;align-items:center;gap:12px}.legend-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff9}.stress-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:9999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:2px solid}.stress-chip.low{background:#4ade8026;border-color:var(--stress-low);color:var(--stress-low)}.stress-chip.medium{background:#ffe60026;border-color:var(--stress-medium);color:var(--stress-medium)}.stress-chip.high{background:#ff6b3526;border-color:var(--stress-high);color:var(--stress-high)}.stress-chip.critical{background:#ff3af226;border-color:var(--stress-critical);color:var(--stress-critical)}.physics-context-menu{position:fixed;min-width:180px;padding:8px 0;background:#2d1b4efa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:3px solid var(--accent-1);border-radius:12px;box-shadow:0 8px 32px #0006,0 0 20px #ff3af24d;font-family:var(--font-body);z-index:1000;opacity:0;transform:scale(.95);transition:opacity .1s ease-out,transform .1s ease-out}.physics-context-menu.visible{opacity:1;transform:scale(1)}.physics-context-menu .context-menu-item{padding:12px 16px;color:var(--fg);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease-out}.physics-context-menu .context-menu-item:hover{background:linear-gradient(90deg,rgba(255,58,242,.3),transparent);color:var(--accent-3)}.physics-context-menu hr{margin:6px 0;border:0;border-top:1px solid rgba(255,255,255,.1)}.info-box{padding:16px;background:#0d0d1a80;border:2px dashed var(--accent-5);border-radius:12px}.empty-state{color:#fff6;font-style:italic;font-size:14px}.hint-text{color:#fff6;font-size:12px;font-style:italic;margin-top:8px}.options-group{display:flex;flex-direction:column;gap:12px}.options-group.disabled{opacity:.4;pointer-events:none}.toggle-option{display:grid;grid-template-columns:24px 1fr;grid-template-rows:auto auto;gap:4px 12px;padding:12px;background:#0d0d1a80;border:2px solid var(--accent-5);border-radius:12px;cursor:pointer;transition:all .2s ease-out}.toggle-option:hover{border-color:var(--accent-2);background:#0d0d1acc}.toggle-option input[type=checkbox]{grid-row:span 2;width:20px;height:20px;accent-color:var(--accent-1);cursor:pointer;align-self:center}.toggle-label{font-weight:700;font-size:14px}.toggle-hint{font-size:12px;color:#ffffff80}.control-row{display:flex;flex-direction:column;gap:8px;padding:12px;background:#0d0d1a80;border:2px solid var(--accent-5);border-radius:12px}.control-label{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:var(--fg)}.value-display{font-family:var(--font-heading);font-weight:800;color:var(--accent-2);font-size:14px}.control-hint{font-size:11px;font-weight:400;color:#ffffff80;line-height:1.3;margin-top:4px}.control-select{width:100%;padding:10px 14px;background:#0d0d1acc;border:2px solid var(--accent-5);border-radius:8px;color:var(--fg);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease-out;-webkit-appearance:none;-moz-appearance:none;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='%2300F5D4' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.control-select:hover{border-color:var(--accent-2);box-shadow:0 0 15px #00f5d44d}.control-select:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 20px #00f5d466}.control-select option{background:var(--bg);color:var(--fg);padding:10px}.control-slider{width:100%;height:8px;background:#0d0d1acc;border-radius:4px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.control-slider::-webkit-slider-track{height:8px;background:linear-gradient(90deg,var(--accent-5),var(--accent-2));border-radius:4px}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent-3);border:3px solid var(--fg);border-radius:50%;cursor:pointer;box-shadow:0 0 10px #ffe60080;transition:all .2s ease-out}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 20px #ffe600cc}.control-slider::-moz-range-track{height:8px;background:linear-gradient(90deg,var(--accent-5),var(--accent-2));border-radius:4px}.control-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent-3);border:3px solid var(--fg);border-radius:50%;cursor:pointer;box-shadow:0 0 10px #ffe60080}.stress-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:12px;font-size:13px}.stress-bar{width:40px;height:8px;border-radius:4px}.stress-bar.low{background:var(--stress-low)}.stress-bar.medium{background:var(--stress-medium)}.stress-bar.high{background:var(--stress-high)}.stress-bar.critical{background:var(--stress-critical);animation:pulse-glow 1s ease-in-out infinite}.stats .stat-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}.stat-label{color:#fff9;font-size:14px}.stat-value{font-family:var(--font-heading);font-weight:800;font-size:16px;color:var(--accent-2)}.floating-shape{position:fixed;font-size:32px;color:var(--accent-1);opacity:.3;pointer-events:none;z-index:0}.shape-1{top:10%;left:35%;color:var(--accent-1);animation:float 6s ease-in-out infinite}.shape-2{top:60%;right:35%;color:var(--accent-2);animation:float-reverse 5s ease-in-out infinite}.shape-3{bottom:20%;left:40%;color:var(--accent-3);animation:float 7s ease-in-out infinite;font-size:24px}.shape-4{top:30%;right:40%;color:var(--accent-5);animation:wiggle 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}@keyframes float-reverse{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(20px) rotate(-5deg)}}@keyframes wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px var(--accent-1);opacity:1}50%{box-shadow:0 0 20px var(--accent-1),0 0 30px var(--accent-4);opacity:.8}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent-5);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-1)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.15s!important}}@media (max-width: 1200px){:root{--panel-width: 240px}}@media (max-width: 900px){#app{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}#left-panel,#right-panel{max-height:300px;border:none;border-bottom:4px solid var(--accent-1)}#right-panel{border-bottom:none;border-top:4px solid var(--accent-2)}.mode-buttons,.material-buttons{flex-direction:row;flex-wrap:wrap}.mode-btn,.material-btn{flex:1;min-width:120px}}.weight-popup{position:fixed;min-width:200px;background:#2d1b4efa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:3px solid var(--accent-4);border-radius:12px;box-shadow:0 8px 32px #0006,0 0 20px #ff6b354d;font-family:var(--font-body);z-index:1000;overflow:hidden}.weight-popup-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ff6b3533;border-bottom:2px solid var(--accent-4)}.weight-popup-title{font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--accent-4)}.weight-popup-delete-row{margin-top:8px;padding:10px 12px;background:#ff3af21a;border:2px solid var(--accent-1);border-radius:8px;color:var(--accent-1);font-size:14px;font-weight:600;text-align:center;cursor:pointer;transition:all .15s ease-out}.weight-popup-delete-row:hover{background:var(--accent-1);color:var(--bg)}.weight-popup-controls{padding:12px 16px;display:flex;flex-direction:column;gap:12px}.scrubber-row{display:flex;flex-direction:column;gap:8px}.scrubber-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff9}.scrubber{display:flex;align-items:center;gap:12px;cursor:ew-resize;-webkit-user-select:none;user-select:none}.scrubber-track{flex:1;height:24px;background:#0d0d1a99;border:2px solid var(--accent-5);border-radius:12px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.scrubber-track:before{content:"◀  ▶";font-size:10px;color:#ffffff4d;letter-spacing:4px}.scrubber-thumb{position:absolute;left:50%;margin-left:-4px;width:8px;height:16px;background:var(--accent-3);border-radius:4px;transition:transform .1s ease-out;box-shadow:0 0 8px #ffe60080}.scrubber.scrubbing .scrubber-track{border-color:var(--accent-2);background:#00f5d41a}.scrubber.scrubbing .scrubber-thumb{background:var(--accent-2);transition:none}.scrubber-value{min-width:60px;font-family:var(--font-heading);font-weight:800;font-size:14px;color:var(--accent-3);text-align:right}.scrubber:hover .scrubber-track{border-color:var(--accent-2)}.scrubber:hover .scrubber-track:before{color:#ffffff80}.node-popup{position:fixed;min-width:200px;background:#2d1b4efa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:3px solid var(--accent-2);border-radius:12px;box-shadow:0 8px 32px #0006,0 0 20px #00f5d44d;font-family:var(--font-body);z-index:1000;overflow:hidden}.node-popup-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#00f5d433;border-bottom:2px solid var(--accent-2)}.node-popup-title{font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--accent-2)}.node-popup-controls{padding:12px 16px;display:flex;flex-direction:column;gap:12px}.node-popup-action-row{padding:10px 12px;background:#7b2fff1a;border:2px solid var(--accent-5);border-radius:8px;color:var(--accent-5);font-size:14px;font-weight:600;text-align:center;cursor:pointer;transition:all .15s ease-out}.node-popup-action-row:hover{background:var(--accent-5);color:var(--bg)}.node-popup-delete-row{background:#ff3af21a;border-color:var(--accent-1);color:var(--accent-1)}.node-popup-delete-row:hover{background:var(--accent-1);color:var(--bg)}.state-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0d1ae6;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.state-modal{background:var(--bg-darker);border:2px solid var(--accent-5);border-radius:16px;width:min(90vw,600px);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #7b2fff4d}.state-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(123,47,255,.3)}.state-modal-header h3{margin:0;font-family:var(--font-heading);font-size:18px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-2)}.state-modal-close{background:none;border:none;color:#fff9;font-size:24px;cursor:pointer;padding:0;line-height:1;transition:color .2s}.state-modal-close:hover{color:var(--accent-1)}.state-modal-body{padding:20px;flex:1;overflow:hidden}.state-modal-textarea{width:100%;height:300px;background:var(--bg-panel);border:2px solid rgba(123,47,255,.3);border-radius:8px;color:var(--text-primary);font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.4;padding:12px;resize:none;box-sizing:border-box}.state-modal-textarea:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 12px #00f5d433}.state-modal-textarea::placeholder{color:#ffffff4d}.state-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid rgba(123,47,255,.3)}.state-modal-btn{padding:10px 24px;border-radius:8px;font-family:var(--font-heading);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s}.state-modal-btn.primary{background:var(--accent-2);border:2px solid var(--accent-2);color:var(--bg-darker)}.state-modal-btn.primary:hover{background:transparent;color:var(--accent-2);box-shadow:0 0 15px #00f5d466}.state-modal-btn.secondary{background:transparent;border:2px solid rgba(255,255,255,.3);color:var(--text-secondary)}.state-modal-btn.secondary:hover{border-color:var(--accent-1);color:var(--accent-1)}.state-modal-message{text-align:center;padding:0 20px 12px;font-size:13px;font-weight:500;min-height:20px}.state-modal-message.success{color:var(--stress-low)}.state-modal-message.error{color:var(--accent-1)}.multi-select-actions{display:flex;gap:8px;margin-top:12px}.bulk-action-btn{flex:1;padding:10px 12px;background:#7b2fff1a;border:2px solid var(--accent-5);border-radius:8px;color:var(--accent-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease-out}.bulk-action-btn:hover{background:var(--accent-5);color:var(--fg)}.bulk-action-btn.danger{border-color:var(--accent-1);color:var(--accent-1)}.bulk-action-btn.danger:hover{background:var(--accent-1);color:var(--bg)}.bulk-action-btn.small{flex:0;padding:6px 12px;font-size:12px}.bulk-mass-control{margin-top:12px;padding:10px;background:#0d0d1a80;border:2px solid var(--accent-5);border-radius:8px}.bulk-mass-control label{display:block;font-size:12px;font-weight:600;color:#fff9;margin-bottom:8px}.bulk-mass-input-row{display:flex;align-items:center;gap:8px}.bulk-mass-input-row input{flex:1;padding:8px 10px;background:#0d0d1acc;border:2px solid var(--accent-5);border-radius:6px;color:var(--fg);font-family:var(--font-heading);font-size:14px;font-weight:700;width:60px}.bulk-mass-input-row input:focus{outline:none;border-color:var(--accent-2)}.bulk-mass-input-row span{color:#ffffff80;font-size:12px}.multi-node-popup .multi-node-info{padding:8px 12px;background:#0d0d1a80;border:1px solid rgba(0,245,212,.3);border-radius:6px;font-size:12px;color:#ffffffb3}
