:root{--bg-0:#0a0a14;--bg-1:#11111c;--bg-2:#181826;--bg-3:#20203a;--border:#2a2a45;--border-strong:#3a3a55;--text:#c8c8d8;--text-dim:#8b8ba0;--text-bright:#fafaff;--accent:#7c5cff;--accent-2:#ff5c8a;--accent-3:#4dd0ff;--good:#34d399;--warn:#fbbf24;--shadow-lg:0 20px 60px #0006, 0 6px 20px #7c5cff14;--shadow-md:0 8px 24px #00000059;--shadow-glow:0 0 24px #7c5cff40;--sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;font-family:var(--sans);color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:var(--bg-0);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}*{box-sizing:border-box}html,body{background:var(--bg-0);background-image:radial-gradient(80% 60% at 20% 0,#7c5cff1a,#0000 60%),radial-gradient(60% 50% at 80% 100%,#ff5c8a14,#0000 60%),radial-gradient(70% 50%,#4dd0ff0a,#0000 70%);background-attachment:fixed;min-height:100vh;margin:0;padding:0}#root{min-height:100vh}button{font-family:inherit;font-size:inherit;cursor:pointer}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#4d4d70}::selection{background:var(--accent);color:#fff}.app{flex-direction:column;gap:16px;max-width:1600px;min-height:100vh;margin:0 auto;padding:20px 28px 40px;display:flex}.app-header{border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#7c5cff1a,#ff5c8a0f);border-radius:16px;justify-content:space-between;align-items:center;gap:24px;padding:16px 22px;display:flex}.brand{align-items:center;gap:14px;display:flex}.brand-mark{border:1px solid var(--border-strong);background:radial-gradient(circle at 30% 30%,#7c5cff66,#0000);border-radius:12px;place-items:center;width:44px;height:44px;display:grid}.brand-title{color:var(--text-bright);letter-spacing:-.2px;font-size:18px;font-weight:600}.brand-sub{color:var(--text-dim);margin-top:2px;font-size:12.5px}.header-actions{align-items:center;gap:10px;display:flex}.qubit-control{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;align-items:center;gap:8px;padding:6px 10px;display:flex}.qubit-control>span:first-child{color:var(--text-dim);margin-right:4px;font-size:12px}.qubit-control button{background:var(--bg-3);border:1px solid var(--border-strong);width:26px;height:26px;color:var(--text-bright);border-radius:7px;place-items:center;font-size:16px;transition:all .12s;display:grid}.qubit-control button:hover{background:var(--accent);border-color:var(--accent)}.qubit-control .num{font-variant-numeric:tabular-nums;color:var(--text-bright);text-align:center;min-width:14px;font-weight:600}.btn-soft,.btn-ghost{border:1px solid var(--border-strong);background:var(--bg-2);color:var(--text-bright);border-radius:10px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .12s}.btn-soft:hover{background:var(--bg-3);border-color:var(--accent)}.btn-ghost{background:0 0}.btn-ghost:hover{background:var(--bg-2)}.btn-x{color:var(--text-dim);background:0 0;border:none;font-size:18px;position:absolute;top:8px;right:10px}.btn-x:hover{color:var(--text-bright)}.help-banner{color:var(--text);background:linear-gradient(90deg,#7c5cff1f,#4dd0ff0f);border:1px solid #7c5cff4d;border-radius:12px;padding:14px 40px 14px 16px;font-size:13.5px;line-height:1.6;position:relative}.help-banner strong{color:var(--text-bright)}.presets{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.presets-label{color:var(--text-dim);margin-right:4px;font-size:12px}.preset-btn{background:var(--bg-2);border:1px solid var(--border);color:var(--text-bright);border-radius:999px;padding:7px 13px;font-size:12.5px;font-weight:500;transition:all .12s}.preset-btn:hover{background:var(--bg-3);border-color:var(--accent);box-shadow:0 0 0 3px #7c5cff1f}.layout{grid-template-columns:280px 1fr;align-items:start;gap:16px;display:grid}@media (width<=1100px){.layout{grid-template-columns:1fr}}.sidebar{position:sticky;top:16px}.main{grid-template-columns:1fr 1fr;gap:16px;display:grid}.circuit-card,.bloch-card,.code-card{grid-column:1/-1}@media (width<=800px){.main{grid-template-columns:1fr}}.card{border:1px solid var(--border);box-shadow:var(--shadow-md);background:linear-gradient(#20203a80,#181826b3);border-radius:16px;padding:18px;position:relative;overflow:hidden}.card:before{content:"";pointer-events:none;background:radial-gradient(100% 30% at 50% 0,#7c5cff1a,#0000 60%);position:absolute;inset:0}.card-head{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:14px;display:flex}.card-head h2{letter-spacing:.4px;text-transform:uppercase;color:var(--text-bright);margin:0;font-size:14px;font-weight:600}.card-sub{color:var(--text-dim);font-size:12px}.palette{border:1px solid var(--border);box-shadow:var(--shadow-md);background:linear-gradient(#20203a80,#181826b3);border-radius:16px;padding:16px}.palette-title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-bright);align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.palette-title .dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 12px var(--accent);border-radius:999px}.palette-group{margin-bottom:12px}.palette-group-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:6px;font-size:11px}.palette-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.gate-tile{aspect-ratio:1;background:var(--bg-2);border:1px solid var(--border-strong);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:9px;flex-direction:column;justify-content:center;align-items:center;padding:4px;transition:all .12s;display:flex;position:relative}.gate-tile:hover{background:var(--bg-3);border-color:var(--gate-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--gate-color) 15%, transparent);transform:translateY(-1px)}.gate-tile:active{cursor:grabbing}.gate-symbol{font-family:var(--mono);color:var(--gate-color);text-shadow:0 0 12px color-mix(in srgb, var(--gate-color) 50%, transparent);font-size:17px;font-weight:700}.gate-name{color:var(--text-dim);text-align:center;margin-top:1px;font-size:9px;line-height:1}.palette-hint{color:var(--text-dim);border-top:1px dashed var(--border);margin-top:12px;padding-top:12px;font-size:11.5px;line-height:1.5}.circuit-grid-wrap{border-radius:12px;padding-bottom:8px;overflow-x:auto}.circuit-grid{min-height:80px;position:relative}.circuit-wires{pointer-events:none;position:absolute;inset:0}.wire-label{font-family:var(--mono);color:var(--text-dim);border-right:1px dashed var(--border);justify-content:space-around;align-items:center;font-size:13px;display:flex;position:absolute;left:0}.wire-label .wire-q{color:var(--text-bright);font-weight:600}.wire-label .wire-state{color:var(--text-dim)}.circuit-cell{border-radius:8px;place-items:center;transition:background .12s;display:grid;position:absolute}.circuit-cell.dropping{outline:2px dashed var(--accent);outline-offset:-3px;background:#7c5cff26}.placed-gate{background:linear-gradient(160deg, color-mix(in srgb, var(--gate-color) 30%, var(--bg-2)) 0%, var(--bg-2) 100%);border:1.5px solid var(--gate-color);width:44px;height:44px;color:var(--text-bright);font-family:var(--mono);cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 4px 14px color-mix(in srgb, var(--gate-color) 25%, transparent), inset 0 1px 0 #ffffff0f;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:all .12s;display:flex;position:relative}.placed-gate:hover{box-shadow:0 8px 22px color-mix(in srgb, var(--gate-color) 35%, transparent), inset 0 1px 0 #ffffff1a;transform:translateY(-1px)}.placed-symbol{color:var(--gate-color);text-shadow:0 0 10px color-mix(in srgb, var(--gate-color) 60%, transparent)}.placed-param{color:var(--text-dim);margin-top:1px;font-size:9px}.gate-x{background:var(--bg-1);border:1px solid var(--border-strong);width:18px;height:18px;color:var(--text-dim);opacity:0;border-radius:999px;place-items:center;font-size:12px;line-height:1;transition:all .12s;display:grid;position:absolute;top:-8px;right:-8px}.placed-gate:hover .gate-x{opacity:1}.gate-x:hover{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}.placed-gate.ctrl{box-shadow:none;background:0 0;border:none;width:30px;height:30px}.ctrl-dot{background:var(--gate-color);width:18px;height:18px;box-shadow:0 0 0 3px color-mix(in srgb, var(--gate-color) 25%, transparent), 0 0 18px color-mix(in srgb, var(--gate-color) 60%, transparent);border-radius:999px}.placed-gate.target{border:2px solid var(--gate-color);width:32px;height:32px;box-shadow:0 0 12px color-mix(in srgb, var(--gate-color) 50%, transparent);background:0 0;border-radius:999px}.target-circle{width:100%;height:100%;position:relative}.target-cross:before,.target-cross:after{content:"";background:var(--gate-color);position:absolute}.target-cross:before{width:2px;top:-2px;bottom:-2px;left:50%;transform:translate(-50%)}.target-cross:after{height:2px;top:50%;left:-2px;right:-2px;transform:translateY(-50%)}.placed-gate.swap{box-shadow:none;background:0 0;border:none;width:36px;height:36px}.swap-x{color:var(--gate-color);text-shadow:0 0 14px color-mix(in srgb, var(--gate-color) 60%, transparent);font-size:26px}.param-editor{background:var(--bg-1);border:1px solid var(--border-strong);z-index:10;box-shadow:var(--shadow-lg);border-radius:8px;align-items:center;gap:6px;padding:6px 8px;display:flex;position:absolute;top:100%;left:50%;transform:translate(-50%,6px)}.param-editor label{color:var(--text-dim);font-size:11px;font-family:var(--mono)}.param-editor input{background:var(--bg-2);border:1px solid var(--border);width:60px;color:var(--text-bright);font-family:var(--mono);border-radius:5px;padding:4px 6px;font-size:12px}.param-editor input:focus{border-color:var(--accent);outline:none}.warnings{color:var(--warn);background:#fbbf2414;border:1px solid #fbbf244d;border-radius:8px;flex-direction:column;gap:4px;margin-top:10px;padding:8px 12px;font-size:12px;display:flex}.bloch-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.bloch-sphere{background:radial-gradient(ellipse 80% 60% at 50% 30%, #7c5cff26, transparent 70%), var(--bg-1);border:1px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:12px;display:flex}.bloch-meta{width:100%;font-family:var(--mono);flex-direction:column;gap:4px;font-size:11px;display:flex}.bloch-label{text-align:center;color:var(--text-bright);letter-spacing:.4px;font-size:13px;font-weight:700}.bloch-coords{color:var(--text-dim);justify-content:space-between;display:flex}.bloch-coords b{margin-right:4px}.bloch-purity{color:var(--text-dim);border-top:1px dashed var(--border);justify-content:space-between;padding-top:4px;display:flex}.prob-chart{flex-direction:column;gap:12px;display:flex}.prob-header{color:var(--text-dim);font-size:12px}.prob-bars{align-items:flex-end;gap:6px;height:200px;padding:4px 2px;display:flex;overflow-x:auto}.prob-bar{flex-direction:column;flex:36px;align-items:center;gap:4px;min-width:36px;display:flex}.prob-bar.dim .prob-bar-track{border-color:var(--border);background:#ffffff05}.prob-bar-track{border:1px solid var(--border);background:#ffffff0a;border-radius:6px;align-items:flex-end;width:100%;height:150px;display:flex;position:relative;overflow:hidden}.prob-bar-fill{border-radius:5px 5px 0 0;width:100%;transition:height .22s cubic-bezier(.2,.8,.2,1),background .22s}.prob-bar-label{font-family:var(--mono);color:var(--text-dim);font-size:10px}.prob-bar-value{font-family:var(--mono);color:var(--text-bright);font-variant-numeric:tabular-nums;font-size:10px}.phase-legend{color:var(--text-dim);font-size:11px;font-family:var(--mono);align-items:center;gap:6px;display:flex}.phase-wheel{border:1px solid var(--border);border-radius:999px;width:200px;height:8px;display:flex;overflow:hidden}.phase-tick{flex:1}.state-panel-title{display:none}.state-list{font-family:var(--mono);flex-direction:column;gap:4px;max-height:240px;padding-right:4px;font-size:13px;display:flex;overflow-y:auto}.state-row{border:1px solid var(--border);background:#ffffff05;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;display:flex}.state-amp{color:var(--text-bright)}.state-mul{color:var(--text-dim)}.state-ket{color:var(--accent-3);font-weight:600}.state-phase{border:1px solid #fff3;border-radius:999px;width:14px;height:14px;margin-left:auto}.code-tabs{align-items:center;gap:6px;margin-bottom:10px;display:flex}.code-tab{background:var(--bg-2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .12s}.code-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px #7c5cff33}.code-tab:hover:not(.active){color:var(--text-bright);border-color:var(--border-strong)}.code-actions{gap:6px;margin-left:auto;display:flex}.code-actions .btn-soft{padding:6px 12px;font-size:12px}.code-pre{border:1px solid var(--border);max-height:320px;font-family:var(--mono);color:#d4d4f0;background:#0a0a14;border-radius:10px;margin:0;padding:14px 16px;font-size:12.5px;line-height:1.55;overflow:auto}.app-footer{text-align:center;color:var(--text-dim);justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:24px 8px 0;font-size:12px;display:flex}.dot-sep{opacity:.4}sub{vertical-align:-.25em;font-size:.7em}
