: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)}.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))}.histo-val{text-align:right;color:var(--muted)}.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);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}
