:root{--bg: #0a0e1a;--bg2: #121829;--panel: #161d33;--panel2: #1d2742;--line: #2a3756;--text: #e6ecff;--muted: #8b97b8;--cyan: #2dd4bf;--cyan-dim: #155e57;--gold: #eab308;--danger: #ef4444;--glow: 0 0 12px rgba(45, 212, 191, .4)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(1200px 800px at 70% -10%,#15203a 0%,var(--bg) 60%);color:var(--text);font-family:Segoe UI,Noto Sans Thai,system-ui,sans-serif}h1,h2,h3{font-weight:700}button{font-family:inherit;cursor:pointer;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:8px;padding:8px 14px;font-size:14px;transition:all .12s ease}button:hover:not(:disabled){border-color:var(--cyan);box-shadow:var(--glow)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--cyan);color:#04201c;border-color:var(--cyan);font-weight:700}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.ghost{background:transparent}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:.1;z-index:-1;pointer-events:none}.app{max-width:1560px;margin:0 auto;padding:16px;position:relative}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.title{font-size:22px;letter-spacing:.5px}.title .ket{color:var(--cyan);font-size:inherit}.badge{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:3px 10px}.layout{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}@media(max-width:940px){.layout{grid-template-columns:1fr}}.card-panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;min-width:0}.section-title{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:0 0 10px}.board{display:flex;flex-direction:column;gap:10px;overflow-x:auto;padding-bottom:6px}.noise-badge{font-size:11px;font-weight:800;padding:1px 6px;border-radius:999px;white-space:nowrap}.noise-badge.hidden{color:#f472b6;background:#f472b624;border:1px solid rgba(244,114,182,.4)}.noise-badge.on{color:#f472b6;background:#f472b633;border:1px solid #f472b6;box-shadow:0 0 8px #f472b666}.zones-head{display:grid;grid-template-columns:112px repeat(4,minmax(72px,1fr)) 18px 92px 88px 66px 66px;gap:6px;font-size:11px;color:var(--muted);align-items:end}.zones-head .z-simple{grid-column:2 / 6;text-align:center;color:var(--cyan)}.qrow{display:grid;grid-template-columns:112px repeat(4,minmax(72px,1fr)) 18px 92px 88px 66px 66px;gap:6px;align-items:center}.qlabel{display:flex;align-items:center;gap:6px;font-size:12px}.chip{width:12px;height:12px;border-radius:3px;flex:none}.wire{position:relative}.cell{height:64px;border:1px solid var(--line);border-radius:8px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;position:relative}.cell.gate{background:var(--panel2)}.cell.gate.owner{box-shadow:inset 0 0 0 2px currentColor}.cell.swap{color:var(--cyan)}.cell.empty{color:var(--line);font-size:12px}.cell.target{outline:2px dashed var(--cyan);outline-offset:1px;cursor:pointer}.cell.target:hover{background:var(--cyan-dim)}.cell.pickable{outline:2px dashed var(--gold);outline-offset:1px;cursor:pointer}.cell.pickable:hover{box-shadow:0 0 10px #eab30880}.cell.picked{outline:2px solid var(--gold);box-shadow:0 0 12px #eab30899}.noise-cell{height:64px;display:flex;align-items:center;justify-content:center;font-size:14px}.noise-on{color:#f472b6;font-weight:700}.noise-hidden{color:#db73a6;font-weight:700}.divider{width:1px;height:52px;background:var(--line);margin:0 auto}.ket{font-size:24px;text-align:center;font-weight:700}.ket.sup{color:var(--gold)}.ket.def{color:var(--cyan)}.cnotzone{border:1px dashed var(--cyan-dim);border-radius:8px;height:64px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted)}.result{font-size:22px;text-align:center;font-weight:700;color:var(--text)}.cnot-badge{font-size:10px;color:var(--cyan)}.hand{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px;align-items:flex-end}.gcard{width:96px;height:134px;border-radius:10px;border:1px solid var(--line);background:linear-gradient(160deg,var(--panel2),var(--panel));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;padding:6px;text-align:center;overflow:hidden}.gcard.has-img{width:190px;height:auto;padding:0;background:#0b0f1c}.gcard-img{display:block;width:100%;height:auto}.gcard:hover{border-color:var(--cyan);transform:scale(1.18);transform-origin:bottom center;box-shadow:var(--glow);z-index:10}.gcard.selected{border-color:var(--cyan);box-shadow:var(--glow);transform:scale(1.1);transform-origin:bottom center;z-index:9}.gcard .big{font-size:30px;font-weight:800}.gcard .kindtag{font-size:9px;text-transform:uppercase;letter-spacing:1px}.gcard .nm{font-size:9px;color:var(--muted);line-height:1.1}.gcard.kind-strategy{background:linear-gradient(160deg,#1c2b22,var(--panel))}.gcard.kind-noise{background:linear-gradient(160deg,#2b1c2a,var(--panel))}.gcard.kind-instant{background:linear-gradient(160deg,#2b261c,var(--panel))}.mission-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line);font-size:13px}.mission-row .pts{color:var(--cyan);font-weight:700}.obj-bits{letter-spacing:4px;font-size:20px;font-weight:800;color:var(--gold)}.scoretable{width:100%;border-collapse:collapse;font-size:13px}.scoretable th,.scoretable td{text-align:center;padding:5px 4px;border-bottom:1px solid var(--line)}.scoretable td.name{text-align:left}.log{font-size:12px;color:var(--muted);max-height:160px;overflow-y:auto;display:flex;flex-direction:column-reverse;gap:3px}.turnbar{display:flex;align-items:center;gap:10px;margin:4px 0 12px}.turn-dot{width:10px;height:10px;border-radius:50%}.controls{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.hint{font-size:12px;color:var(--muted);margin-top:6px;min-height:16px}.action-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.action-list button{text-align:left}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050810c7;display:flex;align-items:center;justify-content:center;z-index:50}.overlay.overlay-top{z-index:70}.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px;width:min(560px,92vw);box-shadow:0 20px 60px #00000080}.modal h2{margin-top:0}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;color:var(--muted)}.seg{display:flex;gap:6px;flex-wrap:wrap}.seg button.on{background:var(--cyan);color:#04201c;border-color:var(--cyan)}.winner{font-size:20px;font-weight:800}.countdown-bar{height:7px;border-radius:999px;background:var(--bg2);overflow:hidden;border:1px solid var(--line)}.countdown-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--danger));transition:width .12s linear}.countdown-num{font-size:13px;font-weight:700;color:var(--gold);white-space:nowrap;font-variant-numeric:tabular-nums}.interrupt-toast{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:55;width:min(440px,94vw);background:#161d33eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--gold);border-radius:12px;padding:12px 14px;box-shadow:0 10px 34px #00000080,0 0 16px #eab30840;animation:toastIn .22s ease both}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-14px)}to{opacity:1;transform:translate(-50%)}}.it-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.it-zap{font-size:16px}.it-title{font-size:14px;font-weight:800;letter-spacing:.3px}.it-head .countdown-num{margin-left:auto}.it-msg{font-size:13px;line-height:1.45;margin:0 0 10px;color:var(--text)}.it-actions{display:flex;gap:8px;margin-top:10px}.it-actions button{flex:1;padding:9px 10px;font-size:13px}@media(max-width:520px){.interrupt-toast{top:8px}.it-actions{flex-direction:column}}.center{text-align:center}.dice{font-size:40px}.histo{display:flex;flex-direction:column;gap:5px;margin-top:6px}.histo-row{display:grid;grid-template-columns:56px 1fr 36px;gap:8px;align-items:center;font-size:13px}.histo-key{font-family:ui-monospace,monospace;letter-spacing:1px;color:var(--gold)}.histo-bar{background:var(--bg2);border-radius:4px;height:16px;overflow:hidden}.histo-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--cyan-dim),var(--cyan));transition:width .45s ease}.histo-val{text-align:right;color:var(--muted);transition:color .2s ease}.shotreveal{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin:8px 0 4px;min-height:56px}.shot-die{font-size:26px;animation:dieRoll .5s ease;display:inline-block}@keyframes dieRoll{0%{transform:rotate(-25deg) scale(.7)}50%{transform:rotate(20deg) scale(1.15)}to{transform:rotate(0) scale(1)}}.shot-label{font-size:14px;font-weight:700;color:var(--text)}.shot-bits{display:flex;gap:6px;margin-left:auto}.shot-bit{width:30px;height:38px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,monospace;font-size:20px;font-weight:800;color:var(--gold);background:var(--panel2);border:1px solid var(--gold);animation:bitPop .32s cubic-bezier(.2,1.5,.4,1) both}@keyframes bitPop{0%{transform:translateY(-8px) scale(.5);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.histo-row{transition:transform .2s ease}.histo-row.hit{transform:scale(1.015)}.histo-row.hit .histo-key{text-shadow:0 0 10px rgba(234,179,8,.9)}.histo-row.hit .histo-bar{box-shadow:0 0 10px #2dd4bf8c}.histo-row.hit .histo-val{color:var(--cyan);font-weight:800}.measure-done{font-size:13px;font-weight:700;color:var(--cyan);margin:6px 0 12px}@media(prefers-reduced-motion:reduce){.shot-die,.shot-bit{animation:none}.histo-bar>span{transition:none}}.intro{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1100px 700px at 50% -10%,#16223f 0%,var(--bg) 62%);animation:introIn .6s ease both}@keyframes introIn{0%{opacity:0}to{opacity:1}}.intro-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:.07;filter:saturate(1.1);pointer-events:none}.intro-field{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.qp{position:absolute;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px #2dd4bfcc;opacity:.5;animation-name:qpDrift;animation-timing-function:ease-in-out;animation-iteration-count:infinite}.qp.gold{background:var(--gold);box-shadow:0 0 8px #eab308cc}@keyframes qpDrift{0%,to{transform:translateY(0) scale(1);opacity:.25}50%{transform:translateY(-26px) scale(1.4);opacity:.7}}.intro-inner{position:relative;text-align:center;max-width:760px;width:100%}.intro-stage{display:flex;align-items:center;justify-content:center;width:min(460px,80vw);margin:0 auto 18px}.qnode{position:relative;width:112px;height:112px;flex:none;display:flex;align-items:center;justify-content:center}.qorb{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;letter-spacing:.5px;background:radial-gradient(circle at 35% 30%,#1d2742,#0c1322);animation:orbFloat 4.5s ease-in-out infinite}.qorb.cyan{color:var(--cyan);border:1px solid var(--cyan);box-shadow:0 0 22px #2dd4bf80,inset 0 0 18px #2dd4bf2e}.qorb.gold{color:var(--gold);border:1px solid var(--gold);box-shadow:0 0 22px #eab30873,inset 0 0 18px #eab30829;animation-delay:-2.2s}@keyframes orbFloat{0%,to{transform:translateY(-5px)}50%{transform:translateY(5px)}}.qring{position:absolute;top:0;right:0;bottom:0;left:0;animation:spin 5s linear infinite}.qring.rev{animation-direction:reverse;animation-duration:6.5s}.qspark{position:absolute;top:2px;left:50%;width:7px;height:7px;margin-left:-3.5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}.qspark.gold{background:var(--gold);box-shadow:0 0 10px var(--gold)}@keyframes spin{to{transform:rotate(360deg)}}.bond{flex:1;height:3px;position:relative;border-radius:3px;background:linear-gradient(90deg,var(--cyan),rgba(139,151,184,.25),var(--gold));box-shadow:0 0 10px #2dd4bf59}.bond-pulse{position:absolute;top:50%;left:0;width:9px;height:9px;margin-top:-4.5px;border-radius:50%;background:#fff;box-shadow:0 0 12px var(--cyan);animation:bondTravel 2.4s ease-in-out infinite}@keyframes bondTravel{0%{left:0;opacity:0}15%{opacity:1}85%{opacity:1}to{left:100%;opacity:0}}.intro-title{font-size:clamp(34px,7vw,60px);margin:0 0 6px;letter-spacing:1px;text-shadow:0 2px 30px rgba(0,0,0,.5)}.intro-title .ket{color:var(--cyan);font-size:1.06em;font-weight:800;animation:ketGlow 3s ease-in-out infinite}@keyframes ketGlow{0%,to{text-shadow:0 0 10px rgba(45,212,191,.4)}50%{text-shadow:0 0 26px rgba(45,212,191,.9)}}.intro-tag{color:var(--muted);font-size:15px;line-height:1.6;max-width:560px;margin:0 auto 26px}.intro-tag b{color:var(--text);font-weight:700}.concepts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 auto 28px;max-width:660px}@media(max-width:620px){.concepts{grid-template-columns:1fr}}.concept{background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:12px;padding:16px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}.concept:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:var(--glow)}.concept .c-ket{font-size:24px;font-weight:800;color:var(--cyan);font-family:ui-monospace,monospace}.concept b{font-size:14px}.concept span:last-child{font-size:12px;color:var(--muted);line-height:1.45}.intro-cta{font-size:17px;padding:13px 30px;border-radius:10px;animation:ctaPulse 2.6s ease-in-out infinite}@keyframes ctaPulse{0%,to{box-shadow:0 0 #2dd4bf00}50%{box-shadow:0 0 22px #2dd4bf99}}.intro-foot{color:var(--muted);font-size:12px;margin-top:14px}.intro-cta-row{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}.intro-howto{font-size:15px;padding:13px 22px;border-radius:10px}@media(prefers-reduced-motion:reduce){.intro,.qp,.qorb,.qring,.bond-pulse,.intro-title .ket,.intro-cta{animation:none}}.gateref{position:fixed;right:16px;bottom:16px;z-index:40;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.gateref-fab{background:var(--panel2);border:1px solid var(--cyan);color:var(--text);border-radius:999px;padding:9px 14px;font-size:13px;font-weight:700;box-shadow:0 6px 18px #0006;white-space:nowrap}.gateref-fab:hover:not(:disabled){box-shadow:var(--glow)}.gateref-card{width:min(300px,86vw);background:#161d33f5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:14px;padding:12px;box-shadow:0 14px 40px #0000008c;animation:toastIn .2s ease both}.gateref-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;color:var(--muted);margin-bottom:8px}.gateref-x{padding:2px 8px}.gateref-img{display:block;width:100%;height:auto;border-radius:10px;background:#fff}.gateref-note{font-size:11px;color:var(--muted);margin:8px 0 0;line-height:1.5;text-align:center}.modal.howto{width:min(680px,94vw);max-height:88vh;overflow-y:auto}.howto-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.howto-head h2{margin:0;font-size:22px}.howto-p{font-size:14px;line-height:1.65;color:var(--text);margin:4px 0 8px}.howto-ul{font-size:14px;line-height:1.7;color:var(--text);margin:4px 0 8px;padding-left:22px}.howto-ul li{margin-bottom:3px}.howto-img{display:block;width:min(280px,70%);height:auto;margin:6px auto 4px;border-radius:12px;background:#fff;padding:6px}.howto .section-title{margin-top:18px;color:var(--cyan)}.modal.gallery{width:min(920px,95vw);max-height:90vh;overflow-y:auto}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:10px}.gallery-cell{padding:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;position:relative;cursor:zoom-in}.gallery-cell img{display:block;width:100%;height:auto}.gallery-cell:hover{border-color:var(--cyan);box-shadow:var(--glow)}.gallery-num{position:absolute;top:5px;left:5px;background:#0000009e;color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:999px}.gallery-zoom{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#050810eb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px;cursor:zoom-out}.gallery-zoom img{max-width:min(560px,92vw);max-height:78vh;border-radius:12px;box-shadow:0 20px 60px #0009;cursor:default}.gallery-zoom-bar{display:flex;gap:18px;align-items:center;color:var(--text);font-weight:700}.tutorial{position:fixed;top:0;right:0;bottom:0;left:0;z-index:65;display:flex;flex-direction:column;padding:16px clamp(12px,4vw,40px) 0;background:radial-gradient(1100px 700px at 50% -10%,#16223f 0%,var(--bg) 62%);overflow:hidden;animation:introIn .4s ease both}.tut-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:.06;z-index:-1;pointer-events:none}.tut-head{flex:none;display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;max-width:1000px;margin:0 auto 12px}.tut-head-title{font-size:19px;font-weight:800;letter-spacing:.4px}.tut-head-title .ket{color:var(--cyan);font-size:inherit;text-align:left}.tut-menu-wrap{flex:1;min-height:0;width:100%;max-width:1000px;margin:0 auto;overflow-y:auto;padding-bottom:24px}.tut-menu-lead{color:var(--muted);font-size:15.5px;line-height:1.7;text-align:center;max-width:680px;margin:4px auto 0}.tut-menu{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin-top:18px}.tut-chap{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:16px;border-radius:14px;min-height:158px;background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line)}.tut-chap:hover{border-color:var(--cyan);box-shadow:var(--glow);transform:translateY(-3px)}.tut-chap.done{border-color:var(--cyan-dim)}.tut-chap-icon{font-size:30px;line-height:1}.tut-chap-icon.sm{font-size:20px}.tut-chap-num{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.tut-chap-title{font-size:18.5px;font-weight:800}.tut-chap-sub{font-size:13.5px;color:var(--muted);line-height:1.5}.tut-chap-cta{margin-top:auto;color:var(--cyan);font-size:14px;font-weight:700}.tut-chap.done .tut-chap-cta{color:#4ade80}.tut-flow{flex:1;min-height:0;width:100%;max-width:1000px;margin:0 auto;display:flex;flex-direction:column}.tut-flow-top{flex:none;display:flex;align-items:center;gap:12px;margin-bottom:8px}.tut-flow-heading{display:flex;align-items:center;gap:8px;font-weight:800}.tut-dots{display:flex;gap:6px;margin:0 auto}.tut-dot{width:9px;height:9px;border-radius:50%;background:var(--line);transition:all .2s ease}.tut-dot.past{background:var(--cyan-dim)}.tut-dot.on{background:var(--cyan);box-shadow:var(--glow)}.tut-flow-count{font-size:12px;color:var(--muted);white-space:nowrap}.tut-step{flex:1;min-height:0;overflow-y:auto;padding:6px 2px 12px;font-size:16.5px}.tut-step-title{font-size:24px;margin:0 0 14px}.tut-nav{flex:none;display:flex;align-items:center;gap:10px;padding:12px 0 16px;border-top:1px solid var(--line)}.tut-gate-note{font-size:12px;color:var(--gold)}.tut-doneview{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:4px}.tut-done-badge{font-size:64px;animation:orbFloat 3.5s ease-in-out infinite}.tut-done-title{font-size:26px;margin:6px 0}.tut-done-sub{color:var(--muted)}.tut-teach p{font-size:16.5px;line-height:1.75;margin:8px 0}.tut-ul{font-size:16px;line-height:1.85;padding-left:24px;margin:8px 0}.tut-ul li{margin-bottom:5px}.tut-rule{background:#eab30814;border-left:3px solid var(--gold);padding:10px 14px;border-radius:6px;font-size:15px;line-height:1.65}.tut-stage{display:flex;justify-content:center;margin:14px 0}.tut-tr{display:flex;align-items:center;gap:10px;margin:7px 0;font-size:18px}.tut-tr-gate,.tut-seq-gate{padding:2px 10px;border-radius:6px;background:var(--panel2);border:1px solid var(--cyan-dim);color:var(--cyan);font-weight:800;font-family:ui-monospace,monospace}.tut-tr-note{font-size:12px;color:var(--muted)}.tut-arrow{color:var(--muted)}.tut-ket{display:inline-flex;align-items:center;padding:3px 10px;border-radius:8px;font-weight:800;font-size:17px;border:1px solid;font-family:ui-monospace,monospace}.tut-ket.def{color:var(--cyan);border-color:var(--cyan-dim);background:#2dd4bf14}.tut-ket.sup{color:var(--gold);border-color:#eab30873;background:#eab30814}.tut-ket.big{font-size:26px;padding:7px 13px}.tut-gate{width:52px;height:52px;font-size:22px;font-weight:800;border-radius:8px;border:1px solid var(--line);background:var(--panel2);color:var(--text)}.tut-gate:hover:not(:disabled){border-color:var(--cyan);box-shadow:var(--glow)}.tut-gate:disabled{opacity:1;cursor:default}.tut-gate.dim{color:var(--muted)}.tut-gatemap{width:min(260px,80vw);height:auto}.gm-node.def{fill:#2dd4bf1f;stroke:var(--cyan);stroke-width:2}.gm-node.sup{fill:#eab3081f;stroke:var(--gold);stroke-width:2}.gm-ket{fill:var(--text);font-size:14px;font-weight:700;font-family:ui-monospace,monospace}.gm-edge{stroke:var(--line);stroke-width:2}.gm-lab{font-size:14px;font-weight:800;fill:var(--muted)}.gm-lab.x{fill:var(--cyan)}.gm-lab.z{fill:var(--gold)}.gm-lab.h{fill:var(--text)}.tut-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:12px;margin:12px 0}.tut-cards.single{grid-template-columns:minmax(0,340px);justify-content:center}.tut-card{display:flex;gap:12px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:12px;background:var(--panel2)}.tut-card img{width:104px;height:auto;border-radius:8px;flex:none;background:#0b0f1c}.tut-card-body b{display:block;font-size:15.5px;margin-bottom:4px}.tut-card-body span{font-size:13.5px;color:var(--muted);line-height:1.55}.tut-puzzle{margin-top:12px}.tut-goal{font-size:16px;line-height:1.65;margin-bottom:14px}.tut-seq{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:14px;background:var(--bg2);border:1px solid var(--line);border-radius:12px}.tut-seq-step{display:inline-flex;align-items:center;gap:8px}.tut-result{padding:2px;border-radius:10px;transition:box-shadow .2s ease}.tut-result.ok{box-shadow:0 0 14px #2dd4bf99;border-radius:12px}.tut-palette{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.tut-puzzle-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px}.tut-count{font-size:14.5px;color:var(--muted);margin-right:auto}.tut-success{background:#22c55e1f;border:1px solid #22c55e;color:#4ade80;padding:11px 14px;border-radius:8px;margin-top:12px;font-weight:700;font-size:16px}.tut-hint-line{font-size:14px;color:var(--muted);margin-top:8px}.tut-hint-line.wrong{color:#fb7185}.tut-rows{display:flex;flex-direction:column;gap:8px;margin:12px 0}.tut-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg2);cursor:pointer;transition:all .12s ease}.tut-rows:not(.static) .tut-row:hover{border-color:var(--cyan)}.tut-rows.static .tut-row{cursor:default}.tut-row.sel{border-color:var(--gold);box-shadow:0 0 12px #eab30866}.tut-row.hit{border-color:var(--cyan-dim);background:#2dd4bf0d}.tut-row-name{width:58px;color:var(--muted);font-size:13px;flex:none}.tut-row-arrow{margin-left:auto;color:var(--muted);font-size:12px}.tut-swap-bridge{display:flex;justify-content:center}.tut-choices{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0}.tut-choice{padding:13px 24px;font-size:18px;min-width:70px;font-weight:700}.tut-choice:disabled{opacity:1;cursor:default}.tut-choice.correct{background:#22c55e2e;border-color:#22c55e;color:#4ade80}.tut-choice.wrong{background:#ef444429;border-color:var(--danger);color:#fda4af}.tut-explain{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:12px 14px;margin-top:8px;font-size:15px;line-height:1.65}.tut-dice{font-size:80px;text-align:center;line-height:1;color:var(--gold)}.tut-dice-num{text-align:center;color:var(--muted);font-size:15px;margin-top:4px}.tut-demo{display:flex;flex-direction:column;gap:10px;margin-top:10px}.tut-bell{display:flex;flex-wrap:wrap;gap:8px}.tut-bell-shot{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg2)}.tut-bell-shot.eq{border-color:var(--cyan-dim)}.tut-bell-bit{width:30px;height:30px;display:grid;place-items:center;font-family:ui-monospace,monospace;font-weight:800;font-size:16px;color:var(--cyan);background:var(--panel2);border:1px solid var(--cyan-dim);border-radius:6px}.tut-bell-bit.sm{width:20px;height:20px;font-size:12px;display:inline-grid;vertical-align:middle}.tut-bell-link{color:var(--muted);font-size:13px}.tut-bell-legend{font-size:14.5px;color:var(--muted);line-height:1.65}.tut-truth{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:12px 0;background:var(--bg2)}.tut-truth-row{display:grid;grid-template-columns:1fr 1.7fr;gap:8px;padding:9px 14px;border-bottom:1px solid var(--line);font-size:14px}.tut-truth-row:last-child{border-bottom:none}.tut-truth-row.head{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.tut-score{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:12px 0;background:var(--bg2)}.tut-score-row{display:flex;justify-content:space-between;gap:10px;padding:11px 16px;border-bottom:1px dashed var(--line);font-size:15.5px}.tut-score-row:last-child{border-bottom:none}.tut-score-row .ok{color:#4ade80;font-weight:700}.tut-score-row .no{color:var(--muted)}@media(max-width:560px){.tut-head-title{font-size:16px}.tut-flow-count{display:none}}@media(prefers-reduced-motion:reduce){.tutorial,.tut-done-badge{animation:none}}.tut-circuit{width:100%;max-width:540px;height:auto;display:block;margin:12px 0}.cd-wire{stroke:var(--line);stroke-width:2.5}.cd-wire.sel{stroke:var(--gold);filter:drop-shadow(0 0 4px rgba(234,179,8,.75))}.cd-ket{font-family:ui-monospace,monospace;font-weight:800;font-size:18px}.cd-ket.def{fill:var(--cyan)}.cd-ket.sup{fill:var(--gold)}.cd-ket.q{fill:var(--muted)}.cd-label{fill:var(--muted);font-size:13px}.cd-head{fill:var(--muted);font-size:12px;letter-spacing:.4px}.cd-ctrl{fill:var(--cyan)}.cd-link{stroke:var(--cyan);stroke-width:2.5}.cd-tgt circle,.cd-tgt line{stroke:var(--cyan);stroke-width:2.5;fill:none}.cd-swap line{stroke:var(--gold);stroke-width:3.5;stroke-linecap:round}.cd-gate{fill:var(--panel2);stroke:var(--cyan-dim);stroke-width:1.5}.cd-gate-txt{fill:var(--text);font-weight:800;font-size:17px;font-family:ui-monospace,monospace}.cd-hit{fill:transparent;cursor:pointer}.tut-case{margin:14px 0}.tut-case-cap,.tut-play-out{font-size:15.5px;line-height:1.65;padding:11px 14px;border-radius:8px;margin-top:4px;border:1px solid var(--line);background:var(--bg2)}.tut-case-cap.flip,.tut-play-out.flip{border-color:var(--gold);background:#eab30814}.tut-case-cap.keep,.tut-play-out.keep{border-color:var(--cyan-dim);background:#2dd4bf0f}.tut-play{margin:10px 0}.tut-play-toggles{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:6px}.tut-toggle{display:flex;flex-direction:column;gap:6px}.tut-toggle>span{font-size:14px;color:var(--muted);font-weight:700}.tut-toggle .seg button{font-size:17px;font-family:ui-monospace,monospace;padding:9px 18px}.tut-play-out{margin-top:10px;font-weight:600}.tut-alts{margin-top:12px;background:var(--bg2);border:1px dashed var(--cyan-dim);border-radius:10px;padding:12px 14px}.tut-alts-head{font-size:14.5px;color:var(--muted);margin-bottom:8px}.tut-alts-list{display:flex;flex-wrap:wrap;gap:10px}.tut-alt{display:inline-flex;align-items:center;padding:7px 13px;border-radius:8px;background:var(--panel2);border:1px solid var(--cyan-dim);font-family:ui-monospace,monospace;font-size:16px}.tut-alt b{color:var(--cyan);font-weight:800}.tut-tt{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:14px 0;background:var(--bg2);max-width:460px}.tut-tt-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:11px 14px;border-bottom:1px solid var(--line);align-items:center;justify-items:center;font-size:15px}.tut-tt-row:last-child{border-bottom:none}.tut-tt-row.head{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.4px;background:#ffffff05}.tut-tt-row.flip{background:#eab3080f}
