*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--surface: #16213e;--surface2: #0f3460;--accent: #e94560;--text: #eee;--text-dim: #aaa;--radius: 8px}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}header{text-align:center;padding:1.5rem 1rem 1rem}header h1{font-size:1.8rem}header p{color:var(--text-dim);margin-top:.3rem}header code{background:var(--surface2);padding:2px 6px;border-radius:4px;font-size:.85em}main{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;max-width:1400px;margin:0 auto;padding:1rem 1.5rem 2rem}.controls{display:flex;flex-direction:column;gap:1rem;max-height:calc(100vh - 120px);overflow-y:auto;padding-right:.5rem}.controls section{background:var(--surface);border-radius:var(--radius);padding:1rem}.controls h2{font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin-bottom:.75rem;border-bottom:1px solid var(--surface2);padding-bottom:.4rem}label{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.85rem;color:var(--text-dim);padding:4px 0}input[type=color]{width:40px;height:28px;border:1px solid var(--surface2);border-radius:4px;cursor:pointer;background:none;padding:0}input[type=range]{width:100px;accent-color:var(--accent)}select{background:var(--surface2);color:var(--text);border:1px solid #333;border-radius:4px;padding:4px 8px;font-size:.85rem;width:100%}.range-val{min-width:28px;text-align:right;font-size:.8rem;color:var(--text-dim)}.node-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.75rem}.tab{background:var(--surface2);color:var(--text-dim);border:1px solid transparent;border-radius:4px;padding:4px 8px;font-size:.75rem;cursor:pointer;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn{width:100%;padding:8px;margin-top:4px;border:1px solid var(--surface2);border-radius:var(--radius);background:var(--surface2);color:var(--text);font-size:.85rem;cursor:pointer;transition:background .15s}.btn:hover{background:var(--accent)}.btn-outline{border-color:var(--accent)}.preview{background:var(--surface);border-radius:var(--radius);padding:1.5rem;position:sticky;top:1rem;align-self:start}.preview h2{font-size:1rem;margin-bottom:1rem;color:var(--accent)}.preview-tabs{display:flex;gap:4px;margin-bottom:1rem}.mermaid-input{margin-bottom:1rem}.mermaid-input label{display:block;font-size:.85rem;color:var(--text-dim);margin-bottom:.4rem}.mermaid-input textarea{width:100%;min-height:140px;background:var(--bg);color:var(--text);border:1px solid var(--surface2);border-radius:var(--radius);padding:.75rem;font-family:Courier New,monospace;font-size:.8rem;resize:vertical;line-height:1.5}.mermaid-input textarea:focus{outline:none;border-color:var(--accent)}.mermaid-error{background:#e9456026;border:1px solid var(--accent);border-radius:var(--radius);padding:.5rem .75rem;margin-bottom:.75rem;font-size:.8rem;color:var(--accent);white-space:pre-wrap;word-break:break-word}.mermaid-output svg{max-width:100%;height:auto}.svg-preview{border:1px solid var(--surface2);border-radius:var(--radius);padding:1rem;min-height:300px;display:flex;align-items:center;justify-content:center;overflow:auto}.svg-preview svg{max-width:100%;height:auto}details{margin-top:1rem}details summary{color:var(--text-dim);cursor:pointer;font-size:.85rem}.theme-json{background:var(--bg);border-radius:var(--radius);padding:1rem;font-size:.75rem;overflow-x:auto;max-height:400px;overflow-y:auto;margin-top:.5rem;white-space:pre-wrap;word-break:break-all}footer{text-align:center;padding:1rem;color:var(--text-dim);font-size:.85rem}footer a{color:var(--accent);text-decoration:none}.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--accent);color:#fff;padding:.75rem 1.25rem;border-radius:var(--radius);font-size:.85rem;opacity:0;transform:translateY(10px);transition:all .3s;z-index:100}.toast.show{opacity:1;transform:translateY(0)}@media(max-width:800px){main{grid-template-columns:1fr}.controls{max-height:none}.preview{position:static}}
