<!DOCTYPE html>
<html lang="en">
<head>
    <title>2048 Game</title>
    <link rel="icon" href="__PLACEHOLDER_ASSETS_BASE_DIR__/003.svg">
    <style>
        body {
            background: #faf8ef;
            color: #776e65;
            font-family: sans-serif;
            font-size: 18px;
            margin: 0;
            padding: 20px 0;
        }
        .container {
            width: 500px;
            margin: 0 auto;
        }
        .heading {
            text-align: center;
            margin-bottom: 20px;
        }
        .title {
            background: #bbada0;
            padding: 10px 20px;
            border-radius: 6px;
            font-weight: bold;
            font-size: 24px;
            display: inline-block;
        }
        .game-board {
            background: #bbada0;
            padding: 20px;
            border-radius: 6px;
            width: 460px;
            height: 460px;
            box-sizing: content-box;
            margin: 0 auto;
        }
        .grid-container {
            position: relative;
            width: 460px;
            height: 460px;
        }
        .grid-cell {
            position: absolute;
            width: 100px;
            height: 100px;
            border-radius: 3px;
            background: rgba(238, 228, 218, 0.35);
        }
        .tile {
            position: absolute;
            width: 100px;
            height: 100px;
            border-radius: 3px;
            line-height: 100px;
            text-align: center;
            font-weight: bold;
            font-size: 50px;
            transition: left 0.1s linear, top 0.1s linear;
        }
        .tile-2 { background: #eee4da; color: #776e65; }
        .tile-4 { background: #ede0c8; color: #776e65; }
        .tile-8 { background: #f2b179; color: #f9f6f2; }
        .tile-16 { background: #f59563; color: #f9f6f2; }
        .tile-32 { background: #f67c5f; color: #f9f6f2; }
        .tile-64 { background: #f65e3b; color: #f9f6f2; }
        .tile-128 { background: #edcf72; color: #f9f6f2; box-shadow: 0 0 30px 10px rgba(243, 215, 116, 0.2381), inset 0 0 0 1px rgba(255, 255, 255, 0.14286); }
        .tile-256 { background: #edcc61; color: #f9f6f2; box-shadow: 0 0 30px 10px rgba(243, 215, 116, 0.31746), inset 0 0 0 1px rgba(255, 255, 255, 0.19048); }
        .tile-512 { background: #edc850; color: #f9f6f2; box-shadow: 0 0 30px 10px rgba(243, 215, 116, 0.39683), inset 0 0 0 1px rgba(255, 255, 255, 0.2381); }
        .tile-1024 { background: #edc53f; color: #f9f6f2; box-shadow: 0 0 30px 10px rgba(243, 215, 116, 0.47619), inset 0 0 0 1px rgba(255, 255, 255, 0.28571); font-size: 45px; }
        .tile-2048 { background: #edc22e; color: #f9f6f2; box-shadow: 0 0 30px 10px rgba(243, 215, 116, 0.55556), inset 0 0 0 1px rgba(255, 255, 255, 0.33333); font-size: 45px; }
        .below-board {
            display: flex;
            justify-content: space-between;
            margin: 20px 0;
        }
        .score-container {
            background: #bbada0;
            border-radius: 3px;
            text-align: center;
            width: 140px;
            height: 60px;
        }
        .score-title {
            font-size: 13px;
            line-height: 13px;
            color: #eee4da;
            margin-top: 8px;
        }
        .score-value {
            font-size: 30px;
            color: #ffffff;
            line-height: 35px;
        }
        .how-to-play {
            background: #bbada0;
            border-radius: 3px;
            padding: 10px;
            display: flex;
            align-items: center;
        }
        .game-explanation {
            text-align: center;
            margin: 20px 0;
            font-size: 15px;
        }
        .other-games {
            text-align: center;
            margin-top: 40px;
        }
        .other-games h2 {
            color: #119f0b;
            font-size: 20px;
            margin-bottom: 10px;
        }
        .other-games div {
            display: flex;
            justify-content: center;
            gap: 20px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="heading">
            <div class="title">2048 Game</div>
        </div>
        <div class="game-board">
            <div class="grid-container"></div>
        </div>
        <div class="below-board">
            <div class="score-container">
                <div class="score-title">SCORE</div>
                <div class="score-value" id="score">0</div>
            </div>
            <div class="how-to-play">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/007.png" width="120" height="40" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/008.png" width="40" height="40" alt="">
            </div>
        </div>
        <p class="game-explanation">
            Join the numbers and get to the <strong>2048 tile!</strong> Use your arrow keys to move the tiles. When two tiles with the same number touch, they <strong>merge into one!</strong>
        </p>
        <div class="other-games">
            <h2>Play Other Games</h2>
            <div>
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/009.png" width="80" height="60" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/010.png" width="60" height="60" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/011.png" width="100" height="60" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/012.png" width="100" height="60" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/013.png" width="60" height="60" alt="">
                <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/014.png" width="40" height="40" alt="">
            </div>
        </div>
    </div>
    <script>
        const cellSize = 100;
        const cellGap = 20;
        let board = Array.from({length: 4}, () => Array(4).fill(0));
        let score = 0;
        const grid = document.querySelector('.grid-container');
        const scoreEl = document.getElementById('score');

        // Create grid cells
        for (let i = 0; i < 4; i++) {
            for (let j = 0; j < 4; j++) {
                const cell = document.createElement('div');
                cell.className = 'grid-cell';
                cell.style.left = `${j * (cellSize + cellGap)}px`;
                cell.style.top = `${i * (cellSize + cellGap)}px`;
                grid.appendChild(cell);
            }
        }

        function addRandom() {
            const empty = [];
            board.forEach((row, i) => {
                row.forEach((v, j) => {
                    if (v === 0) empty.push({i, j});
                });
            });
            if (empty.length > 0) {
                const {i, j} = empty[Math.floor(Math.random() * empty.length)];
                board[i][j] = Math.random() > 0.1 ? 2 : 4;
            }
        }

        function render() {
            document.querySelectorAll('.tile').forEach(t => t.remove());
            board.forEach((row, i) => {
                row.forEach((v, j) => {
                    if (v !== 0) {
                        const tile = document.createElement('div');
                        tile.className = `tile tile-${v}`;
                        tile.innerText = v;
                        tile.style.left = `${j * (cellSize + cellGap)}px`;
                        tile.style.top = `${i * (cellSize + cellGap)}px`;
                        grid.appendChild(tile);
                    }
                });
            });
        }

        function updateScore() {
            scoreEl.innerText = score;
        }

        function slideLeft() {
            let moved = false;
            for (let i = 0; i < 4; i++) {
                let row = board[i].filter(v => v !== 0);
                for (let j = 0; j < row.length - 1; j++) {
                    if (row[j] === row[j + 1]) {
                        row[j] *= 2;
                        score += row[j];
                        row.splice(j + 1, 1);
                        j--;
                        moved = true;
                    }
                }
                while (row.length < 4) row.push(0);
                if (!board[i].every((v, k) => v === row[k])) moved = true;
                board[i] = row;
            }
            return moved;
        }

        function reverse() {
            board.forEach(row => row.reverse());
        }

        function transpose() {
            const newBoard = Array.from({length: 4}, () => Array(4).fill(0));
            for (let i = 0; i < 4; i++) {
                for (let j = 0; j < 4; j++) {
                    newBoard[j][i] = board[i][j];
                }
            }
            board = newBoard;
        }

        function move(direction) {
            let moved = false;
            if (direction === 'left') {
                moved = slideLeft();
            } else if (direction === 'right') {
                reverse();
                moved = slideLeft();
                reverse();
            } else if (direction === 'up') {
                transpose();
                moved = slideLeft();
                transpose();
            } else if (direction === 'down') {
                transpose();
                reverse();
                moved = slideLeft();
                reverse();
                transpose();
            }
            if (moved) {
                addRandom();
            }
            render();
            updateScore();
        }

        document.addEventListener('keydown', e => {
            let direction;
            switch (e.key) {
                case 'ArrowLeft': direction = 'left'; break;
                case 'ArrowRight': direction = 'right'; break;
                case 'ArrowUp': direction = 'up'; break;
                case 'ArrowDown': direction = 'down'; break;
            }
            if (direction) {
                move(direction);
            }
        });

        // Initialize
        addRandom();
        addRandom();
        render();
        updateScore();
    </script>
</body>
</html>