:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#212529;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-weight:400;line-height:1.5}@media (prefers-reduced-motion:reduce){:root{scroll-behavior:auto}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{min-width:320px;min-height:100vh;margin:0;padding:0;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;border:2px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:600;transition:all .3s}button:focus,button:focus-visible,a:focus,input:focus,select:focus,textarea:focus{outline-offset:2px;outline:3px solid #4dabf7}@media (prefers-contrast:high){button,a,input,select,textarea{border-width:3px}button:focus,button:focus-visible,a:focus,input:focus,select:focus,textarea:focus{outline-width:4px}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{color:#fff;z-index:10000;background:#4dabf7;border-radius:0 0 4px;padding:8px 16px;font-weight:600;text-decoration:none;transition:top .3s;position:absolute;top:-40px;left:0}.skip-link:focus{outline-offset:2px;outline:3px solid #fff;top:0}::selection{color:#fff;background-color:#4dabf7}::selection{color:#fff;background-color:#4dabf7}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#0000001a;border-radius:6px}::-webkit-scrollbar-thumb{background:#4dabf799 padding-box padding-box;border:2px solid #0000;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#4dabf7cc padding-box padding-box}#root{text-align:center;max-width:1280px;margin:0 auto;padding:2rem}.logo{will-change:filter;height:6em;padding:1.5em;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:20s linear infinite logo-spin}}.card{padding:2em}.read-the-docs{color:#888}.box{box-sizing:border-box;background-size:20px 20px;border:2px solid #00000026;justify-content:center;align-items:center;width:100%;height:100%;transition:all .25s;display:flex;position:relative}.box--red{background-color:#ff6b6b;background-image:repeating-linear-gradient(45deg,#0000,#0000 10px,#0000000d 10px 20px)}.box--green{background-color:#51cf66;background-image:radial-gradient(circle,#0000000d 2px,#0000 2px)}.box--blue{background-color:#4dabf7;background-image:repeating-linear-gradient(0deg,#0000,#0000 10px,#0000000d 10px 20px)}.box--gray{background-color:#adb5bd}.box--current{animation:2s ease-in-out infinite pulse;box-shadow:inset 0 0 0 3px #fffc,0 0 20px #ffd70099}@keyframes pulse{0%,to{box-shadow:inset 0 0 0 3px #fffc,0 0 20px #ffd70099}50%{box-shadow:inset 0 0 0 3px #fff,0 0 30px #ffd700e6}}.box__star{-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 0 4px #ffd700cc);font-size:1.5em;line-height:1;animation:2s ease-in-out infinite starTwinkle}@keyframes starTwinkle{0%,to{opacity:1;transform:scale(1)rotate(0)}50%{opacity:.9;transform:scale(1.1)rotate(5deg)}}.box:hover{border-color:#0000004d;transform:scale(1.02)}@media (prefers-reduced-motion:reduce){.box,.box__star{transition:none;animation:none}.box--current{animation:none}.box:hover{transform:none}}.ship{transform-origin:50%;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:10;filter:drop-shadow(0 2px 8px #0000004d);margin-top:-.5em;margin-left:-.5em;font-size:2em;line-height:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1);animation:3s ease-in-out infinite shipFloat;position:absolute;top:50%;left:50%}@keyframes shipFloat{0%,to{filter:drop-shadow(0 2px 8px #0000004d)}50%{filter:drop-shadow(0 4px 12px #0006)}}@media (max-width:768px){.ship{font-size:1.5em}}@media (max-width:480px){.ship{font-size:1.2em}}@media (prefers-reduced-motion:reduce){.ship{filter:drop-shadow(0 2px 8px #0000004d);transition:none;animation:none}}.game-board{justify-content:center;align-items:center;width:100%;max-width:100%;padding:1rem;display:flex}.game-board__grid{aspect-ratio:1;background-color:#0000001a;border-radius:4px;gap:2px;width:min(90vw,600px);height:min(90vw,600px);padding:2px;display:grid}.game-board__cell{width:100%;min-width:0;height:100%;min-height:0;position:relative}.game-board__grid[style*=repeat\(3]{width:min(60vw,400px);height:min(60vw,400px)}.game-board__grid[style*=repeat\(5]{width:min(70vw,500px);height:min(70vw,500px)}.game-board__grid[style*=repeat\(7]{width:min(80vw,600px);height:min(80vw,600px)}@media (max-width:768px){.game-board{padding:.5rem}.game-board__grid{width:95vw;max-width:500px;height:95vw;max-height:500px}}@media (max-width:480px){.game-board__grid{gap:1px;padding:1px}}.command{cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#fff 0%,#f8f9fa 100%);border:2px solid #dee2e6;border-radius:10px;align-items:center;gap:.5rem;min-width:60px;padding:.5rem .75rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;box-shadow:0 2px 4px #0000000d}.command:hover{background:linear-gradient(135deg,#fff 0%,#e9ecef 100%);border-color:#868e96;transform:translateY(-2px)scale(1.02);box-shadow:0 4px 12px #00000026}.command:focus{outline-offset:2px;outline:3px solid #4dabf7}.command--executing{background:linear-gradient(135deg,#fff9db 0%,#fff3bf 100%);border-color:#ffd43b;animation:1s ease-in-out infinite executeGlow;box-shadow:0 0 20px #ffd43b99,0 4px 12px #00000026}@keyframes executeGlow{0%,to{box-shadow:0 0 20px #ffd43b99,0 4px 12px #00000026}50%{box-shadow:0 0 30px #ffd43be6,0 6px 16px #0003}}.command__icon{justify-content:center;align-items:center;font-size:1.5em;line-height:1;transition:transform .2s;display:flex}.command:hover .command__icon{transform:scale(1.1)}.command__filter-bar{border-radius:10px 0 0 10px;width:4px;position:absolute;top:0;bottom:0;left:0}.command__filter-bar--red{background:linear-gradient(#ff6b6b 0%,#fa5252 100%)}.command__filter-bar--green{background:linear-gradient(#51cf66 0%,#40c057 100%)}.command__filter-bar--blue{background:linear-gradient(#4dabf7 0%,#339af0 100%)}.command__filter-bar--gray{background:linear-gradient(#adb5bd 0%,#868e96 100%)}.command__filter{border:1px solid #0003;border-radius:50%;flex-shrink:0;width:12px;height:12px}.command__paint-color{border:1px solid #0003;border-radius:4px;flex-shrink:0;width:16px;height:16px}.command--color-red,.command__filter.command--color-red,.command__paint-color.command--color-red{background-color:#ff6b6b}.command--color-green,.command__filter.command--color-green,.command__paint-color.command--color-green{background-color:#51cf66}.command--color-blue,.command__filter.command--color-blue,.command__paint-color.command--color-blue{background-color:#4dabf7}.command--color-gray,.command__filter.command--color-gray,.command__paint-color.command--color-gray{background-color:#adb5bd}.command__function-name{color:#495057;font-family:monospace;font-size:.875rem;font-weight:600}.command__remove{color:#fff;cursor:pointer;background:linear-gradient(135deg,#fa5252 0%,#e03131 100%);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:.75rem;line-height:1;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:none;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 8px #fa525266}.command:hover .command__remove{animation:.3s removeButtonAppear;display:flex}@keyframes removeButtonAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.command__remove:hover{background:linear-gradient(135deg,#e03131 0%,#c92a2a 100%);transform:scale(1.2)rotate(90deg);box-shadow:0 4px 12px #fa525299}.command__remove:focus{outline-offset:2px;outline:3px solid #4dabf7}.command:focus-visible{outline-offset:3px;outline:4px solid #4dabf7;box-shadow:0 0 0 6px #4dabf733}.command__remove:focus-visible{outline-offset:2px;outline:3px solid #fff;box-shadow:0 0 0 6px #4dabf780}@media (prefers-reduced-motion:reduce){.command,.command__remove,.command__icon{transition:none;animation:none}.command--executing{animation:none}.command:hover{transform:none}.command__remove:hover{transform:scale(1.1)}}.command-palette{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border:2px solid #ffffff80;border-radius:16px;min-width:200px;padding:1.25rem;box-shadow:0 4px 12px #0000001a}.command-palette__title{color:#212529;text-transform:uppercase;letter-spacing:.5px;text-shadow:0 1px 2px #fffc;margin:0 0 1rem;font-size:1.125rem;font-weight:700}.command-palette__group{background:#ffffff80;border:1px solid #0000000d;border-radius:12px;margin-bottom:1.5rem;padding:1rem;box-shadow:0 2px 4px #0000000d}.command-palette__group:last-child{margin-bottom:0}.command-palette__group-title{color:#495057;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #0000001a;margin:0 0 .75rem;padding-bottom:.5rem;font-size:.875rem;font-weight:600}.command-palette__grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.375rem;display:grid}.palette-command{cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#fff 0%,#f8f9fa 100%);border:2px solid #dee2e6;border-radius:6px;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .25rem;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 6px #00000014}.palette-command:before{content:"";background:linear-gradient(90deg,#0000,#fff9,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.palette-command:hover:before{left:100%}.palette-command:hover{background:linear-gradient(135deg,#fff 0%,#e7f5ff 100%);border-color:#4dabf7;transform:translateY(-4px)scale(1.05);box-shadow:0 6px 16px #4dabf74d}.palette-command:active{background:linear-gradient(135deg,#e7f5ff 0%,#d0ebff 100%);border-color:#339af0;transform:translateY(-2px)scale(1.02);box-shadow:0 4px 10px #4dabf766}.palette-command:focus{outline-offset:2px;outline:3px solid #4dabf7}.palette-command--dragging{opacity:.6;cursor:grabbing;transform:rotate(5deg)scale(1.1);box-shadow:0 8px 24px #0000004d}.palette-command__icon{filter:drop-shadow(0 2px 4px #0000001a);font-size:1em;line-height:1;transition:transform .3s}.palette-command:hover .palette-command__icon{transform:scale(1.15)rotate(5deg)}.palette-command__label{color:#343a40;text-align:center;text-shadow:0 1px 1px #fffc;font-size:.75rem;font-weight:600;line-height:1.2;transition:color .2s}.palette-command:hover .palette-command__label{color:#212529;font-weight:700}.palette-command:active .palette-command__label{color:#1971c2}.palette-command__color-indicator{border:1px solid #0000004d;border-radius:3px;flex-shrink:0;width:12px;height:12px;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 2px #00000026,inset 0 1px 2px #ffffff4d}.palette-command:hover .palette-command__color-indicator{transform:scale(1.1);box-shadow:0 3px 6px #0003,inset 0 1px 2px #fff6}.palette-command__color-indicator--red{background-color:#ff6b6b}.palette-command__color-indicator--green{background-color:#51cf66}.palette-command__color-indicator--blue{background-color:#4dabf7}.palette-command__color-indicator--gray{background-color:#adb5bd}.palette-command__function-name{color:#212529;background:linear-gradient(135deg,#fff5f5 0%,#ffe3e3 100%);border:1px solid #ffc9c9;border-radius:3px;padding:.125rem .25rem;font-family:Courier New,Courier,monospace;font-size:.625rem;font-weight:700;transition:all .2s;box-shadow:0 1px 2px #0000001a}.palette-command:hover .palette-command__function-name{background:linear-gradient(135deg,#ffe3e3 0%,#ffc9c9 100%);border-color:#ffa8a8;transform:scale(1.05)}@media (max-width:768px){.command-palette__grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.palette-command{padding:.75rem .25rem}.palette-command__icon{font-size:1.5em}.palette-command__label{font-size:.625rem}}.palette-command:focus-visible{outline-offset:3px;border-color:#1971c2;outline:4px solid #1971c2;box-shadow:0 0 0 6px #1971c24d,0 6px 16px #4dabf74d}@media (prefers-contrast:high){.palette-command{border-width:3px;border-color:#000}.palette-command:hover{background:#fff;border-color:#00f}.palette-command:focus-visible{outline-width:5px;outline-color:#00f}.palette-command__color-indicator{border-width:3px;border-color:#000}.palette-command__function-name{background:#fff;border-width:3px;border-color:#000}.command-palette__group-title{border-bottom-width:3px;border-bottom-color:#000}}.palette-command--color-red{border-left:4px solid #ff6b6b}.palette-command--color-green{border-left:4px solid #51cf66}.palette-command--color-blue{border-left:4px solid #4dabf7}.palette-command--color-gray{border-left:4px solid #adb5bd}.palette-command--color-red:hover{background:linear-gradient(135deg,#fff5f5 0%,#ffe3e3 100%)}.palette-command--color-green:hover{background:linear-gradient(135deg,#f4fcf7 0%,#d3f9d8 100%)}.palette-command--color-blue:hover{background:linear-gradient(135deg,#f0f9ff 0%,#d0ebff 100%)}.palette-command--color-gray:hover{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%)}.command-palette--disabled{opacity:.6;pointer-events:none}.palette-command--disabled{cursor:not-allowed;opacity:.5;pointer-events:none;background:linear-gradient(135deg,#f1f3f5 0%,#e9ecef 100%);border-color:#ced4da}.palette-command--disabled .palette-command__icon,.palette-command--disabled .palette-command__label,.palette-command--disabled .palette-command__color-indicator,.palette-command--disabled .palette-command__function-name{opacity:.6}@media (prefers-reduced-motion:reduce){.palette-command,.palette-command__icon,.palette-command__label,.palette-command__color-indicator,.palette-command__function-name{transition:none}.palette-command:before{display:none}.palette-command:hover,.palette-command:hover .palette-command__icon,.palette-command:hover .palette-command__color-indicator,.palette-command:hover .palette-command__function-name{transform:none}}.color-picker{background:#fffffff2;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;display:flex;box-shadow:0 2px 8px #0000001a}.color-picker__label{color:#333;font-size:14px;font-weight:600}.color-picker__options{gap:8px;display:flex}.color-picker__option{cursor:pointer;background:#f0f0f0;border:3px solid #0000;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:all .2s;display:flex}.color-picker__option:hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026}.color-picker__option:focus{outline-offset:2px;outline:2px solid #4a90e2}.color-picker__option--selected{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.color-picker__option--none{background:linear-gradient(135deg,#f0f0f0 45%,#ddd 45% 55%,#f0f0f0 55%)}.color-picker__icon{font-size:20px}.color-picker__option--red{background:#ff6b6b}.color-picker__option--green{background:#51cf66}.color-picker__option--blue{background:#4dabf7}.color-picker__option--gray{background:#868e96}.color-picker__color-box{background:#ffffff4d;border:2px solid #ffffff80;border-radius:4px;width:24px;height:24px}@media (prefers-contrast:high){.color-picker__option{border-width:4px}.color-picker__option--selected{border-color:#000}}@media (prefers-reduced-motion:reduce){.color-picker__option{transition:none}.color-picker__option:hover{transform:none}}.function-grid{width:100%;padding:.5rem 0}.function-grid__row{grid-auto-columns:1fr;grid-auto-flow:column;gap:.5rem;width:100%;display:grid}.function-grid__cell{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;min-height:60px;padding:.25rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.function-grid__cell--empty{background:repeating-linear-gradient(45deg,#f8f9fa,#f8f9fa 10px,#fff 10px 20px);border:2px dashed #dee2e6}.function-grid__cell--empty:hover{background:repeating-linear-gradient(45deg,#e9ecef,#e9ecef 10px,#f8f9fa 10px 20px);border-color:#adb5bd}.function-grid__cell--filled{background:0 0;border:2px solid #0000}.function-grid__cell--selected{border-color:#4dabf7;box-shadow:0 0 0 3px #4dabf733}.function-grid__cell--selected.function-grid__cell--empty{background:linear-gradient(135deg,#e7f5ff 0%,#d0ebff 100%);border-style:solid;border-color:#4dabf7}.function-grid__cell--executing{animation:1s ease-in-out infinite cellExecuteGlow}@keyframes cellExecuteGlow{0%,to{box-shadow:0 0 20px #ffd43b99}50%{box-shadow:0 0 30px #ffd43be6}}.function-grid__cell--disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.function-grid__cell--disabled.function-grid__cell--empty{background:repeating-linear-gradient(45deg,#f1f3f5,#f1f3f5 10px,#f8f9fa 10px 20px);border-color:#ced4da}.function-grid__cell--disabled .function-grid__empty-state{color:#ced4da}.function-grid__selection-indicator{pointer-events:none;border:3px solid #4dabf7;border-radius:10px;animation:2s ease-in-out infinite selectionPulse;position:absolute;inset:-4px}@keyframes selectionPulse{0%,to{opacity:1}50%{opacity:.6}}.function-grid__empty-state{color:#adb5bd;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.5rem;font-weight:300;transition:all .2s;display:flex}.function-grid__cell--empty:hover .function-grid__empty-state{color:#868e96;transform:scale(1.2)}.function-grid__cell--selected .function-grid__empty-state{color:#4dabf7;font-weight:600}.function-grid__empty-icon{line-height:1;display:block}.function-grid__command-wrapper{justify-content:center;align-items:center;width:100%;display:flex}.function-grid__cell .command{cursor:pointer;width:100%;min-width:auto}.function-grid__cell:focus{outline:none}.function-grid__cell:focus-visible{outline-offset:2px;outline:4px solid #4dabf7;box-shadow:0 0 0 6px #4dabf733}@media (max-width:768px){.function-grid__row{gap:.375rem}.function-grid__cell{min-height:50px}.function-grid__empty-state{font-size:1.25rem}}@media (prefers-reduced-motion:reduce){.function-grid__cell,.function-grid__empty-state{transition:none;animation:none}.function-grid__cell--executing{animation:none;box-shadow:0 0 20px #ffd43b99}.function-grid__selection-indicator{opacity:1;animation:none}.function-grid__cell--empty:hover .function-grid__empty-state{transform:none}}.function-editor{background:linear-gradient(135deg,#fff 0%,#f8f9fa 100%);border:2px solid #dee2e6;border-radius:16px;min-height:120px;padding:1.25rem;transition:all .3s;box-shadow:0 2px 8px #00000014}.function-editor:focus{outline:none}.function-editor:focus-visible{outline-offset:4px;outline:3px solid #4dabf7}.function-editor--active{background:linear-gradient(135deg,#e7f5ff 0%,#d0ebff 100%);border-color:#4dabf7;transform:scale(1.01);box-shadow:0 0 20px #4dabf780,0 4px 12px #00000026}.function-editor__header{border-bottom:2px solid #e9ecef;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.function-editor__name{color:#212529;text-shadow:0 1px 2px #fffc;letter-spacing:.5px;margin:0;font-family:Courier New,monospace;font-size:1.25rem;font-weight:700}.function-editor__count{color:#868e96;background-color:#f1f3f5;border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:600;transition:all .2s}.function-editor--active .function-editor__count{color:#1971c2;background-color:#d0ebff}.function-editor__body{min-height:60px;position:relative}@media (max-width:768px){.function-editor{padding:.75rem}.function-editor__header{margin-bottom:.75rem}.function-editor__name{font-size:1rem}.function-editor__count{font-size:.75rem}}@media (prefers-reduced-motion:reduce){.function-editor,.function-editor__count{transition:none;animation:none}.function-editor--active{transform:none}}.function-list{flex-direction:column;gap:1rem;width:100%;display:flex}.function-list__limit{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border:2px solid #dee2e6;border-radius:12px;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.875rem;transition:all .3s;display:flex;box-shadow:0 2px 6px #00000014}.function-list__limit--warning{background:linear-gradient(135deg,#fff9db 0%,#fff3bf 100%);border-color:#ffd43b;animation:2s ease-in-out infinite warningPulse;box-shadow:0 2px 8px #ffd43b4d}@keyframes warningPulse{0%,to{box-shadow:0 2px 8px #ffd43b4d}50%{box-shadow:0 2px 12px #ffd43b80}}.function-list__limit--danger{background:linear-gradient(135deg,#ffe3e3 0%,#ffc9c9 100%);border-color:#ff6b6b;animation:1.5s ease-in-out infinite dangerPulse;box-shadow:0 2px 8px #ff6b6b4d}@keyframes dangerPulse{0%,to{box-shadow:0 2px 8px #ff6b6b4d}50%{box-shadow:0 2px 16px #ff6b6b99}}.function-list__limit-label{color:#495057;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:700}.function-list__limit-count{color:#212529;background-color:#fff9;border-radius:6px;padding:.125rem .5rem;font-family:Courier New,monospace;font-size:1rem;font-weight:800}.function-list__limit--warning .function-list__limit-count{color:#e67700;background-color:#ffedd5cc}.function-list__limit--danger .function-list__limit-count{color:#c92a2a;background-color:#fff5f5e6}.function-list__limit-message{color:#c92a2a;align-items:center;gap:.25rem;margin-left:auto;font-weight:700;animation:.5s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.function-list__editors{flex-direction:column;gap:1rem;display:flex}.function-list__empty{color:#adb5bd;background:repeating-linear-gradient(45deg,#f8f9fa,#f8f9fa 15px,#fff 15px 30px);border:2px dashed #dee2e6;border-radius:16px;justify-content:center;align-items:center;padding:3rem 2rem;font-size:1rem;font-style:italic;font-weight:500;display:flex}@media (max-width:768px){.function-list{gap:.75rem}.function-list__limit{flex-wrap:wrap;padding:.5rem .75rem;font-size:.75rem}.function-list__limit-message{width:100%;margin-top:.25rem;margin-left:0}.function-list__editors{gap:.75rem}}@media (prefers-reduced-motion:reduce){.function-list__limit,.function-list__limit-message{transition:none;animation:none}.function-list__limit--warning,.function-list__limit--danger{animation:none}}.execution-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffffa 0%,#f8f9fafa 100%);border:2px solid #ffffff80;border-radius:16px;flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex;box-shadow:0 4px 16px #0000001a}.execution-controls__main{justify-content:center;align-items:center;gap:.5rem;display:flex}.execution-controls__button{cursor:pointer;background:linear-gradient(135deg,#fff 0%,#f8f9fa 100%);border:2px solid #dee2e6;border-radius:12px;justify-content:center;align-items:center;min-width:52px;min-height:52px;padding:.75rem 1rem;font-size:1rem;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.execution-controls__button:before{content:"";background:#fff9;border-radius:50%;width:0;height:0;transition:width .4s,height .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.execution-controls__button:hover:not(:disabled):before{width:120%;height:120%}.execution-controls__button:hover:not(:disabled){background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-color:#868e96;transform:translateY(-3px)scale(1.05);box-shadow:0 6px 16px #00000026}.execution-controls__button:active:not(:disabled){transform:translateY(-1px)scale(1.02);box-shadow:0 3px 10px #0000001f}.execution-controls__button:focus-visible{outline-offset:3px;outline:4px solid #4dabf7;box-shadow:0 0 0 6px #4dabf733}.execution-controls__button:disabled{opacity:.35;cursor:not-allowed;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);box-shadow:0 1px 3px #0000000d}.execution-controls__button--primary{color:#fff;background:linear-gradient(135deg,#4dabf7 0%,#339af0 100%);border-color:#4dabf7;min-width:68px;min-height:68px;padding:.875rem 1.25rem;box-shadow:0 4px 12px #4dabf766}.execution-controls__button--primary:before{background:#ffffff4d}.execution-controls__button--primary:hover:not(:disabled){background:linear-gradient(135deg,#339af0 0%,#228be6 100%);border-color:#339af0;box-shadow:0 8px 20px #4dabf799}.execution-controls__button--primary:disabled{background:linear-gradient(135deg,#adb5bd 0%,#868e96 100%);border-color:#868e96;box-shadow:0 2px 6px #0000001a}.execution-controls__button--pause{background:linear-gradient(135deg,#ffa94d 0%,#ff922b 100%);border-color:#ffa94d;animation:2s ease-in-out infinite pulseExecuting;box-shadow:0 4px 12px #ffa94d66}@keyframes pulseExecuting{0%,to{box-shadow:0 4px 12px #ffa94d66}50%{box-shadow:0 4px 20px #ffa94db3}}.execution-controls__button--pause:hover:not(:disabled){background:linear-gradient(135deg,#ff922b 0%,#fd7e14 100%);border-color:#ff922b;box-shadow:0 8px 20px #ffa94d99}.execution-controls__button--reset{color:#fff;background:linear-gradient(135deg,#ff6b6b 0%,#fa5252 100%);border-color:#ff6b6b;box-shadow:0 2px 8px #ff6b6b66}.execution-controls__button--reset:before{background:#ffffff4d}.execution-controls__button--reset:hover:not(:disabled){background:linear-gradient(135deg,#fa5252 0%,#f03e3e 100%);border-color:#fa5252;box-shadow:0 6px 16px #ff6b6b99}.execution-controls__button--reset:disabled{background:linear-gradient(135deg,#adb5bd 0%,#868e96 100%);border-color:#868e96;box-shadow:0 2px 6px #0000001a}.execution-controls__icon{z-index:1;filter:drop-shadow(0 1px 2px #0003);font-size:1.25em;line-height:1;transition:transform .2s;display:inline-block;position:relative}.execution-controls__button:hover:not(:disabled) .execution-controls__icon{transform:scale(1.1)}.execution-controls__speed{border-top:1px solid #e9ecef;flex-direction:column;gap:.5rem;padding-top:.5rem;display:flex}.execution-controls__speed-label{color:#495057;text-align:center;font-size:.875rem;font-weight:600}.execution-controls__speed-slider{appearance:none;background:linear-gradient(90deg,#e9ecef 0%,#4dabf7 50%,#339af0 100%);border-radius:4px;outline:none;width:100%;height:8px;box-shadow:inset 0 1px 3px #0000001a}.execution-controls__speed-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:linear-gradient(135deg,#4dabf7 0%,#339af0 100%);border:3px solid #fff;border-radius:50%;width:24px;height:24px;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 3px 8px #4dabf766}.execution-controls__speed-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#339af0 0%,#228be6 100%);transform:scale(1.2);box-shadow:0 4px 12px #4dabf799}.execution-controls__speed-slider::-moz-range-thumb{cursor:pointer;background:linear-gradient(135deg,#4dabf7 0%,#339af0 100%);border:3px solid #fff;border-radius:50%;width:24px;height:24px;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 3px 8px #4dabf766}.execution-controls__speed-slider::-moz-range-thumb:hover{background:linear-gradient(135deg,#339af0 0%,#228be6 100%);transform:scale(1.2);box-shadow:0 4px 12px #4dabf799}.execution-controls__speed-slider:focus-visible{outline-offset:2px;outline:3px solid #4dabf7}.execution-controls__speed-slider:focus-visible::-webkit-slider-thumb{outline-offset:3px;outline:3px solid #4dabf7;box-shadow:0 0 0 6px #4dabf74d}.execution-controls__speed-slider:focus-visible::-moz-range-thumb{outline-offset:3px;outline:3px solid #4dabf7;box-shadow:0 0 0 6px #4dabf74d}.execution-controls__speed-markers{justify-content:space-between;padding:0 .25rem;display:flex}.execution-controls__speed-marker{color:#868e96;font-size:.75rem}.execution-controls__status{text-align:center;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1rem;font-size:.875rem;font-weight:600;animation:.3s statusSlideIn;display:flex;box-shadow:0 2px 8px #0000001a}@keyframes statusSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.execution-controls__status--error{color:#c92a2a;background:linear-gradient(135deg,#ffe3e3 0%,#ffc9c9 100%);border:2px solid #ff6b6b}.execution-controls__status--success{color:#2b8a3e;background:linear-gradient(135deg,#d3f9d8 0%,#b2f2bb 100%);border:2px solid #51cf66}@media (max-width:768px){.execution-controls{padding:.75rem}.execution-controls__main{gap:.375rem}.execution-controls__button{min-width:44px;min-height:44px;padding:.625rem .75rem}.execution-controls__button--primary{min-width:56px;padding:.75rem 1rem}.execution-controls__icon{font-size:1.125em}.execution-controls__speed-label{font-size:.8125rem}.execution-controls__speed-marker{font-size:.6875rem}}@media (prefers-reduced-motion:reduce){.execution-controls__button,.execution-controls__button:before,.execution-controls__icon,.execution-controls__status{transition:none;animation:none}.execution-controls__speed-slider::-webkit-slider-thumb{transition:none;animation:none}.execution-controls__speed-slider::-moz-range-thumb{transition:none;animation:none}.execution-controls__button:hover:not(:disabled),.execution-controls__button:active:not(:disabled),.execution-controls__button:hover:not(:disabled) .execution-controls__icon{transform:none}.execution-controls__speed-slider::-webkit-slider-thumb:hover{transform:none}.execution-controls__speed-slider::-moz-range-thumb:hover{transform:none}.execution-controls__button--pause{animation:none}}@media (prefers-contrast:high){.execution-controls__button{border-width:3px}.execution-controls__status{border-width:2px}}.game{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;min-height:100vh;display:flex}.game__header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0003;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.game__title{text-shadow:2px 2px 4px #0000004d;margin:0;font-size:2rem;font-weight:700}.game__level-button{color:#fff;cursor:pointer;background:#fff3;border:2px solid #ffffff4d;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.game__level-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.game__level-selector{background:#00000026;border-bottom:1px solid #ffffff1a;padding:1rem 2rem}.game__main{flex:1;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem;display:grid}.game__left-panel{flex-direction:column;gap:1.5rem;display:flex}.game__status{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;gap:2rem;padding:1rem 1.5rem;display:flex}.game__status-item{align-items:center;gap:.5rem;display:flex}.game__status-label{opacity:.9;font-weight:600}.game__status-value{color:gold;font-size:1.25rem;font-weight:700}.game__board-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;justify-content:center;align-items:center;min-height:400px;padding:2rem;display:flex}.game__controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;padding:1.5rem}.game__error{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#dc262633;border:2px solid #dc262680;border-radius:12px;gap:1rem;padding:1.5rem;animation:.5s shake;display:flex}.game__error-icon{flex-shrink:0;font-size:2rem}.game__error-content{flex:1}.game__error-title{margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.game__error-message{margin-bottom:.5rem;font-size:1rem}.game__error-details{opacity:.8;margin-top:.5rem;font-size:.875rem}.game__error-details>div{margin-top:.25rem}.game__right-panel{flex-direction:column;gap:1.5rem;display:flex}.game__palette{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;padding:1.5rem}.game__color-picker{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;padding:1rem;animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.game__functions{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;flex:1;padding:1.5rem;overflow-y:auto}.game__modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game__modal{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;width:90%;max-width:500px;padding:3rem;animation:.3s slideUp;box-shadow:0 20px 60px #00000080}.game__modal--failed{background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%)}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.game__modal-content{text-align:center}.game__modal-icon{margin-bottom:1rem;font-size:4rem;animation:1s infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.game__modal-title{text-shadow:2px 2px 4px #0000004d;margin:0 0 1rem;font-size:2.5rem;font-weight:700}.game__modal-message{opacity:.95;margin:0 0 .5rem;font-size:1.25rem}.game__modal-subtitle{opacity:.85;margin:0 0 2rem;font-size:1rem}.game__modal-actions{justify-content:center;gap:1rem;margin-top:2rem;display:flex}.game__modal-button{cursor:pointer;border:none;border-radius:10px;padding:1rem 2rem;font-size:1.125rem;font-weight:600;transition:all .3s}.game__modal-button--primary{color:#333;background:gold}.game__modal-button--primary:hover{background:#ffed4e;transform:translateY(-2px);box-shadow:0 10px 20px #ffd7004d}.game__modal-button--secondary{color:#fff;background:#fff3;border:2px solid #ffffff4d}.game__modal-button--secondary:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}@media (max-width:1200px){.game__main{grid-template-columns:1fr}.game__right-panel{order:-1}.game__board-container{min-height:350px}}@media (max-width:768px){.game__header{text-align:center;flex-direction:column;gap:1rem;padding:1rem 1.5rem}.game__title{font-size:1.5rem}.game__level-button{padding:.625rem 1.25rem;font-size:.875rem}.game__main{gap:1rem;padding:1rem}.game__status{flex-direction:column;gap:.5rem;padding:.875rem 1rem}.game__board-container{min-height:300px;padding:1rem}.game__controls,.game__palette,.game__functions{padding:1rem}.game__modal{width:95%;padding:2rem}.game__modal-icon{font-size:3rem}.game__modal-title{font-size:2rem}.game__modal-message{font-size:1rem}.game__modal-actions{flex-direction:column}.game__modal-button{width:100%;padding:.875rem 1.5rem;font-size:1rem}}@media (max-width:480px){.game__header{padding:.875rem 1rem}.game__title{font-size:1.25rem}.game__main{gap:.75rem;padding:.75rem}.game__status{padding:.75rem}.game__status-label,.game__status-value{font-size:.875rem}.game__board-container{min-height:250px;padding:.75rem}.game__error{gap:.75rem;padding:1rem}.game__error-icon{font-size:1.5rem}.game__error-title{font-size:1rem}.game__error-message{font-size:.875rem}}.game__level-button:focus-visible,.game__modal-button:focus-visible{outline-offset:3px;outline:3px solid gold}@media (prefers-reduced-motion:reduce){.game__modal-overlay,.game__modal,.game__error,.game__modal-icon{animation:none}.game__level-button:hover,.game__modal-button:hover{transform:none}}.start-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.start-page__content{text-align:center;background:#fffffff2;border-radius:16px;max-width:600px;padding:3rem 2rem;box-shadow:0 20px 60px #0000004d}.start-page__title{color:#2d3748;text-shadow:2px 2px 4px #0000001a;margin:0 0 2rem;font-size:3rem;font-weight:700}.start-page__instructions{margin-bottom:2.5rem}.start-page__tagline{color:#4a5568;margin:0;font-size:1.5rem;line-height:1.6}.start-page__button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50px;padding:1rem 3rem;font-size:1.25rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #667eea66}.start-page__button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.start-page__button:active{transform:translateY(0)}.start-page__button:focus{outline-offset:4px;outline:3px solid #667eea}@media (max-width:768px){.start-page__title{font-size:2rem}.start-page__tagline{font-size:1.25rem}.start-page__content{padding:2rem 1.5rem}}
