:root{color:#17231f;background:#eef2ed;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{width:min(1120px,100%);margin:0 auto;padding:18px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.header-actions{display:flex;gap:8px;align-items:center}.eyebrow{margin:0 0 4px;color:#5a6f66;font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2{margin:0}h1{font-size:clamp(2rem,5vw,3.4rem);line-height:.95}.icon-button{display:inline-grid;width:42px;height:42px;place-items:center;border-radius:8px;background:#fff;color:#18372e;box-shadow:0 1px #101e191f}.sound-icon{width:22px;height:22px;fill:currentColor}.sound-stroke{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.mode-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:16px;padding:4px;border:1px solid #d4ddd8;border-radius:8px;background:#f8faf8}.mode-tabs button{min-height:42px;border-radius:6px;background:transparent;color:#415a50;font-weight:800}.mode-tabs .active{background:#173a30;color:#f6fbf8}.play-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:18px;align-items:start}.game-column,.side-panel{display:grid;gap:12px}.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stats-bar div,.result-panel,.inventory,.shoot-controls,.import-export,.editor-shell{border:1px solid #d3ddd7;border-radius:8px;background:#fbfcfb;box-shadow:0 1px #0a231a14}.stats-bar div{padding:10px 12px}.stats-bar span{display:block;margin-bottom:2px;color:#6a7b74;font-size:.76rem;font-weight:700}.stats-bar strong{font-size:1.1rem}.inventory{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px}.inventory button,.shoot-controls button,.share-button,.import-export button,.editor-actions button,.tool-palette button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:7px;background:#e8eee9;color:#17372f;font-weight:800}.inventory button{min-height:74px;cursor:grab}.inventory button:active{cursor:grabbing}.inventory-piece{position:relative;display:block;width:48px;height:48px;overflow:hidden;border-radius:6px;background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.08),transparent 62%),#1b674f;box-shadow:inset 0 0 0 1px #0a2a2047,0 4px 12px #0f1f191f}.drag-preview{position:fixed;left:0;top:0;z-index:50;width:56px;height:56px;pointer-events:none;will-change:transform}.drag-preview .inventory-piece{width:56px;height:56px;box-shadow:0 14px 26px #07181247,inset 0 0 0 1px #0a2a2047}.inventory .active,.tool-palette .active{outline:3px solid #dfb33d;background:#fff8df}.inventory strong{display:inline-grid;min-width:24px;height:24px;place-items:center;border-radius:999px;background:#16372f;color:#fff;font-size:.82rem}.shoot-controls{display:grid;gap:8px;padding:10px}.primary,.shoot-controls .primary{background:#174d3f;color:#fff}.result-panel{display:grid;gap:4px;padding:14px;color:#42584f}.result-panel strong{color:#1c3c33}.result-panel.win{border-color:#63ab76;background:#eff9ef}.result-panel.loop{border-color:#e2ba52;background:#fff8e5}.share-button{width:100%}.errors{margin:0;padding:10px 14px 10px 30px;border:1px solid #d48768;border-radius:8px;background:#fff5ef;color:#7d3223}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:20px;background:#0a18136b;z-index:20}.modal{position:relative;width:min(520px,100%);padding:24px;border-radius:8px;background:#fff;box-shadow:0 24px 80px #04120e47}.modal .close{position:absolute;top:12px;right:12px}.modal p{color:#435850;line-height:1.55}@media(max-width:860px){.play-layout{grid-template-columns:1fr}.side-panel{order:-1}}@media(max-width:560px){.app-shell{padding:12px}.stats-bar{grid-template-columns:1fr}}.table-wrap{position:relative}.table-rail{position:relative;isolation:isolate;width:min(100%,500px);margin:0 auto;padding:clamp(14px,2.4vw,24px);border:clamp(12px,2.6vw,22px) solid #573c25;border-radius:12px;background:radial-gradient(circle at 18% 12%,rgba(255,255,255,.12),transparent 16%),radial-gradient(circle at 74% 92%,rgba(255,255,255,.08),transparent 18%),repeating-linear-gradient(90deg,rgba(38,20,10,.13) 0 18px,transparent 18px 54px),linear-gradient(#825936,#4b2f1d);box-shadow:inset 0 0 0 2px #ffffff29,inset 0 0 0 8px #25150c38,inset 0 -12px 22px #130a053d,0 18px 36px #141b182e}.rail-detail{position:absolute;z-index:1;display:flex;align-items:center;justify-content:space-around;pointer-events:none}.rail-detail:after{content:"";position:absolute;background:linear-gradient(rgba(255,255,255,.16),transparent 50%),#24885b;box-shadow:inset 0 1px #ffffff3d,inset 0 -3px #0b422b6b}.rail-detail span{width:9px;height:9px;transform:rotate(45deg);background:linear-gradient(135deg,#f5ead4,#bca77c);box-shadow:0 1px 2px #00000057}.rail-detail-top,.rail-detail-bottom{left:var(--board-x);width:var(--board-size);height:30px;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 35%,rgba(0,0,0,.22)),linear-gradient(90deg,#4a2e1a,#805633 34%,#5e3a21 72%,#3f2616)}.rail-detail-top{top:calc(var(--board-y) - 36px);border-bottom:1px solid rgba(21,95,62,.7)}.rail-detail-bottom{top:calc(var(--board-y) + var(--board-size) + 6px);border-top:1px solid rgba(21,95,62,.7)}.rail-detail-top:after{left:0;right:0;bottom:-10px;height:10px;clip-path:polygon(0 0,100% 0,calc(100% - 10px) 100%,10px 100%)}.rail-detail-bottom:after{left:0;right:0;top:-10px;height:10px;clip-path:polygon(10px 0,calc(100% - 10px) 0,100% 100%,0 100%)}.rail-detail-left,.rail-detail-right{top:var(--board-y);width:30px;height:var(--board-size);flex-direction:column;background:linear-gradient(90deg,rgba(255,255,255,.1),transparent 45%,rgba(0,0,0,.24)),linear-gradient(#4a2e1a,#805633 34%,#5e3a21 72%,#3f2616)}.rail-detail-left{left:calc(var(--board-x) - 36px);border-right:1px solid rgba(21,95,62,.7)}.rail-detail-right{left:calc(var(--board-x) + var(--board-size) + 6px);border-left:1px solid rgba(21,95,62,.7)}.rail-detail-left:after{top:0;bottom:0;right:-10px;width:10px;clip-path:polygon(0 0,100% 10px,100% calc(100% - 10px),0 100%)}.rail-detail-right:after{top:0;bottom:0;left:-10px;width:10px;clip-path:polygon(0 10px,100% 0,100% 100%,0 calc(100% - 10px))}.rail-pocket{position:absolute;width:clamp(46px,10.6%,64px);aspect-ratio:1;z-index:7;pointer-events:none}.rail-pocket:before,.rail-pocket:after{content:"";position:absolute;pointer-events:none}.rail-pocket:before{inset:-8% 5% 22%;border-radius:6px 6px 15px 15px;background:radial-gradient(circle at 50% 48%,rgba(255,231,134,.26),transparent 42%),linear-gradient(90deg,rgba(255,227,122,.26),transparent 14% 86%,rgba(255,227,122,.22)),linear-gradient(#a64c38,#693321);box-shadow:inset 0 0 0 1px #ffcc5d3d,inset 0 -10px 16px #1f0c0657,0 5px 11px #0000002e}.rail-pocket:after{inset:11%;border-radius:999px;background:radial-gradient(circle at 36% 30%,#17211d 0 10%,#050605 56%,#000);box-shadow:inset 0 0 16px #000000fa,0 0 0 3px #0f49308a,0 8px 14px #00000047}.rail-pocket-top{transform:translate(-50%,-86%)}.rail-pocket-bottom{transform:translate(-50%,-14%)}.rail-pocket-bottom:before{inset:22% 5% -8%;border-radius:15px 15px 6px 6px}.rail-pocket-left{transform:translate(-86%,-50%)}.rail-pocket-right{transform:translate(-14%,-50%)}.rail-pocket-left:before{inset:5% 22% 5% -8%;border-radius:6px 15px 15px 6px}.rail-pocket-right:before{inset:5% -8% 5% 22%;border-radius:15px 6px 6px 15px}.board{position:relative;z-index:2;display:grid;grid-auto-rows:1fr;gap:1px;aspect-ratio:1;overflow:visible;border:1px solid rgba(7,45,33,.75);border-radius:4px;background:linear-gradient(#d2e6dc2e,#0000001a),#174f3e;box-shadow:inset 0 0 42px #0000003d,inset 0 0 0 1px #ffffff14}.cell{position:relative;display:grid;min-width:0;min-height:0;place-items:center;border:0;background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.045),transparent 68%),#1b674f;color:#f6fbf8;cursor:crosshair;transition:background .14s ease,box-shadow .14s ease}.cell.available:after{content:"";position:absolute;inset:8%;border:2px solid rgba(255,226,112,.92);border-radius:4px;background:#ffe27014;pointer-events:none}.cell.selected{background:#ffe06d2e}.piece{position:absolute;inset:0;display:block;border-radius:0;z-index:2;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:transform .14s ease,filter .14s ease}.player-piece{background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.08),transparent 62%),#1b674f;box-shadow:inset 0 0 0 1px #0a2a2047,0 4px 12px #0f1f191f}.fixed-piece{background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 45%),#375846;box-shadow:inset 0 0 0 2px #081c1680}.fixed-piece.glass{background:radial-gradient(circle at 30% 22%,rgba(255,255,255,.72) 0 7%,transparent 20%),linear-gradient(135deg,#ffffffad,#81daf44d 34%,#1f81a657 72%),#6fd2f08a;box-shadow:inset 0 0 0 2px #cdf8ffc2,inset 8px 8px 12px #ffffff47,inset -10px -10px 18px #195c7e42,0 4px 12px #2684a433;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.fixed-piece.block{background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 48%),#2e2521;box-shadow:inset 0 0 0 2px #0000006b,inset 0 0 18px #00000061}.fixed-piece.gate{background:#2c5948;box-shadow:inset 0 0 0 2px #09221b8f,inset 0 0 18px #0000002e}.fixed-piece.gate-slash.gate-pass-ne{background:linear-gradient(135deg,#e2b83eeb 0 47%,#183027e6 47% 53%,#2b8456f0 53% 100%)}.fixed-piece.gate-slash.gate-pass-sw{background:linear-gradient(135deg,#2b8456f0 0 47%,#183027e6 47% 53%,#e2b83eeb 53% 100%)}.fixed-piece.gate-backslash.gate-pass-nw{background:linear-gradient(45deg,#2b8456f0 0 47%,#183027e6 47% 53%,#e2b83eeb 53% 100%)}.fixed-piece.gate-backslash.gate-pass-se{background:linear-gradient(45deg,#e2b83eeb 0 47%,#183027e6 47% 53%,#2b8456f0 53% 100%)}.piece.slash-wall:before,.piece.backslash-wall:before,.inventory-piece:before{content:"";position:absolute;top:50%;left:50%;width:118%;height:18%;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.36),transparent 42%),#e1d5b8;box-shadow:0 3px 8px #00000047,inset 0 -2px #3c2b1c5c;-webkit-mask:none;mask:none}.piece.slash-wall:not(.glass):not(.gate):after,.piece.backslash-wall:not(.glass):not(.gate):after,.inventory-piece:after{content:none}.piece.slash-wall:before,.inventory-piece.slash-wall:before{transform:translate(-50%,-50%) rotate(-45deg)}.piece.backslash-wall:before,.inventory-piece.backslash-wall:before{transform:translate(-50%,-50%) rotate(45deg)}.piece.slash-wall:not(.glass):not(.gate):after,.inventory-piece.slash-wall:after{transform:none}.piece.backslash-wall:not(.glass):not(.gate):after,.inventory-piece.backslash-wall:after{transform:none}.fixed-piece.slash-wall:before,.fixed-piece.backslash-wall:before{background:linear-gradient(180deg,rgba(255,255,255,.2),transparent 42%),#204138;box-shadow:0 3px 8px #00000047,inset 0 -2px #0000004d}.fixed-piece.glass.slash-wall:before,.fixed-piece.glass.backslash-wall:before{background:linear-gradient(180deg,#ffffffc2,#d2f9ff6b 42%,#3fa0c39e),#8be2f9c7;box-shadow:0 4px 10px #1a6f8f3d,inset 0 2px #ffffffc7,inset 0 -2px #1b719552}.fixed-piece.glass.slash-wall:after,.fixed-piece.glass.backslash-wall:after{content:none}.fixed-piece.glass.slash-wall:after{transform:none}.fixed-piece.glass.backslash-wall:after{transform:none}.fixed-piece.glass:not(.slash-wall):not(.backslash-wall):before{content:"";position:absolute;left:15%;top:14%;width:32%;height:32%;border-radius:999px;background:radial-gradient(circle at 36% 34%,rgba(255,255,255,.96),rgba(232,253,255,.78) 34%,rgba(195,241,250,.24) 58%,transparent 74%);filter:blur(.4px)}.fixed-piece.glass:not(.slash-wall):not(.backslash-wall):after{content:"";position:absolute;inset:8%;border-radius:4px;background:radial-gradient(ellipse at 24% 20%,rgba(255,255,255,.46),transparent 24%),radial-gradient(ellipse at 76% 82%,rgba(202,245,255,.24),transparent 30%),linear-gradient(180deg,rgba(255,255,255,.18),transparent 42%);opacity:1;pointer-events:none}.fixed-piece.gate:before,.fixed-piece.gate:after{content:"";position:absolute;left:50%;top:50%;width:46%;height:18%;border-radius:999px 32px 32px 999px;background:radial-gradient(circle at 14% 50%,#6f4426 0 10%,#f3dfb4 11% 17%,transparent 18%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 44%),#e8d9b6;box-shadow:0 3px 5px #0000003d,inset 0 -2px #48301947}.fixed-piece.gate:before{transform-origin:100% 50%;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M16 2 C7 2 1 9 1 20 C1 31 7 38 16 38 L97 25 C101 24 101 16 97 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M16 2 C7 2 1 9 1 20 C1 31 7 38 16 38 L97 25 C101 24 101 16 97 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat}.fixed-piece.gate:after{transform-origin:0 50%;background:radial-gradient(circle at 86% 50%,#6f4426 0 10%,#f3dfb4 11% 17%,transparent 18%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 44%),#e8d9b6;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M84 2 C93 2 99 9 99 20 C99 31 93 38 84 38 L3 25 C-1 24 -1 16 3 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M84 2 C93 2 99 9 99 20 C99 31 93 38 84 38 L3 25 C-1 24 -1 16 3 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat}.fixed-piece.gate-slash:before{transform:translate(-100%,-50%) rotate(-45deg)}.fixed-piece.gate-slash:after{transform:translateY(-50%) rotate(-45deg)}.fixed-piece.gate-backslash:before{transform:translate(-100%,-50%) rotate(45deg)}.fixed-piece.gate-backslash:after{transform:translateY(-50%) rotate(45deg)}.piece:hover{filter:brightness(1.08)}.piece:active{cursor:grabbing}.eight-ball{position:absolute;display:grid;width:min(calc(var(--cell-size) * .36),34px);aspect-ratio:1;place-items:center;border-radius:999px;background:radial-gradient(circle at 30% 23%,rgba(255,255,255,.3) 0 8%,transparent 19%),radial-gradient(circle at 62% 72%,rgba(0,0,0,.78) 0 26%,transparent 54%),radial-gradient(circle at 42% 34%,#26302d 0 25%,#070b0a 62%,#000);color:#0c1110;font-size:100%;font-weight:900;text-shadow:0 1px 0 rgba(255,255,255,.35);left:0;top:0;z-index:6;box-shadow:inset -.18em -.2em .32em #000000ad,inset .1em .1em .2em #ffffff14,0 .12em .26em #0000004d;transform:translateZ(0);will-change:transform;pointer-events:none;contain:layout paint;isolation:isolate;opacity:1}.eight-ball:before{content:none}.eight-ball-number{position:relative;display:grid;width:44%;aspect-ratio:1;place-items:center;border-radius:999px;background:radial-gradient(circle at 36% 30%,#fff 0 34%,#f1eee1 72%,#d9d0b7);box-shadow:inset -.04em -.04em .12em #50463447,0 .04em .12em #00000042;z-index:3;line-height:1;font-size:42%;font-weight:900;text-shadow:none}.eight-ball:after{content:"";position:absolute;inset:7%;border-radius:inherit;border:1px solid rgba(255,255,255,.07);box-shadow:inset 1px 1px 2px #ffffff0d;z-index:2}.eight-ball.sinking{z-index:8;opacity:0;filter:blur(1px);transition:transform .52s cubic-bezier(.24,.76,.22,1),opacity .52s ease,filter .52s ease}.cue-launch{position:absolute;left:var(--cue-x);top:var(--cue-y);width:1px;height:1px;z-index:9;transform:rotate(var(--cue-angle));pointer-events:none;animation:cue-fade .76s ease-out both}.animated-cue-ball{position:absolute;width:min(calc(var(--cell-size) * .28),18px);height:min(calc(var(--cell-size) * .28),18px);left:calc(min(calc(var(--cell-size) * .28),18px)/-2);top:calc(min(calc(var(--cell-size) * .28),18px)/-2);border-radius:999px;background:radial-gradient(circle at 35% 30%,#fff 0 30%,#dfe5df 70%);box-shadow:0 8px 18px #0000002e;animation:cue-ball-launch .76s cubic-bezier(.18,.9,.3,1) both}.animated-cue-stick{position:absolute;width:132px;height:7px;right:30px;top:-3.5px;border-radius:999px;background:linear-gradient(90deg,#2f1b0d 0 12%,#b68142 12% 72%,#ead5a7 72% 100%);box-shadow:0 3px 8px #00000047;transform-origin:right center;animation:cue-stick-strike .76s cubic-bezier(.18,.9,.3,1) both}@keyframes cue-stick-strike{0%{transform:translate(calc(var(--cue-stick-strike) * -1 - 34px));opacity:0}16%{opacity:1}32%{transform:translate(var(--cue-stick-strike));opacity:1}50%{transform:translate(var(--cue-stick-strike));opacity:1}to{transform:translate(calc(var(--cue-stick-strike) + 12px));opacity:0}}@keyframes cue-ball-launch{0%{transform:translate(0);opacity:1}22%{transform:translate(0);opacity:1}47%{transform:translate(var(--cue-contact));opacity:1}64%{transform:translate(var(--cue-contact));opacity:1}to{transform:translate(var(--cue-contact));opacity:0}}@keyframes cue-fade{0%,70%{opacity:1}to{opacity:0}}.import-export{display:grid;gap:10px;padding:12px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.import-export textarea{width:100%;min-height:220px;resize:vertical;border:1px solid #ccd8d2;border-radius:8px;padding:10px;background:#f7faf8;color:#1b2d27;font-family:Cascadia Code,Consolas,monospace;font-size:.84rem}.editor-shell{display:grid;gap:14px;padding:14px}.editor-controls{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:10px}.editor-controls label{display:grid;gap:5px;color:#52685f;font-size:.78rem;font-weight:800}.editor-controls input,.editor-controls select{min-height:38px;border:1px solid #ccd8d2;border-radius:7px;padding:0 10px;background:#fff;color:#1b2d27}.editor-hint{grid-column:span 2;align-self:end;margin:0;color:#5f746b;font-size:.82rem;line-height:1.35}.tool-palette{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px}.editor-board{display:grid;width:min(100%,620px);aspect-ratio:1;grid-auto-rows:1fr;margin:0 auto;overflow:hidden;border:8px solid #573c25;border-radius:8px;background:#1c6a50}.editor-cell{display:grid;place-items:center;min-width:0;min-height:0;padding:0;border:0;border-right:1px solid rgba(232,249,240,.14);border-bottom:1px solid rgba(232,249,240,.14);background:#ffffff05;color:#f7f7eb;font-size:clamp(.92rem,3vw,1.6rem);font-weight:900}.editor-cell.start{background:#fbf1bc33}.editor-cell.pocket{background:#00000047}.editor-piece{position:relative;display:block;width:78%;height:78%;border-radius:4px}.editor-piece.fixed{background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 45%),#375846;box-shadow:inset 0 0 0 2px #081c1680}.editor-piece.block{background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 48%),#2e2521;box-shadow:inset 0 0 0 2px #0000006b,inset 0 0 18px #00000061}.editor-piece.glass{background:radial-gradient(circle at 30% 22%,rgba(255,255,255,.74) 0 8%,transparent 22%),linear-gradient(135deg,#ffffffad,#81daf452 34%,#1f81a661 72%),#6fd2f094;box-shadow:inset 0 0 0 2px #cdf8ffcc,inset 8px 8px 12px #ffffff47,inset -10px -10px 18px #195c7e42}.editor-piece.gate{background:#2c5948;box-shadow:inset 0 0 0 2px #09221b8f,inset 0 0 18px #0000002e}.editor-piece.gate-slash.gate-pass-ne{background:linear-gradient(135deg,#e2b83eeb 0 47%,#183027e6 47% 53%,#2b8456f0 53% 100%)}.editor-piece.gate-slash.gate-pass-sw{background:linear-gradient(135deg,#2b8456f0 0 47%,#183027e6 47% 53%,#e2b83eeb 53% 100%)}.editor-piece.gate-backslash.gate-pass-nw{background:linear-gradient(45deg,#2b8456f0 0 47%,#183027e6 47% 53%,#e2b83eeb 53% 100%)}.editor-piece.gate-backslash.gate-pass-se{background:linear-gradient(45deg,#e2b83eeb 0 47%,#183027e6 47% 53%,#2b8456f0 53% 100%)}.editor-piece.gate:before,.editor-piece.gate:after{content:"";position:absolute;left:50%;top:50%;width:46%;height:18%;border-radius:999px 32px 32px 999px;background:radial-gradient(circle at 14% 50%,#6f4426 0 10%,#f3dfb4 11% 17%,transparent 18%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 44%),#e8d9b6;box-shadow:0 3px 5px #0000003d,inset 0 -2px #48301947}.editor-piece.gate:before{transform-origin:100% 50%;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M16 2 C7 2 1 9 1 20 C1 31 7 38 16 38 L97 25 C101 24 101 16 97 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M16 2 C7 2 1 9 1 20 C1 31 7 38 16 38 L97 25 C101 24 101 16 97 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat}.editor-piece.gate:after{transform-origin:0 50%;background:radial-gradient(circle at 86% 50%,#6f4426 0 10%,#f3dfb4 11% 17%,transparent 18%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 44%),#e8d9b6;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M84 2 C93 2 99 9 99 20 C99 31 93 38 84 38 L3 25 C-1 24 -1 16 3 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M84 2 C93 2 99 9 99 20 C99 31 93 38 84 38 L3 25 C-1 24 -1 16 3 15 Z'/%3E%3C/svg%3E") center / 100% 100% no-repeat}.editor-piece.gate-slash:before{transform:translate(-100%,-50%) rotate(-45deg)}.editor-piece.gate-slash:after{transform:translateY(-50%) rotate(-45deg)}.editor-piece.gate-backslash:before{transform:translate(-100%,-50%) rotate(45deg)}.editor-piece.gate-backslash:after{transform:translateY(-50%) rotate(45deg)}.editor-piece.slash-wall:before,.editor-piece.backslash-wall:before{content:"";position:absolute;top:50%;left:50%;width:118%;height:18%;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.2),transparent 42%),#204138;box-shadow:0 3px 8px #00000047,inset 0 -2px #0000004d;-webkit-mask:none;mask:none}.editor-piece.glass.slash-wall:before,.editor-piece.glass.backslash-wall:before{background:linear-gradient(180deg,#ffffffc2,#d2f9ff6b 42%,#3fa0c39e),#8be2f9c7;box-shadow:0 4px 10px #1a6f8f3d,inset 0 2px #ffffffc7,inset 0 -2px #1b719552}.editor-piece.slash-wall:not(.glass):not(.gate):after,.editor-piece.backslash-wall:not(.glass):not(.gate):after{content:none}.editor-piece.glass.slash-wall:after,.editor-piece.glass.backslash-wall:after{content:none}.editor-piece.slash-wall:before{transform:translate(-50%,-50%) rotate(-45deg)}.editor-piece.backslash-wall:before{transform:translate(-50%,-50%) rotate(45deg)}.editor-piece.slash-wall:not(.glass):not(.gate):after,.editor-piece.glass.slash-wall:after{transform:none}.editor-piece.backslash-wall:not(.glass):not(.gate):after,.editor-piece.glass.backslash-wall:after{transform:none}.editor-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}@media(max-width:740px){.editor-controls{grid-template-columns:1fr 1fr}.editor-hint{grid-column:1 / -1}}@media(max-width:500px){.editor-controls{grid-template-columns:1fr}}
