.console-wrapper{justify-content:center;align-items:flex-start;gap:1.5rem;padding:1rem 2rem 4rem;display:flex;position:relative}.console-body{z-index:1;background:linear-gradient(#facc15,#eab308,#ca8a04);border:12px solid #fde047;border-radius:48px;flex-direction:column;align-items:center;width:420px;min-height:720px;padding:1.5rem;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 50px #00000080,inset 0 4px 10px #ffffff80,inset 0 -8px 16px #0003}.console-body:before{content:"";background:#a1620766;border-radius:4px;width:96px;height:8px;position:absolute;top:12px;left:50%;transform:translate(-50%);box-shadow:inset 0 2px 4px #0003}.console-screen{background:#0a0a0a;border:8px solid #262626;border-radius:24px;flex:1;justify-content:center;align-items:center;width:100%;min-height:380px;margin-top:1rem;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 10px 30px #000c}.screen-background{opacity:.6;pointer-events:none;position:absolute;inset:0}.swirl-gradient{background:radial-gradient(circle,#dc262666,#581c8766,#000);animation:4s infinite alternate consolePulse;position:absolute;inset:0}@keyframes consolePulse{0%{opacity:.4}to{opacity:.7}}.grid-viewport{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.console-grid{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#00000080;border:1px solid #a855f733;border-radius:12px;gap:6px;padding:8px;display:grid;position:relative;box-shadow:0 0 30px #000c}.console-grid.placing-mode .grid-cell:not(.blocked):not(.occupied){cursor:crosshair}.grid-cell{background:#0009;border:1px solid #a855f71f;border-radius:8px;width:46px;height:46px;transition:border-color .15s,background .15s,box-shadow .15s;position:relative;box-shadow:inset 0 2px 8px #000c}.grid-cell.blocked{background:#1a1a1a;border-color:#ffffff0d;overflow:hidden;box-shadow:inset 0 2px 4px #00000080}.grid-cell.blocked:after{content:"";background:repeating-linear-gradient(45deg,#0000,#0000 5px,#ffffff05 5px 10px);position:absolute;inset:0}.grid-cell.occupied{box-shadow:none;cursor:pointer;background:0 0;border-color:#0000}.grid-cell.occupied:hover{background:#ffffff0d}.grid-cell.ghost-valid{background:#3b82f673;border-color:#60a5fa;animation:.5s infinite alternate ghostPulse;box-shadow:0 0 18px #3b82f680,inset 0 0 10px #3b82f64d}.grid-cell.ghost-invalid{background:#ef444459;border-color:#f87171;box-shadow:0 0 18px #ef444480,inset 0 0 10px #ef44444d}@keyframes ghostPulse{0%{opacity:.7}to{opacity:1}}.placed-piece{pointer-events:none;z-index:15}.css-piece{pointer-events:none}.css-block{border-radius:6px;position:relative;overflow:hidden}.css-block.off{opacity:0;pointer-events:none}.css-piece.blue .css-block.on{background:linear-gradient(135deg,#60a5fa,#2563eb);box-shadow:inset 0 1px 4px #ffffff59,0 0 12px #2563eb59}.css-piece.purple .css-block.on{background:linear-gradient(135deg,#c084fc,#7c3aed);box-shadow:inset 0 1px 4px #ffffff59,0 0 12px #7c3aed59}.css-piece.orange .css-block.on{background:linear-gradient(135deg,#fb923c,#ea580c);box-shadow:inset 0 1px 4px #ffffff59,0 0 12px #ea580c59}.inventory-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#0a0a0ae6;border:2px solid #eab30833;border-radius:24px;flex-direction:column;gap:.75rem;width:580px;max-width:45vw;height:720px;padding:1.25rem;display:flex;position:relative;box-shadow:0 30px 60px #0009}.inventory-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.inventory-title{color:#eab308;letter-spacing:-.025em;font-size:1.15rem;font-weight:800;font-family:var(--font-heading)}.inventory-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;font-size:1rem;transition:color .2s}.inventory-close:hover{color:#fff}.inventory-filters{flex-wrap:wrap;gap:.4rem;display:flex}.filter-btn{color:#fff9;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:.35rem .7rem;font-size:.72rem;font-weight:700;transition:all .2s}.filter-btn:hover{color:#fff;background:#ffffff1a}.filter-btn.active{background:var(--accent-primary,#eab308);color:#000;border-color:var(--accent-primary,#eab308)}.filter-btn[data-type=All].active{color:#fff;background:#f36;border-color:#f36}.pieces-scroll-container{scrollbar-width:thin;scrollbar-color:#a855f74d transparent;flex:1;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;padding:4px;display:grid;overflow-y:auto}.pieces-scroll-container::-webkit-scrollbar{width:4px}.pieces-scroll-container::-webkit-scrollbar-thumb{background:#eab3084d;border-radius:4px}.piece-card{cursor:pointer;background:#00000080;border:2px solid #ffffff14;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;transition:all .2s;display:flex}.piece-card:hover{background:#eab3080f;border-color:#eab30866}.piece-card-visual{background:#0006;border:1px solid #ffffff1a;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100px;display:flex;position:relative;overflow:hidden}.piece-card-img{object-fit:contain;filter:drop-shadow(0 4px 12px #00000080);max-width:80%;max-height:80%;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.piece-card-img.cartridge{filter:drop-shadow(0 0 15px #a855f766);max-width:120%;max-height:120%}.piece-card:hover .piece-card-img{transform:scale(1.1)}.piece-card-shape-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;padding:6px;display:flex;position:absolute;top:8px;right:8px}.piece-card-indicator{color:#3b82f6;z-index:5;background:#0a0a0acc;border:1px solid #fff3;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.8rem;display:flex;position:absolute;top:8px;right:8px}.piece-card.blue.selected{background:#3b82f61a;border-color:#3b82f6;box-shadow:0 0 15px #3b82f640}.piece-card.purple.selected{background:#a855f71a;border-color:#a855f7;box-shadow:0 0 15px #a855f740}.piece-card.orange.selected{background:#f973161a;border-color:#f97316;box-shadow:0 0 15px #f9731640}.piece-card-label{color:#fff6;text-transform:uppercase;letter-spacing:.08em;text-align:center;font-family:monospace;font-size:.68rem;line-height:1.2}.console-footer{flex-shrink:0;justify-content:center;align-items:center;width:100%;min-height:160px;margin-top:1.5rem;display:flex;position:relative}.control-btn{cursor:pointer;color:#fff6;background:#262626;border:4px solid #404040;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;box-shadow:0 4px 8px #0006}.control-btn:active{scale:.9}.inventory-toggle{position:absolute;bottom:24px;left:8px}.inventory-toggle.active{color:#eab308;border-color:#eab30880}.middle-disk{cursor:pointer;background:#171717;border:8px solid #262626;border-radius:50%;justify-content:center;align-items:center;width:144px;height:144px;transition:box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 30px #000000e6,0 8px 20px #0006,0 -2px 4px #fff3}.middle-disk.core-target{border-color:#eab30880;box-shadow:inset 0 0 30px #000000e6,0 0 30px #eab30866}.middle-disk-inner{background:radial-gradient(circle,#581c8733,#0000);border:2px solid #ffffff0d;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:8px}.spinning-glow{opacity:.3;background:conic-gradient(#0000,#a855f7,#0000);animation:10s linear infinite slowSpin;position:absolute;inset:0}@keyframes slowSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reset-btn{color:#ffffffe6;background:linear-gradient(#ef4444,#b91c1c);border:4px solid #7f1d1d;border-radius:50%;position:absolute;bottom:24px;right:8px}.reset-btn svg{transition:transform .5s}.reset-btn:active svg{transform:rotate(-180deg)}.active-core-icon{object-fit:contain;filter:drop-shadow(0 0 30px #a855f799);z-index:10;width:60%;height:60%;position:absolute;top:50%;left:50%;transform:translate(-45%,-50%)scale(2.2)}@keyframes coreBreath{0%,to{filter:drop-shadow(0 0 20px #a855f780);transform:scale(.95)}50%{filter:drop-shadow(0 0 45px #a855f7);transform:scale(1.1)}}.core-placeholder{border:2px dashed #ffffff1a;border-radius:50%;width:40px;height:40px}.selection-toast{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10000;color:#fff;background:#121212e6;border:2px solid #eab308;border-radius:20px;align-items:center;gap:16px;padding:12px 24px;animation:.4s cubic-bezier(.175,.885,.32,1.275) toastSlideUp;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 20px 50px #0009,0 0 30px #eab30833}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%)translateY(40px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast-icon-box{background:#0006;border:1px solid #ffffff1a;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.toast-icon{object-fit:contain;width:85%;height:85%}.toast-shape-badge{background:#000;border:1px solid #fff3;border-radius:4px;padding:2px;position:absolute;bottom:-4px;right:-4px;transform:scale(.8)}.toast-info{flex-direction:column;gap:2px;display:flex}.toast-name{color:#fff;font-size:.95rem;font-weight:800;font-family:var(--font-heading)}.toast-hint{color:#ffffff80;text-transform:uppercase;letter-spacing:.05em;font-family:monospace;font-size:.75rem}.toast-cancel{color:#fff9;cursor:pointer;background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:8px;padding:8px;font-size:1rem;transition:all .2s;display:flex}.toast-cancel:hover{color:#ef4444;background:#ef444433}.placed-piece-wrapper{position:relative}.placed-piece-click-area{cursor:pointer}.remove-piece-btn,.remove-cartridge-btn{color:#fff;cursor:pointer;opacity:0;z-index:100;background:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;position:absolute;top:-8px;right:-8px;transform:scale(.5);box-shadow:0 2px 8px #ef444466}.placed-piece-click-area:hover~.remove-piece-btn,.remove-piece-btn:hover,.middle-disk.has-core:hover .remove-cartridge-btn{opacity:1;pointer-events:auto;transform:scale(1)}.console-grid.placing-mode .remove-piece-btn{display:none!important}.remove-piece-btn:hover,.remove-cartridge-btn:hover{background:#f87171;transform:scale(1.1);box-shadow:0 4px 12px #ef444499}.middle-disk{position:relative}.remove-cartridge-btn{width:24px;height:24px;font-size:12px;top:50%;right:-10px;transform:translateY(-50%)scale(.5)}.middle-disk.has-core:hover .remove-cartridge-btn{transform:translateY(-50%)scale(1)}.remove-cartridge-btn:hover{transform:translateY(-50%)scale(1.1)}@media (max-width:820px){.console-wrapper{flex-direction:column;align-items:center;gap:1rem;padding:1rem}.inventory-sidebar{z-index:10001;border-top:2px solid var(--accent-primary);border-radius:28px 28px 0 0;width:100%;max-width:100%;height:auto;max-height:80vh;margin:0;padding:1.5rem 1.5rem 3rem;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 40px #000c}.inventory-header{padding-bottom:1rem}}@media (max-width:500px){.console-body{border-width:8px;border-radius:36px;width:340px;min-height:640px;padding:1rem}.console-screen{min-height:320px}.grid-cell{width:38px;height:38px}.middle-disk{width:110px;height:110px}.selection-toast{padding:8px 14px;font-size:.75rem;bottom:1rem}}
