:root{--bg-primary: #0a0e14;--bg-secondary: #0d1117;--bg-tertiary: #151b23;--bg-elevated: #1c2433;--accent-cyan: #00d4ff;--accent-cyan-dim: #00d4ff40;--accent-cyan-glow: #00d4ff20;--accent-green: #00ff88;--accent-green-dim: #00ff8840;--accent-orange: #ff9500;--accent-orange-dim: #ff950040;--accent-red: #ff4757;--accent-purple: #a855f7;--accent-purple-dim: #a855f740;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #484f58;--border-color: #21262d;--border-accent: #00d4ff30;--grid-color: #1a2332;--grid-accent: #00d4ff08;--state-atomic: #00d4ff;--state-compound: #a855f7;--state-final: #00ff88;--state-parallel: #ff9500;--state-history: #f472b6;--state-active: #00ff88;--shadow-glow: 0 0 30px var(--accent-cyan-glow);--shadow-card: 0 4px 20px rgba(0,0,0,.4);--transition-fast: .15s ease;--transition-medium: .3s ease;--transition-slow: .5s ease;--bg: var(--bg-primary);--surface: var(--bg-secondary);--surface-hover: var(--bg-tertiary);--accent: var(--accent-cyan);--text: var(--text-primary);--border: var(--border-color);--transition: var(--transition-fast);--radius: 6px;--radius-lg: 12px;--font-mono: "JetBrains Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Space Grotesk,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}h1,h2,h3,h4{font-family:JetBrains Mono,monospace;font-weight:600;letter-spacing:-.02em}code,pre,.mono{font-family:JetBrains Mono,monospace}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px),linear-gradient(var(--grid-accent) 1px,transparent 1px),linear-gradient(90deg,var(--grid-accent) 1px,transparent 1px);background-size:100px 100px,100px 100px,20px 20px,20px 20px;pointer-events:none;z-index:-1}body:after{content:"";position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,212,255,.01) 2px,rgba(0,212,255,.01) 4px);pointer-events:none;z-index:1000;animation:scanline 8s linear infinite}@keyframes scanline{0%{transform:translateY(0)}to{transform:translateY(4px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes ping{0%{transform:scale(1);opacity:.8}to{transform:scale(1.5);opacity:0}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.app{display:grid;grid-template-columns:380px 1fr;grid-template-rows:auto 1fr;min-height:100vh;gap:0}@media(max-width:1024px){.app{grid-template-columns:1fr;grid-template-rows:auto auto 1fr}}.header{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:relative;z-index:100}.header:before{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);opacity:.5}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{width:36px;height:36px;position:relative}.logo-icon svg{width:100%;height:100%}.logo-text{font-size:1.25rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.1em}.logo-text span{color:var(--accent-cyan)}.header-actions{display:flex;align-items:center;gap:1rem}.header-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;padding:.5rem .75rem;border-radius:6px;transition:var(--transition-fast)}.header-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.header-link svg{width:18px;height:18px}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;padding:1rem;gap:1rem;min-height:0}.sidebar-section{padding:1.25rem;border-bottom:1px solid var(--border-color)}.sidebar-section:last-child{border-bottom:none;flex:1;overflow-y:auto}.panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px #0000004d;display:flex;flex-direction:column;flex-shrink:0;overflow:visible}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-tertiary) 100%);border-bottom:1px solid var(--accent-cyan-dim);position:relative;flex-shrink:0;border-radius:8px 8px 0 0}.panel-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);opacity:.3}.panel-title{font-size:.65rem;font-weight:600;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.1em;margin:0;text-shadow:0 0 10px var(--accent-cyan-glow)}.panel-title:before{content:"// ";opacity:.6}.panel-content{padding:.875rem .875rem 1rem;background:var(--bg-primary);border-radius:0 0 8px 8px;overflow:visible}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;background:var(--bg-tertiary);color:var(--text-muted)}.badge-active{background:var(--accent-green-dim);color:var(--accent-green)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2s ease infinite}.simulation-controls{margin-bottom:.75rem}.btn-secondary{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--accent-cyan);background:var(--bg-elevated)}.import-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.import-actions .btn{padding:.5rem .625rem;font-size:.65rem}.json-input{width:100%;min-height:60px;max-height:80px;padding:.5rem;font-family:JetBrains Mono,monospace;font-size:.7rem;line-height:1.4;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;resize:vertical;margin-bottom:.5rem;transition:var(--transition-fast)}.json-input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 2px var(--accent-cyan-glow);max-height:200px}.json-input::placeholder{color:var(--text-muted)}.upload-icon{width:20px;height:20px;color:var(--text-muted);opacity:.5;flex-shrink:0}.file-upload:hover .upload-icon{color:var(--accent-cyan);opacity:1}.file-upload.dragging{border-color:var(--accent-green);background:var(--accent-green-dim)}.file-upload.dragging .upload-icon{color:var(--accent-green);opacity:1}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{font-size:.7rem;font-weight:600;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.15em;display:flex;align-items:center;gap:.5rem}.section-title:before{content:"//";opacity:.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.05) 50%,transparent 60%);transform:translate(-100%);transition:transform .5s ease}.btn:hover:before{transform:translate(100%)}.btn:hover{border-color:var(--accent-cyan);box-shadow:0 0 20px var(--accent-cyan-glow)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan)}.btn-primary:hover{background:#00e5ff;box-shadow:0 0 30px var(--accent-cyan-dim)}.btn-success{background:var(--accent-green-dim);border-color:var(--accent-green);color:var(--accent-green)}.btn-danger{background:#ff47571a;border-color:var(--accent-red);color:var(--accent-red)}.btn-sm{padding:.375rem .75rem;font-size:.7rem}.btn-icon{padding:.5rem;min-width:32px}.btn svg{width:14px;height:14px}.input-group{margin-bottom:1rem}.input-label{display:block;font-size:.7rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.textarea{width:100%;min-height:200px;padding:1rem;font-family:JetBrains Mono,monospace;font-size:.8rem;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;resize:vertical;transition:var(--transition-fast)}.textarea:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 3px var(--accent-cyan-glow)}.textarea::placeholder{color:var(--text-muted)}.file-upload{position:relative;display:flex;flex-direction:row;align-items:center;gap:.5rem;padding:.625rem .75rem;border:1px dashed var(--border-color);border-radius:6px;background:var(--bg-secondary);cursor:pointer;transition:var(--transition-fast);margin-bottom:.5rem}.file-upload:hover{border-color:var(--accent-cyan);background:var(--accent-cyan-glow)}.file-upload.dragover{border-color:var(--accent-green);background:var(--accent-green-dim)}.file-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}.file-upload-icon{width:32px;height:32px;color:var(--text-muted);margin-bottom:.5rem}.file-upload-text{font-size:.8rem;color:var(--text-secondary)}.file-upload-text strong{color:var(--accent-cyan)}.sim-status{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;margin-bottom:1rem}.sim-status-indicator{width:10px;height:10px;border-radius:50%;background:var(--text-muted);position:relative}.sim-status-indicator.active{background:var(--accent-green);animation:pulse 2s ease infinite}.sim-status-indicator.active:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent-green);animation:ping 2s ease infinite}.sim-status-text{font-size:.8rem;color:var(--text-secondary)}.sim-status-text strong{color:var(--text-primary);font-family:JetBrains Mono,monospace}.current-state{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--accent-green-dim);border:1px solid var(--accent-green);border-radius:4px;margin-bottom:.75rem}.current-state-label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.current-state-value{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600;color:var(--accent-green)}.events-title{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.events-list{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem}.event-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .625rem;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:500;color:var(--accent-cyan);background:var(--bg-primary);border:1px solid var(--accent-cyan-dim);border-radius:4px;cursor:pointer;transition:var(--transition-fast)}.event-btn:before{content:">";opacity:.5}.event-btn:hover{background:var(--accent-cyan-dim);border-color:var(--accent-cyan);box-shadow:0 0 15px var(--accent-cyan-glow)}.event-btn:active{transform:scale(.95)}.no-events{font-size:.8rem;color:var(--text-muted);font-style:italic;padding:1rem;text-align:center;border:1px dashed var(--border-color);border-radius:6px}.history-list{display:flex;flex-direction:column;gap:.375rem}.history-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;transition:var(--transition-fast)}.history-item:first-child{border-color:var(--accent-cyan-dim);background:var(--accent-cyan-glow)}.history-index{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:.6rem;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);border-radius:4px;flex-shrink:0}.history-item:first-child .history-index{background:var(--accent-cyan);color:var(--bg-primary)}.history-event{font-family:JetBrains Mono,monospace;color:var(--accent-orange)}.history-arrow{color:var(--text-muted)}.history-state{font-family:JetBrains Mono,monospace;color:var(--text-primary)}.history-empty{font-size:.75rem;color:var(--text-muted);text-align:center;padding:1rem .75rem}.canvas-area{position:relative;background:var(--bg-primary);overflow:hidden}.canvas-container{width:100%;height:100%;position:relative}.canvas-container canvas{width:100%;height:100%;display:block}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.5rem 1rem;pointer-events:none}.canvas-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.empty-state-icon{width:80px;height:80px;color:var(--text-muted);margin-bottom:1.5rem;opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-text{font-size:.9rem;color:var(--text-secondary);max-width:400px;line-height:1.6}.toolbar{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.legend{position:absolute;bottom:1rem;left:1rem;display:flex;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;z-index:10}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:2px}.legend-dot.atomic{background:var(--state-atomic)}.legend-dot.compound{background:var(--state-compound)}.legend-dot.final{background:var(--state-final)}.legend-dot.parallel{background:var(--state-parallel)}.legend-dot.history{background:var(--state-history)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.75rem;z-index:3000}.toast{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-card);animation:slideIn .3s ease}.toast.success{border-color:var(--accent-green)}.toast.error{border-color:var(--accent-red)}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast.success .toast-icon{color:var(--accent-green)}.toast.error .toast-icon{color:var(--accent-red)}.toast-message{font-size:.875rem;color:var(--text-primary)}.state-tooltip{position:absolute;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-card);z-index:100;pointer-events:none;opacity:0;transform:translateY(10px);transition:var(--transition-fast)}.state-tooltip.visible{opacity:1;transform:translateY(0)}.state-tooltip-name{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.state-tooltip-type{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.shortcuts-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:var(--transition-medium)}.shortcuts-overlay.active{opacity:1;visibility:visible}.shortcuts-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:2rem;max-width:500px;width:90%;transform:scale(.9);transition:var(--transition-medium)}.shortcuts-overlay.active .shortcuts-modal{transform:scale(1)}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.shortcuts-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.shortcuts-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.shortcuts-close:hover{color:var(--text-primary);border-color:var(--accent-cyan)}.shortcuts-list{display:flex;flex-direction:column;gap:.75rem}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.shortcut-item:last-child{border-bottom:none}.shortcut-desc{font-size:.875rem;color:var(--text-secondary)}.shortcut-key{display:inline-flex;align-items:center;gap:.25rem}.shortcut-key kbd{padding:.25rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px}.control-row{display:flex;gap:.5rem;margin-bottom:1rem}.control-row .btn{flex:1}.sample-btn{width:100%;margin-top:.5rem}@media(max-width:1024px){.sidebar{border-right:none;border-bottom:1px solid var(--border-color)}.legend{flex-wrap:wrap;bottom:.5rem;left:.5rem;right:.5rem;justify-content:center}}.app[data-astro-cid-j7pv25f6]{display:grid;grid-template-columns:320px 1fr;grid-template-rows:auto 1fr;height:100vh;background:var(--bg)}#visualizer-mount[data-astro-cid-j7pv25f6],.visualizer-content{display:contents}
