:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body{margin:0;background:#1e1e1e;color:#f2f2f2;width:100%;height:100%;overflow:hidden}header{width:100%}:root{--cabinet-side: 5vw;--cabinet-margin-v: 2vh;--cabinet-bg: #293845;--cabinet-border: #14171a;--cabinet-shadow: #0c0e10;--cabinet-shadow-soft: rgba(0, 0, 0, .35)}div{margin:0;padding:0}*,*:before,*:after{box-sizing:border-box}#root{height:100vh;width:100vw;overflow:hidden}.hide{display:none!important}.app{height:100vh;width:100vw;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:16px;font-family:system-ui,Arial,sans-serif;overflow:hidden}.cabinet{width:90vw;height:calc(100% + 6vh);margin:var(--cabinet-margin-v) 5vw 0 5vw;padding:0;background:transparent;border-bottom:0;display:grid;grid-template-columns:var(--cabinet-side) 1fr var(--cabinet-side);gap:0}.cabinet-vertical-spacer{height:100%;width:var(--cabinet-side);background:var(--cabinet-bg);border-bottom:0;position:relative}.cabinet-vertical-spacer.outer-frame:after{content:"";position:absolute;top:0;bottom:0;width:2vh;pointer-events:none;background:linear-gradient(to right,#121213bf,#29384500)}.cabinet-vertical-spacer.outer-frame:first-child:after{right:-2vh}.cabinet-vertical-spacer.outer-frame:last-child:after{left:-2vh;transform:scaleX(-1)}.cabinet-top-left,.cabinet-top-right{height:100%;width:var(--cabinet-side);background:var(--cabinet-bg);border:4px solid var(--cabinet-border);border-bottom:0}.cabinet-horizontal-spacer{width:100%;height:5vh;background:var(--cabinet-bg);border-bottom:0;border-right:0;border-left:0}.cabinet-center{width:100%;display:grid;grid-template-rows:auto minmax(120px,1fr) auto;gap:0;position:relative;padding:0;background:transparent;border:0;z-index:1}.cabinet-center-top-spacer{height:var(--cabinet-margin-v)}.cabinet-center-top-banner{height:20vh;background:var(--cabinet-bg);border:4px solid var(--cabinet-border);border-left:0;border-right:0;border-radius:0;padding:12px;display:flex;align-items:center;justify-content:center;position:relative;overflow:visible;z-index:2;box-shadow:inset 0 6px 0 var(--cabinet-shadow),inset 0 -6px 0 var(--cabinet-shadow),0 10px 12px var(--cabinet-shadow-soft)}.cabinet-center-top-banner .page-header{border:2px solid #ff4fd8;border-radius:8px;padding:10px 18px;box-shadow:inset 0 0 18px #ff4fd8a6,inset 0 0 42px #ff4fd873,inset 0 0 72px #ff4fd840,0 0 14px #ff4fd8e6,0 0 32px #ff4fd8b3,0 0 64px #ff4fd88c}.cabinet-center-top-banner:after{content:"";position:absolute;left:0;right:0;bottom:-2vh;height:2vh;background:linear-gradient(to bottom,#121213bf,#29384500);pointer-events:none}.cabinet-center-main{background:#1f2a33;border:0;box-shadow:none;border-radius:0;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.cabinet-center-main .cabinet-vertical-spacer,.cabinet-center-main .cabinet-horizontal-spacer{background:#1f2a33}.cabinet-center-bottom-banner{height:20vh;background:var(--cabinet-bg)}.arcade-monitor{position:relative;padding:18px;border-radius:12px;background:radial-gradient(circle at top,#20242a,#101216 70%,#0b0d10);border:4px solid #0c0e10;box-shadow:inset 0 0 0 3px #262b30,inset 0 0 18px #000000bf,0 0 18px #00000073,0 0 24px #54b4ff1f;height:min(65vh,625px);overflow:hidden;z-index:3;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.arcade-monitor:before{content:"";position:absolute;inset:8px;border-radius:6px;background:radial-gradient(circle at top,#38445059,#080a0cf2);border:3px solid #121519;box-shadow:inset 0 0 0 3px #1d2228;z-index:0}.arcade-monitor.crt{filter:saturate(1.25) contrast(1.15) brightness(1.05)}.arcade-monitor.crt:after{content:"";position:absolute;inset:8px;border-radius:12px;background:radial-gradient(ellipse at center,#0000 55%,#0000008c),repeating-linear-gradient(to bottom,#ffffff0f,#ffffff0f 1px,#0000001a 2px 3px);mix-blend-mode:screen;opacity:.9;pointer-events:none;z-index:2;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.arcade-monitor>*{position:relative;z-index:3}.arcade-monitor .card-grid{width:100%;height:100%;padding:1%;gap:2% 2%;row-gap:5%;grid-template-columns:repeat(auto-fit,250px);grid-auto-rows:auto;align-content:start;justify-content:center;place-items:center;overflow-y:auto;overflow-x:hidden}.under-construction-banner{position:fixed;left:0;right:0;bottom:0;z-index:2000;background:#ffb020f2;color:#1f1300;text-align:center;font-weight:800;letter-spacing:.08em;padding:10px 12px;border-top:2px solid #ff8c00;box-shadow:0 -4px 14px #00000059;font-family:system-ui,Arial,sans-serif;text-transform:uppercase}.arcade-monitor .app-card{width:250px;height:200px;justify-self:center;align-self:center}.outer-frame{inset:0;border-radius:12px;position:relative;z-index:4;box-shadow:inset 0 0 0 6px #0c0e10,inset 0 0 18px #000000d9,0 0 28px #0000008c}.page-header{text-align:center;margin-bottom:0}.page-header h1{margin:0 0 6px;font-weight:300;color:#ff4fd8;text-shadow:0 0 6px rgba(255,79,216,.85),0 0 16px rgba(255,79,216,.55),0 0 32px rgba(255,79,216,.4)}.page-header p{margin:0;opacity:.8}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:18px;width:100%}@media(max-width:615px){.app{padding:24px 12px}.card-grid{grid-template-columns:1fr;gap:12px}}.app-card{position:relative;background:radial-gradient(circle at top,#2e2e2e,#171717);color:#f2f2f2;border:2px solid #222;border-radius:12px;padding:18px;text-align:center;display:flex;align-items:center;justify-content:center;cursor:pointer;aspect-ratio:4 / 3;width:100%;min-width:0;min-height:0;overflow:hidden;box-shadow:inset 0 0 10px #0000008c,0 0 18px #54b4ff1f;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.app-card-disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.2)}.app-card-disabled:hover{transform:none;border-color:#222;box-shadow:inset 0 0 10px #0000008c,0 0 18px #54b4ff1f}.app-card-content{display:flex;flex-direction:column;align-items:center;gap:6px}.app-card:hover{transform:translateY(-2px);border-color:#5a5a5a;box-shadow:inset 0 0 12px #0009,0 0 22px #54b4ff38}.app-card-focused,.app-card:focus-visible{transform:translateY(-2px);border-color:#8ab4ff;box-shadow:inset 0 0 12px #0009,0 0 0 2px #8ab4ff4d,0 0 26px #54b4ff59}.app-card:after{content:"";position:absolute;inset:8px;border-radius:12px;background:repeating-linear-gradient(to bottom,#ffffff0d,#ffffff0d 1px,#0000000a 2px 3px);opacity:.5;pointer-events:none;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.app-card h2{margin:0;font-size:16px}.app-subtitle{margin:0;font-size:12px;opacity:.8}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10}.screen-modal-overlay{position:fixed;inset:0;--screen-glow: .2;background:radial-gradient(ellipse 90% 70% at 50% 56%,rgba(0,255,255,calc(var(--screen-glow) * .5)),rgba(0,210,255,calc(var(--screen-glow) * .35)) 32%,#0000008c 72%,#000000b3);display:block;padding:24px;z-index:1000;border-radius:0;animation:screenOverlayFadeIn .18s ease-out}.screen-modal-overlay .modal{background:radial-gradient(circle at top,#20242a,#101216 70%,#0b0d10);max-width:none;max-height:none;border-radius:12px;box-shadow:0 0 180px rgba(0,255,255,calc(var(--screen-glow) * .8)),0 0 60px rgba(0,210,255,calc(var(--screen-glow) * .7)),0 0 24px rgba(0,160,255,calc(var(--screen-glow) * .55));animation:gameScreenFadeIn .2s ease-out}.screen-modal-overlay.closing{animation:screenOverlayFadeOut .16s ease-in forwards}.screen-modal-overlay.closing .modal{animation:gameScreenFadeOut .16s ease-in forwards}@keyframes screenOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes screenOverlayFadeOut{0%{opacity:1}to{opacity:0}}@keyframes gameScreenFadeIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes gameScreenFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(6px) scale(.98)}}.modal{background:#2f2f2f;color:#f2f2f2;border-radius:12px;width:fit-content;max-width:calc(100vw - 40px);box-shadow:0 16px 40px #00000059;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.screen-modal-overlay .modal{box-shadow:0 0 140px #78beff59,0 0 40px #78beff33;overflow:hidden}.modal-body{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;height:100%}.crt-toggle{background:transparent;border:1px solid #444;color:#f2f2f2;width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.crt-toggle.active{border-color:#8ab4ff;box-shadow:0 0 0 2px #8ab4ff59}.display-controls{position:relative}.display-button{background:transparent;border:1px solid #444;color:#f2f2f2;width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.display-reset{margin-top:4px;padding:8px 10px;border-radius:8px;border:1px solid #444;background:#1f1f1f;color:#f2f2f2;cursor:pointer;font-size:12px}.display-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:#e5e5e5}.display-row input[type=range]{flex:0 0 140px;width:140px}.settings-overlay{position:fixed;inset:0;background:#0000008c;z-index:1400;display:flex;align-items:center;justify-content:center;pointer-events:auto}.settings-window{width:min(840px,calc(100vw - 32px));max-height:calc(100vh - 40px);overflow:auto;border:1px solid #3d475e;border-radius:14px;background:#0f141ef5;box-shadow:0 18px 40px #00000073;padding:14px}.settings-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.settings-header h2{margin:0;font-size:18px;color:#e7f0ff}.settings-close{width:30px;height:30px;border:1px solid #58627d;border-radius:10px;background:#1c2332;color:#d7e3ff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:0}.settings-tabs{display:flex;gap:8px;margin-bottom:12px}.settings-tab{border:1px solid #4d5872;border-radius:10px;background:#1d2535;color:#c9d9ff;padding:7px 12px;cursor:pointer}.settings-tab.active{border-color:#87a7ff;box-shadow:0 0 0 2px #87a7ff40}.settings-body{border:1px solid #2c3448;border-radius:12px;background:#0c1018cc;padding:12px}.settings-grid{display:flex;flex-direction:column;gap:10px}.settings-placeholder p{margin:0 0 8px;color:#ccd7ee;font-size:13px}.settings-control-row{margin-bottom:10px}.screen{position:relative;padding:12px;border-radius:12px;background:radial-gradient(circle at top,#2b2b2b,#161616);border:3px solid #222;box-shadow:inset 0 0 18px #0009,0 10px 24px #00000059;overflow:hidden;width:100%;height:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;flex:1;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.crt-overlay{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:4}.crt-overlay canvas{width:100%;height:100%;display:block;border-radius:inherit}.screen .game-card{width:min(440px,80vw);max-height:80vh;margin:auto}.screen .board:not(.lights-board){width:100%;height:auto;max-height:100%;aspect-ratio:1 / 1;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.screen .board:not(.lights-board) .square{width:100%;height:100%;font-size:clamp(24px,7vw,56px)}.game-area{position:relative;width:100%;height:100%}.inline-modal-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000073;border-radius:12px;z-index:2;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.inline-modal{background:#191919e6;border:1px solid #4b4b4b;border-radius:12px;padding:12px 18px;text-align:center;box-shadow:0 6px 18px #0006;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.info-window{max-width:320px}.info-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.info-title{font-weight:700;margin:0}.info-close{background:transparent;border:none;color:#f2f2f2;cursor:pointer;font-size:16px}.info-text{font-size:14px;opacity:.9}.endgame-window{display:flex;flex-direction:column;align-items:center;gap:16px;min-height:240px;justify-content:space-between;font-weight:700;font-size:20px;min-width:min(360px,90vw);text-align:center}.endgame-message{font-size:22px;width:100%;flex:1;display:flex;align-items:center;justify-content:center;text-align:center}.endgame-actions{display:flex;gap:12px;justify-content:center;width:100%}.endgame-button{background:#1f1f1f;color:#f2f2f2;border:1px solid #4b4b4b;border-radius:12px;width:44px;height:44px;display:inline-flex;align-items:center;gap:0;cursor:pointer;font-weight:600;justify-content:center;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.endgame-button .fa{font-size:16px}@media(max-width:500px),(max-height:700px){.modal{padding:14px 16px}.modal-header{margin-bottom:8px}.modal-body{gap:8px}.screen{height:min(92vw,70vh);padding:8px;border-radius:12px;max-height:70vh}.screen .game-card{transform:scale(clamp(.65,min(100vw / 520,100vh / 720),.9));transform-origin:center}.game-card{padding:14px 16px;gap:12px}}.screen>*{z-index:1}.screen-content{position:relative;width:100%;height:100%;--curve-radius: calc(12px + var(--content-curvature, 0) * 18px);border-radius:var(--curve-radius);overflow:hidden;transform:scale(calc(1 - var(--content-curvature, 0) * .04));transform-origin:center;clip-path:inset(0 round var(--curve-radius));mask-image:radial-gradient(120% 120% at 50% 50%,#000 calc(78% - var(--content-curvature, 0) * 12%),transparent 100%);mask-size:100% 100%;mask-repeat:no-repeat;-webkit-mask-image:radial-gradient(120% 120% at 50% 50%,#000 calc(78% - var(--content-curvature, 0) * 12%),transparent 100%);-webkit-mask-size:100% 100%;-webkit-mask-repeat:no-repeat}.screen:before{content:"";position:absolute;inset:8px;border-radius:12px;border:1px solid rgba(255,255,255,.06);z-index:2;pointer-events:none}.screen.crt:after{content:"";position:absolute;inset:0;border-radius:12px;background:repeating-linear-gradient(to bottom,#ffffff14,#ffffff14 1px,#0000001a 2px 3px);mix-blend-mode:screen;opacity:1;z-index:3;pointer-events:none;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.screen.static:after{background:repeating-linear-gradient(to bottom,#ffffff38,#ffffff38 1px,#0003 2px 3px),repeating-linear-gradient(to right,#ffffff0f,#ffffff0f 1px,#0000000f 2px 3px);mix-blend-mode:normal;opacity:1;z-index:6;background-size:3px 3px,4px 4px;animation:staticFlicker .12s steps(1,end) infinite,staticShift .15s steps(2,end) infinite}.screen.static:before{background:none;z-index:5}.screen.static>*{visibility:hidden}@keyframes staticFlicker{0%{opacity:1}to{opacity:1}}@keyframes staticShift{0%{background-position:0 0,0 0}25%{background-position:1px 2px,-2px 1px}50%{background-position:-1px 3px,2px -1px}75%{background-position:2px -2px,-1px -2px}to{background-position:0 0,0 0}}.screen.crt{filter:saturate(1.35) contrast(1.22) brightness(1.05);box-shadow:inset 0 0 28px #000c,0 0 28px #54b4ff38}.screen.crt:before{content:"";position:absolute;inset:0;border-radius:12px;background:radial-gradient(ellipse at center,#0000,#00000052 60%,#000000a6);z-index:2;pointer-events:none;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.modal-header h2{margin:0}.close-button{background:transparent;border:none;color:#f2f2f2;font-size:20px;cursor:pointer}.modal-actions{display:flex;align-items:center;gap:8px}.global-controls{position:fixed;top:16px;right:16px;display:flex;align-items:center;gap:8px;z-index:1100;flex-direction:column;align-items:flex-end}.input-hint{min-width:280px;max-width:340px;border:1px solid #3f3f3f;border-radius:12px;background:#0e0e0edb;color:#d9d9d9;padding:8px 10px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 18px #00000059}.input-hint-source{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8ab4ff;font-weight:700}.input-hint-controls{font-size:12px;line-height:1.3}.info-button{background:transparent;border:1px solid #444;color:#f2f2f2;width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.info-button.active{border-color:#8ab4ff;box-shadow:0 0 0 2px #8ab4ff59}.reset-button{background:transparent;border:1px solid #444;color:#f2f2f2;width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.reset-button .fa{font-size:16px}.global-controls .close-button{background:transparent;border:1px solid #444;color:#f2f2f2;width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.global-controls .close-button .fa{font-size:16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.game-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 24px;background:#757272;border-radius:12px;box-shadow:none;max-width:100%}.world-scene-root{position:fixed;inset:0;width:100vw;height:100vh;background:#0b0e16}.world-canvas{width:100%;height:100%}.world-scene-root.world-input-locked .world-canvas{pointer-events:none}.monitor-capture-source{position:fixed;left:-200vw;top:0;width:990px;height:605px;opacity:0;pointer-events:none;overflow:hidden}.monitor-capture-content{width:100%;height:100%}.world-interact-prompt{position:fixed;left:50%;bottom:32px;transform:translate(-50%);padding:10px 16px;border:1px solid #3e4e63;border-radius:12px;background:#0c0f18e6;color:#dce8ff;font-size:14px;font-weight:600;box-shadow:0 8px 24px #00000059;z-index:1200}.world-help{position:fixed;left:16px;bottom:16px;max-width:320px;padding:8px 12px;border:1px solid #2f3d54;border-radius:10px;background:#0c0f18c7;color:#c6d2ea;font-size:12px;z-index:1200}.fps-overlay{position:fixed;top:10px;left:10px;z-index:1300;min-width:64px;padding:6px 8px;border:1px solid #2f3d54;border-radius:8px;background:#0c0f18d6;color:#d6e2ff;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px}.splash-screen{position:fixed;inset:0;z-index:1600;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,#10182a,#05070d 65%,#03040a);color:#d7e5ff;opacity:1;transition:opacity .7s ease;pointer-events:all}.splash-screen.fade-out{opacity:0}.splash-inner{text-align:center;border:1px solid rgba(120,152,214,.35);border-radius:14px;background:#070a14b8;padding:22px 28px;box-shadow:0 18px 40px #0006}.splash-inner h1{margin:0 0 8px;font-size:28px;font-weight:600;color:#dbe7ff}.splash-inner p{margin:0;font-size:14px;color:#9db3db}.arcade-monitor-surface{width:100%;height:100%;display:flex;flex-direction:column;gap:0;border:0;border-radius:0;background:#000;box-shadow:none;overflow:hidden}.arcade-monitor-stack{position:relative;flex:1 1 auto;min-height:0}.arcade-monitor-stack .arcade-monitor{height:100%;padding:0;border:0;border-radius:0;background:#000;box-shadow:none}.arcade-monitor-stack .arcade-monitor:before{display:none}.embedded-game-host{position:absolute;inset:0;z-index:10;animation:gameScreenFadeIn .2s ease-out}.embedded-game-host.closing{animation:gameScreenFadeOut .16s ease-in forwards}.embedded-game-host .screen{width:100%;height:100%;border-radius:12px}.lights-card{padding:14px 22px;gap:12px}.board{display:grid;grid-template-columns:repeat(3,70px);grid-template-rows:repeat(3,70px);gap:8px}.square{width:70px;height:70px;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;line-height:1;border:2px solid #222;color:#f2f2f2;border-radius:12px;background:#000;padding:0;box-sizing:border-box;cursor:pointer;aspect-ratio:1 / 1;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.square:focus{outline:3px solid #4c8bf5}.square.tile{background:#111}.square.chromatic-text{background-color:#111;background-image:linear-gradient(90deg,#ff3b7f,#ffd400,#39e9ff,#7cff6b,#a44bff,#ff3b7f);background-size:300% 100%;background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;animation:chromaticTextShift 3.5s linear infinite}.square.blank{background:transparent;border-color:transparent;cursor:default}@keyframes chromaticTextShift{0%{background-position:0% 50%}to{background-position:100% 50%}}.lights-board{gap:6px;width:100%;height:100%;place-content:center}.lights-square{border-radius:12px;width:100%;height:100%;font-size:20px;aspect-ratio:1 / 1;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.square.lights-square.light{background:#f2f2f2;border-color:#d0d0d0;box-shadow:0 0 6px #f2f2f259}.square.lights-square.light.chromatic-squares{position:relative;overflow:hidden;background:#101010;border-color:#fff9;box-shadow:0 0 10px #78c8ff59}.square.lights-square.light.chromatic-squares:before{content:"";position:absolute;inset:-30%;background:conic-gradient(#ff4d6d,#ffb347,#ffe66d,#7cff6b,#39e9ff,#6a5bff,#ff4d6d);animation:chromaticSquaresSpin 4s linear infinite,chromaticSquaresHue 3s linear infinite;opacity:.95}.square.lights-square.light.chromatic-squares:after{content:"";position:absolute;inset:8%;border-radius:10px;background:#00000040;box-shadow:inset 0 0 14px #00000073}@keyframes chromaticSquaresSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes chromaticSquaresHue{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.square.lights-square.dark{background:#111;border-color:#333}.lights-controls{position:relative;width:100%;display:flex;justify-content:center;margin-top:2px}.drawer-toggle{background:#2a2a2a;color:#f2f2f2;border:1px solid #444;border-radius:12px;width:30px;height:26px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.difficulty-drawer{position:absolute;bottom:40px;background:#202020f2;border:1px solid #444;border-radius:12px;padding:10px 12px;transform:translateY(12px);opacity:0;pointer-events:none;transition:transform .2s ease,opacity .2s ease;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.difficulty-drawer.open{transform:translateY(0);opacity:1;pointer-events:auto}.size-buttons{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.size-button{background:#2a2a2a;color:#f2f2f2;border:1px solid #444;border-radius:12px;padding:6px 10px;cursor:pointer;-webkit-border-radius:12px;-moz-border-radius:12px;-ms-border-radius:12px;-o-border-radius:12px}.size-button.active{border-color:#8ab4ff;box-shadow:0 0 0 2px #8ab4ff4d}
