ADHD CONSOLE
COPY THE DATA URI BELOW
PASTE INTO YOUR BROWSER
AND START PLAYING
data:text/html;base64,<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,minimum-scale=1.0,user-scalable=no,viewport-fit=cover">
<meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
<title>ADHD</title>
<style>
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;touch-action:manipulation}
html,body{height:100%;overflow:hidden;position:fixed;inset:0;touch-action:none;user-select:none;-webkit-user-select:none}
body{font-family:system-ui,-apple-system,sans-serif;background:#1a1a22}
.desktop-wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center}
.desktop-surface{display:none}
.device{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(178deg,#e8e4de 0%,#ddd8d0 25%,#d8d3cb 50%,#d4cfc6 75%,#d0cbc2 100%)}
.device::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 1px,rgba(255,255,255,.03) 1px,rgba(255,255,255,.03) 2px);pointer-events:none;z-index:0}
.device::after{content:'';position:absolute;inset:0;opacity:.35;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");pointer-events:none;z-index:0}
@media(min-width:500px){
  body{background:linear-gradient(145deg,#2a2a35,#1a1a22,#151520)}
  .desktop-surface{display:block;position:fixed;inset:0;background:radial-gradient(ellipse at 50% 40%,#2a2a35,#151520);pointer-events:none}
  .desktop-surface::before{content:'';position:absolute;inset:0;opacity:.4;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)' opacity='.08'/%3E%3C/svg%3E")}
  .device{width:390px;height:760px;max-height:95vh;border-radius:28px;box-shadow:0 8px 30px rgba(0,0,0,.4),0 30px 80px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.05),inset 0 1px 0 rgba(255,255,255,.15);overflow:hidden}
}
@media(min-width:500px) and (max-height:600px){.device{height:95vh;width:340px}}
.top-strip{flex-shrink:0;display:flex;align-items:center;padding:max(env(safe-area-inset-top),8px) 18px 2px;z-index:2}
.brand-block{display:flex;align-items:center;gap:10px}
.led-housing{width:12px;height:12px;border-radius:50%;background:linear-gradient(145deg,#c8c4bc,#b8b4ac);box-shadow:inset 0 1px 2px rgba(0,0,0,.15),0 1px 0 rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center}
.led-dot{width:6px;height:6px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#6f6,#0a0);box-shadow:0 0 4px rgba(0,255,0,.4);animation:ledg 3s ease-in-out infinite}
@keyframes ledg{0%,100%{box-shadow:0 0 4px rgba(0,255,0,.4)}50%{box-shadow:0 0 2px rgba(0,255,0,.2)}}
.brand-text{font-family:'Courier New',monospace;font-weight:700;font-size:13px;color:#555;letter-spacing:4px}
.brand-sub{font-family:'Courier New',monospace;font-size:5.5px;color:#999;letter-spacing:1.5px;margin-top:1px}
.screen-section{flex-shrink:0;padding:6px 14px 6px;z-index:2}
.screen-bezel{background:linear-gradient(180deg,#222,#1a1a1a);border-radius:16px;padding:6px;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.25),0 8px 24px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.04)}
.screen-bezel::before,.screen-bezel::after{content:'';position:absolute;width:5px;height:5px;border-radius:50%;background:radial-gradient(circle at 40% 40%,#2a2a36,#16161e);box-shadow:inset 0 1px 1px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.03);top:50%;transform:translateY(-50%)}
.screen-bezel::before{left:3px}.screen-bezel::after{right:3px}
.screen-glass{position:relative;width:100%;aspect-ratio:5/4;border-radius:12px;overflow:hidden;background:#111;box-shadow:inset 0 0 30px rgba(0,0,0,.6),inset 0 2px 4px rgba(0,0,0,.4)}
.screen-glass::before{content:'';position:absolute;top:-10%;left:-20%;width:60%;height:40%;background:radial-gradient(ellipse,rgba(255,255,255,.03) 0%,transparent 70%);transform:rotate(-15deg);pointer-events:none;z-index:20}
canvas{position:absolute;top:0;left:0;width:100%;height:100%;image-rendering:pixelated;z-index:1}
.controls-section{flex:1;display:flex;flex-direction:column;justify-content:center;z-index:2;padding:0 14px;min-height:0;gap:4px}
.controls-main{display:flex;justify-content:space-between;align-items:center}
.dpad{position:relative;width:115px;height:115px;flex-shrink:0}
.dpad::before{content:'';position:absolute;inset:14px;border-radius:50%;box-shadow:0 6px 14px rgba(0,0,0,.12);pointer-events:none}
.dpad-arm{position:absolute;cursor:pointer;z-index:2;background:linear-gradient(180deg,#ff7b3a 0%,#f06a28 40%,#e55d1e 100%);box-shadow:0 3px 0 #b8461a,0 4px 8px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.3),inset 0 -1px 2px rgba(0,0,0,.15)}
.dpad-arm:active{background:linear-gradient(180deg,#ff8844,#f07030);transform:translateY(1px);box-shadow:0 1px 0 #b8461a,inset 0 1px 0 rgba(255,255,255,.2)}
.dpad-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:34px;height:34px;background:linear-gradient(145deg,#f07030,#e05818);border-radius:50%;z-index:3;box-shadow:inset 0 2px 4px rgba(255,255,255,.2),inset 0 -2px 4px rgba(0,0,0,.2),0 2px 6px rgba(0,0,0,.15)}
.d-up{width:34px;height:40px;top:0;left:50%;margin-left:-17px;border-radius:6px 6px 0 0}
.d-down{width:34px;height:40px;bottom:0;left:50%;margin-left:-17px;border-radius:0 0 6px 6px}
.d-left{width:40px;height:34px;left:0;top:50%;margin-top:-17px;border-radius:6px 0 0 6px}
.d-right{width:40px;height:34px;right:0;top:50%;margin-top:-17px;border-radius:0 6px 6px 0}
.dpad-arm::after{content:'';position:absolute;opacity:.35}
.d-up::after{border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:6px solid #fff;top:8px;left:50%;margin-left:-5px}
.d-down::after{border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #fff;bottom:8px;left:50%;margin-left:-5px}
.d-left::after{border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:6px solid #fff;left:10px;top:50%;margin-top:-5px}
.d-right::after{border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:6px solid #fff;right:10px;top:50%;margin-top:-5px}
.ab-section{flex-shrink:0}
.ab-row{display:flex;gap:8px;transform:rotate(-25deg)}
.ab-col{text-align:center}
.ab-ring{width:52px;height:52px;border-radius:50%;padding:3px;background:linear-gradient(145deg,#aaa,#888);box-shadow:0 3px 8px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.3)}
.ab-btn{width:100%;height:100%;border-radius:50%;border:none;cursor:pointer;font-family:'Courier New',monospace;font-weight:700;font-size:11px;color:rgba(255,255,255,.5);background:linear-gradient(155deg,#3a3a3a 0%,#222 40%,#1a1a1a 100%);box-shadow:inset 0 2px 4px rgba(255,255,255,.08),inset 0 -3px 6px rgba(0,0,0,.4);position:relative;overflow:hidden}
.ab-btn::before{content:'';position:absolute;top:3px;left:15%;width:70%;height:35%;border-radius:50%;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);pointer-events:none}
.ab-btn:active{background:linear-gradient(155deg,#444,#2a2a2a);box-shadow:inset 0 3px 6px rgba(0,0,0,.5)}
.ab-lbl{font-family:'Courier New',monospace;font-size:7px;color:#999;margin-top:5px;font-weight:700;transform:rotate(25deg)}
.menu-row{display:flex;justify-content:center;align-items:flex-start;gap:12px;padding:4px 0 0}
.menu-col{text-align:center}
.menu-pill{width:56px;height:20px;border-radius:10px;border:none;cursor:pointer;background:linear-gradient(180deg,#6a6a72,#555560);box-shadow:0 3px 0 #444448,0 4px 8px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.1)}
.menu-pill:active{box-shadow:0 1px 0 #444448;transform:translateY(2px)}
.menu-lbl{font-family:'Courier New',monospace;font-size:6px;color:#999;margin-top:4px;letter-spacing:1px;font-weight:700}
.home-pill{width:44px;height:20px;border-radius:10px;border:2px solid rgba(0,0,0,.15);cursor:pointer;background:linear-gradient(180deg,#ff7b3a,#e05520);box-shadow:0 3px 0 #a03a10,0 4px 8px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center}
.home-pill:active{box-shadow:0 1px 0 #a03a10;transform:translateY(2px)}
.home-pill-inner{width:12px;height:7px;border-radius:3px;background:rgba(255,255,255,.45)}
.speaker-section{padding:4px 18px 0;z-index:2}
.speaker-grid{display:grid;grid-template-columns:repeat(6,6px);grid-template-rows:repeat(4,6px);gap:3px;width:fit-content}
.sp-dot{width:5px;height:5px;border-radius:50%;background:linear-gradient(145deg,#b8b4ac,#c8c4bc);box-shadow:inset 0 1px 2px rgba(0,0,0,.25),0 1px 0 rgba(255,255,255,.3)}
.bottom-strip{display:flex;justify-content:space-between;align-items:center;padding:2px 18px max(env(safe-area-inset-bottom),6px);z-index:2}
.bot-left{font-family:'Courier New',monospace;font-size:5px;color:#aaa;letter-spacing:2px}
.bot-right{font-family:'Courier New',monospace;font-size:4.5px;color:#bbb;letter-spacing:1px}
</style>
</head>
<body>
<div class="desktop-wrap">
<div class="desktop-surface"></div>
<div class="device">
<div class="top-strip"><div class="brand-block"><div class="led-housing"><div class="led-dot"></div></div><div><div class="brand-text">ADHD</div><div class="brand-sub">ALL DAY HYPER DRIVE</div></div></div></div>
<div class="screen-section"><div class="screen-bezel"><div class="screen-glass"><canvas id="gc"></canvas></div></div></div>
<div class="controls-section">
  <div class="controls-main">
    <div class="dpad"><div class="dpad-center"></div><div class="dpad-arm d-up" id="du"></div><div class="dpad-arm d-down" id="dd"></div><div class="dpad-arm d-left" id="dl"></div><div class="dpad-arm d-right" id="dr"></div></div>
    <div class="ab-section"><div class="ab-row">
      <div class="ab-col"><div class="ab-ring"><button class="ab-btn" id="bB">B</button></div><div class="ab-lbl">B</div></div>
      <div class="ab-col"><div class="ab-ring"><button class="ab-btn" id="bA">A</button></div><div class="ab-lbl">A</div></div>
    </div></div>
  </div>
  <div class="menu-row">
    <div class="menu-col"><div class="menu-pill" id="mSel"></div><div class="menu-lbl">SELECT</div></div>
    <div class="menu-col"><div class="menu-pill" id="mSt"></div><div class="menu-lbl">START</div></div>
    <div class="menu-col"><button class="home-pill" id="homeBtn"><div class="home-pill-inner"></div></button><div class="menu-lbl">HOME</div></div>
  </div>
</div>
<div class="speaker-section"><div class="speaker-grid" id="spkr"></div></div>
<div class="bottom-strip"><span class="bot-left">HYPERFOCUS™</span><span class="bot-right">MODEL ADHD-01</span></div>
</div>
</div>
<script>
document.addEventListener('gesturestart',function(e){e.preventDefault()});
document.addEventListener('gesturechange',function(e){e.preventDefault()});
document.addEventListener('gestureend',function(e){e.preventDefault()});
document.addEventListener('dblclick',function(e){e.preventDefault()});
document.addEventListener('touchmove',function(e){if(e.touches.length>1)e.preventDefault()},{passive:false});
(function(){var g=document.getElementById('spkr');for(var i=0;i<24;i++){var d=document.createElement('div');d.className='sp-dot';g.appendChild(d)}})();

var cv=document.getElementById('gc'),c=cv.getContext('2d');
cv.width=240;cv.height=192;
var W=240,H=192,F='700 ';
var STATE='boot',bootT=0,bootPhase=0,menuSel=0;
var input={u:0,d:0,l:0,r:0,a:0,b:0,start:0,home:0};
var stars=[];for(var i=0;i<40;i++)stars.push({x:Math.random()*W,y:Math.random()*H,s:Math.random()*.6+.2,b:Math.random()*6,sp:Math.random()*.02+.005});
var particles=[];
function drawStars(a){stars.forEach(function(s){s.b+=s.sp;c.fillStyle='rgba(255,255,255,'+(Math.sin(s.b)*.3+.2)*a+')';c.fillRect(s.x,s.y,s.s,s.s)})}
function addP(x,y,n,cols){for(var i=0;i<n;i++)particles.push({x:x,y:y,vx:(Math.random()-.5)*4,vy:(Math.random()-.5)*4,life:18,color:cols[i%cols.length]})}
function drawP(){particles.forEach(function(p){p.x+=p.vx;p.y+=p.vy;p.vx*=.94;p.vy*=.94;p.life--;c.globalAlpha=p.life/18;c.fillStyle=p.color;c.fillRect(p.x-1,p.y-1,2,2);c.globalAlpha=1});particles=particles.filter(function(p){return p.life>0})}

var games=[
  {name:'HYPER BLOCKS',genre:'PUZZLE',color:'#48dbfb',icon:function(x,y){c.fillStyle='#48dbfb';c.fillRect(x,y,8,8);c.fillRect(x+9,y,8,8);c.fillRect(x,y+9,8,8);c.fillRect(x+9,y+9,8,8)}},
  {name:'SEROTONIN SNAKE',genre:'ARCADE',color:'#55efc4',icon:function(x,y){c.fillStyle='#55efc4';for(var i=0;i<4;i++)c.fillRect(x+i*5,y+8,4,4);c.fillStyle='#fff';c.fillRect(x,y+6,4,6)}},
  {name:'DOPAMINE BREAKER',genre:'ACTION',color:'#fd79a8',icon:function(x,y){var cl=['#ff6b6b','#feca57','#48dbfb'];for(var i=0;i<3;i++){c.fillStyle=cl[i];c.fillRect(x,y+i*5,18,4)}}},
  {name:'FOCUS FIRE',genre:'SHOOTER',color:'#feca57',icon:function(x,y){c.fillStyle='#feca57';var a=[[0,0,1,0,0],[0,1,1,1,0],[1,0,1,0,1]];for(var r=0;r<a.length;r++)for(var co=0;co<a[r].length;co++)if(a[r][co])c.fillRect(x+co*4,y+r*4,3,3)}}
];
var RC=['#ff6b6b','#feca57','#48dbfb','#55efc4'];

// ==================== BOOT ====================
function drawBoot(){
  c.fillStyle='#0a0c14';c.fillRect(0,0,W,H);drawStars(1);bootT++;
  if(bootPhase===0){
    var a=Math.min(1,bootT/40);c.globalAlpha=a;
    c.font=F+'28px "Courier New",monospace';c.textAlign='center';
    var t='ADHD',tw=c.measureText(t).width,sx=120-tw/2;
    for(var i=0;i<4;i++){c.fillStyle=RC[i];c.fillText(t[i],sx+c.measureText(t.substring(0,i)).width+8,92)}
    c.font='400 6px "Courier New",monospace';c.fillStyle='rgba(255,255,255,.4)';c.fillText('ALL DAY HYPER DRIVE',120,108);
    if(bootT>30){var bw=Math.min(80,(bootT-30)*2);c.fillStyle='rgba(255,255,255,.08)';c.fillRect(80,125,80,3);c.fillStyle='#ff7b3a';c.fillRect(80,125,bw,3);if(Math.random()>.5)addP(80+bw,126,1,RC)}
    c.globalAlpha=1;if(bootT>80){bootPhase=1;bootT=0}
  }else{
    c.font=F+'28px "Courier New",monospace';c.textAlign='center';
    var t='ADHD',tw=c.measureText(t).width,sx=120-tw/2;
    for(var i=0;i<4;i++){c.fillStyle=RC[i];c.fillText(t[i],sx+c.measureText(t.substring(0,i)).width+8,82)}
    c.font='400 6px "Courier New",monospace';c.fillStyle='rgba(255,255,255,.3)';c.fillText('ALL DAY HYPER DRIVE',120,98);
    if(Math.floor(bootT/25)%2===0){c.font=F+'8px "Courier New",monospace';c.fillStyle='#ff7b3a';c.fillText('PRESS START',120,130)}
    c.font='400 5px "Courier New",monospace';c.fillStyle='rgba(255,255,255,.12)';c.fillText('v1.0 // 4 GAMES',120,170);
  }
  drawP();
}

// ==================== MENU ====================
function drawMenu(){
  c.fillStyle='#0a0c14';c.fillRect(0,0,W,H);drawStars(.5);
  c.font=F+'10px "Courier New",monospace';c.textAlign='left';var hx=10;
  for(var i=0;i<4;i++){c.fillStyle=RC[i];c.fillText('ADHD'[i],hx,16);hx+=c.measureText('ADHD'[i]).width+1}
  c.font='400 5px "Courier New",monospace';c.fillStyle='rgba(255,255,255,.2)';c.fillText('SELECT CARTRIDGE',hx+6,16);
  var grad=c.createLinearGradient(10,22,230,22);grad.addColorStop(0,'#ff6b6b');grad.addColorStop(.33,'#feca57');grad.addColorStop(.66,'#48dbfb');grad.addColorStop(1,'#55efc4');
  c.fillStyle=grad;c.fillRect(10,20,220,1);
  games.forEach(function(g,i){
    var y=32+i*38,s=i===menuSel;
    if(s){c.fillStyle='rgba(255,255,255,.03)';c.fillRect(6,y-4,228,36);c.strokeStyle=g.color;c.globalAlpha=.3;c.strokeRect(6.5,y-3.5,227,35);c.globalAlpha=1;c.fillStyle=g.color;c.fillRect(6,y-4,2,36)}
    g.icon(14,y+4);
    c.font=F+'8px "Courier New",monospace';c.fillStyle=s?'#fff':'rgba(255,255,255,.4)';c.textAlign='left';c.fillText(g.name,40,y+10);
    c.font='400 5px "Courier New",monospace';c.fillStyle=s?g.color:'rgba(255,255,255,.15)';c.fillText(g.genre,40,y+20);
    if(s){c.fillStyle=g.color;c.font=F+'10px "Courier New",monospace';c.textAlign='right';c.fillText('>',230,y+14)}
  });
  c.font='400 5px "Courier New",monospace';c.textAlign='center';c.fillStyle='rgba(255,255,255,.12)';c.fillText('D-PAD = SELECT  /  A = PLAY  /  HOME = BACK',120,186);
  drawP();
}

// ==================== TETRIS ====================
var tet={};
tet.SHAPES=[[[1,1,1,1]],[[1,1],[1,1]],[[0,1,0],[1,1,1]],[[1,0,0],[1,1,1]],[[0,0,1],[1,1,1]],[[1,1,0],[0,1,1]],[[0,1,1],[1,1,0]]];
tet.C=[{f:'#48dbfb',h:'#7ae8ff',s:'#2a9ac0'},{f:'#feca57',h:'#ffe080',s:'#c8a030'},{f:'#a29bfe',h:'#c4bfff',s:'#7a72d0'},{f:'#ff6b6b',h:'#ff9a9a',s:'#d04040'},{f:'#ff9ff3',h:'#ffc0f8',s:'#d070c0'},{f:'#55efc4',h:'#80ffda',s:'#30c090'},{f:'#fd79a8',h:'#ff99c0',s:'#d05080'}];
tet.SZ=9;tet.COLS=10;tet.ROWS=20;tet.OX=4;tet.OY=4;tet.SIDE=tet.COLS*tet.SZ+tet.OX+10;
function tetInit(){tet.board=[];for(var r=0;r<tet.ROWS;r++){tet.board[r]=[];for(var c=0;c<tet.COLS;c++)tet.board[r][c]=-1}tet.score=0;tet.level=1;tet.lines=0;tet.drop=0;tet.speed=36;tet.over=false;tet.paused=false;tet.shk=0;tet.nxt=Math.floor(Math.random()*7);tetSpawn()}
function tetSpawn(){tet.cT=tet.nxt;tet.nxt=Math.floor(Math.random()*7);tet.cur=tet.SHAPES[tet.cT].map(function(r){return r.slice()});tet.cX=Math.floor((tet.COLS-tet.cur[0].length)/2);tet.cY=0;if(tetHit(tet.cX,tet.cY,tet.cur))tet.over=true}
function tetHit(px,py,p){for(var r=0;r<p.length;r++)for(var co=0;co<p[r].length;co++)if(p[r][co]){var nx=px+co,ny=py+r;if(nx<0||nx>=tet.COLS||ny>=tet.ROWS)return true;if(ny>=0&&tet.board[ny][nx]>=0)return true}return false}
function tetMerge(){for(var r=0;r<tet.cur.length;r++)for(var co=0;co<tet.cur[r].length;co++)if(tet.cur[r][co]&&tet.cY+r>=0)tet.board[tet.cY+r][tet.cX+co]=tet.cT}
function tetClear(){var cl=0;for(var r=tet.ROWS-1;r>=0;r--)if(tet.board[r].every(function(v){return v>=0})){tet.board.splice(r,1);var nr=[];for(var i=0;i<tet.COLS;i++)nr.push(-1);tet.board.unshift(nr);cl++;r++}if(cl){tet.score+=[0,100,300,500,800][cl]*tet.level;tet.lines+=cl;tet.level=Math.floor(tet.lines/10)+1;tet.speed=Math.max(3,36-tet.level*3);tet.shk=cl>2?12:6}}
function tetRot(){var r=tet.cur[0].map(function(_,i){return tet.cur.map(function(row){return row[i]}).reverse()});var k=[0,-1,1,-2,2];for(var i=0;i<k.length;i++)if(!tetHit(tet.cX+k[i],tet.cY,r)){tet.cur=r;tet.cX+=k[i];return}}
function tetMove(d){if(!tetHit(tet.cX+d,tet.cY,tet.cur))tet.cX+=d}
function tetDrop(){var d=0;while(!tetHit(tet.cX,tet.cY+1,tet.cur)){tet.cY++;d++}tet.score+=d*2;tetMerge();tetClear();tetSpawn()}
function tetTick(){if(tet.over||tet.paused)return;tet.drop++;if(tet.drop>=tet.speed){tet.drop=0;if(!tetHit(tet.cX,tet.cY+1,tet.cur))tet.cY++;else{tetMerge();tetClear();tetSpawn()}}}
function tetDraw(){
  var sk=tet.shk>0?Math.sin(tet.shk*2)*(tet.shk/4):0;c.save();c.translate(sk,0);if(tet.shk>0)tet.shk--;
  c.fillStyle='#0a0c12';c.fillRect(0,0,W,H);c.fillStyle='#0c0e16';c.fillRect(tet.OX,tet.OY,tet.COLS*tet.SZ,tet.ROWS*tet.SZ);
  c.globalAlpha=.04;c.strokeStyle='#fff';for(var r=0;r<=tet.ROWS;r++){c.beginPath();c.moveTo(tet.OX,tet.OY+r*tet.SZ);c.lineTo(tet.OX+tet.COLS*tet.SZ,tet.OY+r*tet.SZ);c.stroke()}for(var co=0;co<=tet.COLS;co++){c.beginPath();c.moveTo(tet.OX+co*tet.SZ,tet.OY);c.lineTo(tet.OX+co*tet.SZ,tet.OY+tet.ROWS*tet.SZ);c.stroke()}c.globalAlpha=1;
  for(var r=0;r<tet.ROWS;r++)for(var co=0;co<tet.COLS;co++)if(tet.board[r][co]>=0)tetBlk(co,r,tet.board[r][co]);
  if(tet.cur&&!tet.over){var gy=tet.cY;while(!tetHit(tet.cX,gy+1,tet.cur))gy++;for(var r=0;r<tet.cur.length;r++)for(var co=0;co<tet.cur[r].length;co++)if(tet.cur[r][co]&&gy+r>=0){var bx=tet.OX+(tet.cX+co)*tet.SZ,by=tet.OY+(gy+r)*tet.SZ;c.strokeStyle=tet.C[tet.cT].f;c.globalAlpha=.2;c.strokeRect(bx+.5,by+.5,tet.SZ-2,tet.SZ-2);c.globalAlpha=1}
  for(var r=0;r<tet.cur.length;r++)for(var co=0;co<tet.cur[r].length;co++)if(tet.cur[r][co]&&tet.cY+r>=0)tetBlk(tet.cX+co,tet.cY+r,tet.cT)}
  var sx=tet.SIDE;c.font=F+'8px Arial';c.fillStyle='rgba(255,255,255,.6)';c.textAlign='left';c.fillText('HYPER BLOCKS',sx,14);
  c.font='600 6px Arial';c.fillStyle='rgba(255,255,255,.25)';c.fillText('SCORE',sx,30);c.fillStyle='#feca57';c.font=F+'10px Arial';c.fillText(String(tet.score),sx,42);
  c.fillStyle='rgba(255,255,255,.25)';c.font='600 6px Arial';c.fillText('LEVEL',sx,58);c.fillStyle='#48dbfb';c.font=F+'10px Arial';c.fillText(String(tet.level),sx,70);
  c.fillStyle='rgba(255,255,255,.25)';c.font='600 6px Arial';c.fillText('LINES',sx,86);c.fillStyle='#55efc4';c.font=F+'10px Arial';c.fillText(String(tet.lines),sx,98);
  c.fillStyle='rgba(255,255,255,.25)';c.font='600 6px Arial';c.fillText('NEXT',sx,116);
  if(!tet.over){var np=tet.SHAPES[tet.nxt];for(var r=0;r<np.length;r++)for(var co=0;co<np[r].length;co++)if(np[r][co]){var bx=sx+co*tet.SZ+2,by=120+r*tet.SZ;c.fillStyle=tet.C[tet.nxt].f;c.fillRect(bx,by,tet.SZ-1,tet.SZ-1)}}
  if(tet.over){c.fillStyle='rgba(10,12,18,.92)';c.fillRect(0,0,W,H);c.font=F+'14px Arial';c.fillStyle='#ef4444';c.textAlign='center';c.fillText('GAME OVER',W/2,H/2-12);c.font=F+'10px Arial';c.fillStyle='#feca57';c.fillText(tet.score,W/2,H/2+6);c.font='600 7px Arial';c.fillStyle='rgba(255,255,255,.3)';c.fillText('START TO RETRY',W/2,H/2+22)}
  if(tet.paused&&!tet.over){c.fillStyle='rgba(10,12,18,.88)';c.fillRect(0,0,W,H);c.font=F+'14px Arial';c.fillStyle='rgba(255,255,255,.6)';c.textAlign='center';c.fillText('PAUSED',W/2,H/2)}
  c.restore();
}
function tetBlk(x,y,t){var bx=tet.OX+x*tet.SZ,by=tet.OY+y*tet.SZ,cl=tet.C[t];c.fillStyle=cl.f;c.fillRect(bx,by,tet.SZ-1,tet.SZ-1);c.fillStyle=cl.h;c.fillRect(bx+1,by+1,tet.SZ-3,1);c.fillRect(bx+1,by+1,1,tet.SZ-3);c.fillStyle=cl.s;c.fillRect(bx+tet.SZ-2,by+1,1,tet.SZ-2);c.fillRect(bx+1,by+tet.SZ-2,tet.SZ-2,1)}
function tetInput(btn){if(tet.over){if(btn==='start')tetInit();return}if(btn==='start')tet.paused=!tet.paused;if(tet.paused)return;if(btn==='u'||btn==='a')tetRot();if(btn==='b')tetDrop()}
var tetHoldI=null;function tetHoldStart(fn){fn();tetHoldI=setInterval(fn,70)}function tetHoldStop(){clearInterval(tetHoldI)}

// ==================== SNAKE ====================
var snk={};
function snkInit(){snk.body=[{x:12,y:9},{x:11,y:9},{x:10,y:9}];snk.dir={x:1,y:0};snk.nd={x:1,y:0};snk.score=0;snk.hi=snk.hi||0;snk.spd=6;snk.tick=0;snk.alive=true;snk.trail=[];snkFood()}
function snkFood(){var p;do{p={x:Math.floor(Math.random()*24),y:Math.floor(Math.random()*19)}}while(snk.body.some(function(s){return s.x===p.x&&s.y===p.y}));snk.food=p;snk.food.a=0}
function snkTick(){if(!snk.alive)return;snk.tick++;if(snk.tick<snk.spd)return;snk.tick=0;snk.dir=snk.nd;var h={x:(snk.body[0].x+snk.dir.x+24)%24,y:(snk.body[0].y+snk.dir.y+19)%19};if(snk.body.some(function(s){return s.x===h.x&&s.y===h.y})){snk.alive=false;if(snk.score>snk.hi)snk.hi=snk.score;addP(h.x*9+12+4,h.y*9+10+4,10,['#ff6b6b']);return}var tail=snk.body[snk.body.length-1];snk.trail.push({x:tail.x*9+12+4,y:tail.y*9+10+4,life:8});snk.body.unshift(h);if(h.x===snk.food.x&&h.y===snk.food.y){snk.score+=10;snk.spd=Math.max(2,6-Math.floor(snk.score/30));addP(snk.food.x*9+12+4,snk.food.y*9+10+4,5,['#feca57','#55efc4','#ff9ff3']);snkFood()}else snk.body.pop()}
function snkDraw(){var G=9,OX=12,OY=10;c.fillStyle='#0a0c12';c.fillRect(0,0,W,H);c.strokeStyle='rgba(255,255,255,.03)';c.strokeRect(OX-.5,OY-.5,24*G+1,19*G+1);
c.font=F+'7px Arial';c.textAlign='left';c.fillStyle='rgba(255,255,255,.5)';c.fillText('SEROTONIN SNAKE',OX,OY-2);c.textAlign='right';c.fillStyle='#feca57';c.fillText('SCORE:'+snk.score,OX+24*G,OY-2);
snk.trail.forEach(function(t){t.life--;c.fillStyle='rgba(85,239,196,'+(t.life/12)+')';c.fillRect(t.x-1,t.y-1,2,2)});snk.trail=snk.trail.filter(function(t){return t.life>0});
snk.food.a+=.08;var fp=Math.sin(snk.food.a)*.3+.7,fx=OX+snk.food.x*G,fy=OY+snk.food.y*G;c.fillStyle='rgba(254,202,87,'+fp+')';c.fillRect(fx,fy,G-1,G-1);
var BC=['#55efc4','#00b894','#48dbfb','#81ecec','#a29bfe'];
snk.body.forEach(function(s,i){var sx=OX+s.x*G,sy=OY+s.y*G;if(i===0){c.fillStyle='#fff';c.fillRect(sx,sy,G-1,G-1);c.fillStyle='#55efc4';c.fillRect(sx+1,sy+1,G-3,G-3);c.fillStyle='#0a0c12';c.fillRect(sx+2+snk.dir.x*2,sy+2+snk.dir.y*2,2,2);c.fillRect(sx+G-5+snk.dir.x*2,sy+2+snk.dir.y*2,2,2)}else{c.fillStyle=BC[i%BC.length];c.fillRect(sx+1,sy+1,G-3,G-3)}});
c.textAlign='left';c.fillStyle='rgba(255,255,255,.2)';c.font='600 5px Arial';c.fillText('HI:'+snk.hi+'  LEN:'+snk.body.length,OX,OY+19*G+8);
if(!snk.alive){c.fillStyle='rgba(10,12,18,.88)';c.fillRect(0,0,W,H);c.font=F+'14px Arial';c.fillStyle='#ff6b6b';c.textAlign='center';c.fillText('GAME OVER',W/2,H/2-8);c.font=F+'10px Arial';c.fillStyle='#feca57';c.fillText('SCORE: '+snk.score,W/2,H/2+8);c.font='600 7px Arial';c.fillStyle='rgba(255,255,255,.3)';c.fillText('START TO RETRY',W/2,H/2+24)}
drawP();
}
function snkInput(btn){if(!snk.alive&&btn==='start'){snkInit();return}var d=snk.dir;if(btn==='u'&&d.y!==1)snk.nd={x:0,y:-1};if(btn==='d'&&d.y!==-1)snk.nd={x:0,y:1};if(btn==='l'&&d.x!==1)snk.nd={x:-1,y:0};if(btn==='r'&&d.x!==-1)snk.nd={x:1,y:0};if(btn==='a'||btn==='b'){snk.spd=1;setTimeout(function(){snk.spd=Math.max(2,6-Math.floor(snk.score/30))},180)}}

// ==================== BREAKOUT ====================
var brk={};
function brkInit(){brk.px=W/2-17;brk.bx=W/2;brk.by=178;brk.bdx=1.2;brk.bdy=-1.8;brk.score=0;brk.lives=3;brk.combo=0;brk.launched=false;brk.over=false;brk.bricks=[];var RC2=['#ff6b6b','#fd79a8','#a29bfe','#48dbfb','#55efc4','#feca57'];for(var r=0;r<6;r++)for(var co=0;co<10;co++)brk.bricks.push({x:co*23+3,y:r*8+18,w:22,h:7,hp:r<2?2:1,color:RC2[r]})}
function brkTick(){if(brk.over||!brk.launched)return;brk.bx+=brk.bdx;brk.by+=brk.bdy;if(brk.bx<=2||brk.bx>=W-2)brk.bdx=-brk.bdx;if(brk.by<=2)brk.bdy=Math.abs(brk.bdy);if(brk.by>=178-2&&brk.by<=183&&brk.bx>=brk.px&&brk.bx<=brk.px+34){brk.bdy=-Math.abs(brk.bdy);brk.bdx=((brk.bx-brk.px)/34-.5)*3.5;var sp=Math.sqrt(brk.bdx*brk.bdx+brk.bdy*brk.bdy);if(sp>3){brk.bdx*=3/sp;brk.bdy*=3/sp}brk.combo=0}if(brk.by>200){brk.lives--;brk.combo=0;if(brk.lives<=0)brk.over=true;else{brk.launched=false;brk.bx=brk.px+17;brk.by=170;brk.bdx=1.2;brk.bdy=-1.8}}brk.bricks.forEach(function(b){if(b.hp<=0)return;if(brk.bx+2>b.x&&brk.bx-2<b.x+b.w&&brk.by+2>b.y&&brk.by-2<b.y+b.h){b.hp--;if(b.hp<=0){brk.combo++;brk.score+=10*brk.combo;addP(b.x+b.w/2,b.y+b.h/2,4,[b.color])}if(brk.bx<b.x||brk.bx>b.x+b.w)brk.bdx=-brk.bdx;else brk.bdy=-brk.bdy}});if(brk.bricks.every(function(b){return b.hp<=0}))brk.over=true;if(!brk.launched){brk.bx=brk.px+17;brk.by=170}}
function brkDraw(){c.fillStyle='#0a0c12';c.fillRect(0,0,W,H);c.font=F+'7px Arial';c.textAlign='left';c.fillStyle='rgba(255,255,255,.5)';c.fillText('DOPAMINE BREAKER',4,10);c.textAlign='right';c.fillStyle='#feca57';c.fillText('SCORE:'+brk.score,236,10);
for(var i=0;i<brk.lives;i++){c.fillStyle='#ef4444';c.beginPath();c.arc(8+i*12,187,3,0,Math.PI*2);c.fill()}
brk.bricks.forEach(function(b){if(b.hp<=0)return;c.globalAlpha=b.hp>1?1:.75;c.fillStyle=b.color;c.fillRect(b.x,b.y,b.w,b.h);c.fillStyle='rgba(255,255,255,.18)';c.fillRect(b.x+1,b.y+1,b.w-2,1);c.globalAlpha=1});
c.fillStyle='#fff';c.fillRect(brk.px,178,34,5);c.fillStyle='rgba(255,255,255,.2)';c.fillRect(brk.px+2,179,30,1);
c.fillStyle='#fff';c.fillRect(brk.bx-2,brk.by-2,4,4);
if(brk.combo>1){c.font=F+'10px Arial';c.fillStyle='#feca57';c.textAlign='center';c.globalAlpha=.6;c.fillText('x'+brk.combo,120,100);c.globalAlpha=1}
if(brk.over){c.fillStyle='rgba(10,12,18,.92)';c.fillRect(0,0,W,H);c.textAlign='center';c.font=F+'14px Arial';var w=brk.bricks.every(function(b){return b.hp<=0});c.fillStyle=w?'#55efc4':'#ff6b6b';c.fillText(w?'YOU WIN':'GAME OVER',120,88);c.font=F+'10px Arial';c.fillStyle='#feca57';c.fillText(brk.score,120,106);c.font='600 7px Arial';c.fillStyle='rgba(255,255,255,.3)';c.fillText('START TO RETRY',120,122)}
else if(!brk.launched){c.font='600 7px Arial';c.fillStyle='rgba(255,255,255,.2)';c.textAlign='center';c.fillText('PRESS A TO LAUNCH',120,160)}
drawP();
}
var brkLH=false,brkRH=false;
function brkMv(){if(brkLH)brk.px=Math.max(0,brk.px-3);if(brkRH)brk.px=Math.min(W-34,brk.px+3);if(!brk.launched)brk.bx=brk.px+17}
function brkInput(btn){if(brk.over&&btn==='start'){brkInit();return}if(btn==='a'||btn==='start'){if(!brk.launched&&!brk.over){brk.launched=true;brk.bdx=(Math.random()-.5)*2;brk.bdy=-2.2}}}

// ==================== INVADERS ====================
var inv={};
var A1=[[0,0,1,0,0,1,0,0],[0,0,0,1,1,0,0,0],[0,0,1,1,1,1,0,0],[0,1,1,0,0,1,1,0],[1,1,1,1,1,1,1,1],[1,0,1,1,1,1,0,1],[1,0,1,0,0,1,0,1],[0,0,0,1,1,0,0,0]];
var A2=[[0,1,0,0,0,0,1,0],[0,0,1,0,0,1,0,0],[0,1,1,1,1,1,1,0],[1,1,0,1,1,0,1,1],[1,1,1,1,1,1,1,1],[0,1,1,1,1,1,1,0],[0,1,0,0,0,0,1,0],[0,0,1,0,0,1,0,0]];
var SHP=[[0,0,0,1,0,0,0],[0,0,1,1,1,0,0],[0,0,1,1,1,0,0],[1,1,1,1,1,1,1],[1,1,1,1,1,1,1]];
var AC=['#ff6b6b','#feca57','#ff9ff3','#48dbfb','#55efc4'];
function ds(spr,x,y,s,clr){c.fillStyle=clr;for(var r=0;r<spr.length;r++)for(var co=0;co<spr[r].length;co++)if(spr[r][co])c.fillRect(x+co*s,y+r*s,s,s)}
function invInit(){inv.pl={x:W/2-7,y:172};inv.bul=[];inv.ab=[];inv.sc=0;inv.wav=1;inv.liv=3;inv.md=1;inv.mt=0;inv.ms=20;inv.go=false;inv.stars=[];for(var i=0;i<35;i++)inv.stars.push({x:Math.random()*W,y:Math.random()*H,b:Math.random()*6,s:Math.random()*.8+.3});invSpawn()}
function invSpawn(){inv.ali=[];var rows=Math.min(3+Math.floor(inv.wav/2),5),cols=Math.min(6+inv.wav,9);for(var r=0;r<rows;r++)for(var co=0;co<cols;co++)inv.ali.push({x:12+co*22,y:18+r*15,type:r<rows/2?1:2,alive:true,color:AC[r%AC.length]});inv.ms=Math.max(5,20-inv.wav*2)}
function invShoot(){if(inv.bul.length<3&&!inv.go)inv.bul.push({x:inv.pl.x+6,y:inv.pl.y-2})}
var invLH=false,invRH=false;
function invTick(){if(inv.go)return;if(invLH)inv.pl.x=Math.max(2,inv.pl.x-2.5);if(invRH)inv.pl.x=Math.min(W-16,inv.pl.x+2.5);for(var i=0;i<inv.bul.length;i++)inv.bul[i].y-=4;inv.bul=inv.bul.filter(function(b){return b.y>-5});for(var i=0;i<inv.ab.length;i++)inv.ab[i].y+=2;inv.ab=inv.ab.filter(function(b){return b.y<200});inv.mt++;if(inv.mt>=inv.ms){inv.mt=0;var edge=false;inv.ali.forEach(function(a){if(!a.alive)return;a.x+=inv.md*3;if(a.x<2||a.x>W-18)edge=true});if(edge){inv.md=-inv.md;inv.ali.forEach(function(a){if(a.alive)a.y+=6})}var alive=inv.ali.filter(function(a){return a.alive});if(alive.length&&Math.random()<.25+inv.wav*.04){var s=alive[Math.floor(Math.random()*alive.length)];inv.ab.push({x:s.x+4,y:s.y+8})}}inv.bul.forEach(function(b){inv.ali.forEach(function(a){if(!a.alive)return;if(b.x>a.x&&b.x<a.x+16&&b.y>a.y&&b.y<a.y+12){a.alive=false;b.y=-99;inv.sc+=a.type===1?20:10;addP(a.x+8,a.y+6,6,[a.color])}})});inv.ab.forEach(function(b){if(b.x>inv.pl.x&&b.x<inv.pl.x+14&&b.y>inv.pl.y&&b.y<inv.pl.y+10){inv.liv--;b.y=999;addP(inv.pl.x+7,inv.pl.y+5,8,['#ff6b6b']);if(inv.liv<=0)inv.go=true}});if(inv.ali.some(function(a){return a.alive&&a.y>160}))inv.go=true;if(inv.ali.every(function(a){return!a.alive})){inv.wav++;invSpawn()}}
function invDraw(){c.fillStyle='#060810';c.fillRect(0,0,W,H);inv.stars.forEach(function(s){s.b+=.015;c.fillStyle='rgba(255,255,255,'+(Math.sin(s.b)*.3+.15)+')';c.fillRect(s.x,s.y,s.s,s.s)});
c.font=F+'7px Arial';c.textAlign='left';c.fillStyle='rgba(255,255,255,.5)';c.fillText('FOCUS FIRE',4,10);c.textAlign='right';c.fillStyle='#feca57';c.fillText('SCORE:'+inv.sc+' WAVE:'+inv.wav,236,10);
for(var i=0;i<inv.liv;i++)ds(SHP,4+i*14,182,1.2,'rgba(255,107,107,.6)');
inv.ali.forEach(function(a){if(!a.alive)return;ds(a.type===1?A1:A2,a.x,a.y,2,a.color)});
ds(SHP,inv.pl.x,inv.pl.y,2,'#48dbfb');if(Math.random()>.4){c.fillStyle='#feca57';c.fillRect(inv.pl.x+5,inv.pl.y+10,4,Math.random()*3+1)}
inv.bul.forEach(function(b){c.fillStyle='#feca57';c.fillRect(b.x,b.y,2,6)});c.fillStyle='#ff6b6b';inv.ab.forEach(function(b){c.fillRect(b.x,b.y,2,4)});
if(inv.go){c.fillStyle='rgba(6,8,16,.92)';c.fillRect(0,0,W,H);c.textAlign='center';c.font=F+'14px Arial';c.fillStyle='#ff6b6b';c.fillText('GAME OVER',120,85);c.font=F+'10px Arial';c.fillStyle='#feca57';c.fillText('SCORE: '+inv.sc,120,103);c.font='600 7px Arial';c.fillStyle='rgba(255,255,255,.3)';c.fillText('START TO RETRY',120,119)}
drawP();
}
function invInput(btn){if(inv.go&&btn==='start'){invInit();return}if(btn==='a'||btn==='b'||btn==='u')invShoot()}

// ==================== MAIN LOOP ====================
function mainLoop(){
  if(STATE==='boot')drawBoot();
  else if(STATE==='menu')drawMenu();
  else if(STATE==='tetris'){tetTick();tetDraw()}
  else if(STATE==='snake'){snkTick();snkDraw()}
  else if(STATE==='breakout'){brkMv();brkTick();brkDraw()}
  else if(STATE==='invaders'){invTick();invDraw()}
  requestAnimationFrame(mainLoop);
}
mainLoop();

// ==================== INPUT ====================
function onBtn(btn){
  if(STATE==='boot'){if(btn==='start'||btn==='a'){STATE='menu';addP(120,130,20,RC)};return}
  if(STATE==='menu'){if(btn==='u')menuSel=Math.max(0,menuSel-1);if(btn==='d')menuSel=Math.min(3,menuSel+1);if(btn==='a'||btn==='start'){var g=['tetris','snake','breakout','invaders'][menuSel];STATE=g;if(g==='tetris')tetInit();if(g==='snake')snkInit();if(g==='breakout')brkInit();if(g==='invaders')invInit();addP(120,96,15,[games[menuSel].color,'#fff'])}return}
  if(btn==='home'){STATE='menu';return}
  if(STATE==='tetris')tetInput(btn);
  if(STATE==='snake')snkInput(btn);
  if(STATE==='breakout')brkInput(btn);
  if(STATE==='invaders')invInput(btn);
}

var bind=function(id,fn){document.getElementById(id).addEventListener('pointerdown',function(e){e.preventDefault();fn()})};
var ubind=function(id,fn){var el=document.getElementById(id);['pointerup','pointerleave','pointercancel'].forEach(function(ev){el.addEventListener(ev,fn)})};
bind('bA',function(){onBtn('a')});bind('bB',function(){onBtn('b')});
bind('mSt',function(){onBtn('start')});bind('mSel',function(){onBtn('select')});
bind('homeBtn',function(){onBtn('home')});

// D-pad with hold
var holdI=null;function holdStart(fn){fn();holdI=setInterval(fn,70)}function holdStop(){clearInterval(holdI)}
document.getElementById('du').addEventListener('pointerdown',function(e){e.preventDefault();
  if(STATE==='tetris'){onBtn('u')}
  else if(STATE==='breakout'){}
  else if(STATE==='invaders'){onBtn('u')}
  else{onBtn('u')}
});
document.getElementById('dd').addEventListener('pointerdown',function(e){e.preventDefault();
  if(STATE==='tetris'){holdStart(function(){if(!tetHit(tet.cX,tet.cY+1,tet.cur)){tet.cY++;tet.score++}})}
  else{onBtn('d')}
});ubind('dd',holdStop);
document.getElementById('dl').addEventListener('pointerdown',function(e){e.preventDefault();
  if(STATE==='tetris'){holdStart(function(){tetMove(-1)})}
  else if(STATE==='breakout'){brkLH=true}
  else if(STATE==='invaders'){invLH=true}
  else{onBtn('l')}
});ubind('dl',function(){holdStop();brkLH=false;invLH=false});
document.getElementById('dr').addEventListener('pointerdown',function(e){e.preventDefault();
  if(STATE==='tetris'){holdStart(function(){tetMove(1)})}
  else if(STATE==='breakout'){brkRH=true}
  else if(STATE==='invaders'){invRH=true}
  else{onBtn('r')}
});ubind('dr',function(){holdStop();brkRH=false;invRH=false});

// Keyboard
document.addEventListener('keydown',function(e){
  if(e.key==='ArrowUp')onBtn('u');if(e.key==='ArrowDown'){onBtn('d');if(STATE==='tetris'&&!tetHit(tet.cX,tet.cY+1,tet.cur)){tet.cY++;tet.score++}}
  if(e.key==='ArrowLeft'){onBtn('l');if(STATE==='breakout')brkLH=true;if(STATE==='invaders')invLH=true}
  if(e.key==='ArrowRight'){onBtn('r');if(STATE==='breakout')brkRH=true;if(STATE==='invaders')invRH=true}
  if(e.key===' ')onBtn('a');if(e.key==='Enter')onBtn('start');if(e.key==='Escape'||e.key==='Backspace')onBtn('home');
});
document.addEventListener('keyup',function(e){
  if(e.key==='ArrowLeft'){brkLH=false;invLH=false}if(e.key==='ArrowRight'){brkRH=false;invRH=false}
});
</script>
</body>
</html>

THEN PASTE INTO YOUR BROWSER ADDRESS BAR & GO
X