<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Pomodoro Timer</title>
    <style>
        :root {
            --primary-color: #d94e4e;
            --secondary-color: #4a4a4a;
            --light-color: #f5f5f5;
            --dark-color: #333333;
        }
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            font-family: 'Arial', sans-serif;
        }
        body {
            background-color: var(--secondary-color);
            color: var(--light-color);
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
        }
        .container {
            width: 600px;
            max-width: 95%;
            text-align: center;
            background-color: var(--primary-color);
            padding: 20px;
            border-radius: 10px;
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
        }
        .timer {
            font-size: 5rem;
            font-weight: bold;
            margin: 20px 0;
        }
        .controls {
            margin: 20px 0;
        }
        .btn {
            padding: 10px 20px;
            border: none;
            border-radius: 5px;
            font-size: 1rem;
            cursor: pointer;
            margin: 0 10px;
            transition: all 0.3s ease;
        }
        .btn-start {
            background-color: white;
            color: var(--primary-color);
        }
        .btn-pause {
            background-color: var(--primary-color);
            color: white;
        }
        .task-list {
            margin: 20px 0;
        }
        .task-item {
            padding: 10px;
            margin: 5px 0;
            background-color: rgba(255, 255, 255, 0.1);
            border-radius: 5px;
        }
        .nav-bar {
            display: flex;
            justify-content: space-between;
            margin-bottom: 10px;
        }
        .icon {
            width: 30px;
            height: 30px;
            margin: 0 5px;
            cursor: pointer;
        }
        .task-input {
            width: 100%;
            padding: 10px;
            margin: 10px 0;
            border: none;
            border-radius: 5px;
            background-color: rgba(255, 255, 255, 0.1);
            color: var(--light-color);
        }
        .modal {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0, 0, 0, 0.5);
            justify-content: center;
            align-items: center;
        }
        .modal-content {
            background-color: var(--primary-color);
            padding: 20px;
            border-radius: 10px;
            width: 80%;
            max-width: 500px;
        }
        .confetti {
            position: absolute;
            width: 10px;
            height: 10px;
            background-color: #f00;
            border-radius: 50%;
            animation: fall 3s infinite;
        }
        @keyframes fall {
            0% {
                transform: translateY(-100vh) rotate(0deg);
                opacity: 1;
            }
            100% {
                transform: translateY(100vh) rotate(360deg);
                opacity: 0;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="nav-bar">
            <div class="icon">🎯</div>
            <div class="icon">📊</div>
            <div class="icon">⚙️</div>
            <div class="icon">👤</div>
        </div>
        <h1>Pomodoro Timer</h1>
        <div class="timer" id="timer">25:00</div>
        <div class="controls">
            <button class="btn btn-start" id="startBtn">START</button>
            <button class="btn btn-pause" id="pauseBtn" disabled>PAUSE</button>
        </div>
        <div class="task-list" id="taskList">
            <div class="task-item" data-id="1">Task 1: Complete Pomodoro Tutorial</div>
            <div class="task-item" data-id="2">Task 2: Work on Project</div>
            <div class="task-item" data-id="3">Task 3: Study for Exam</div>
        </div>
        <div class="task-input-container">
            <input type="text" class="task-input" id="taskInput" placeholder="Add new task...">
        </div>
    </div>

    <div class="modal" id="taskModal">
        <div class="modal-content">
            <h2>Add New Task</h2>
            <input type="text" id="newTaskInput" placeholder="Task description">
            <button class="btn" id="saveTaskBtn">Save</button>
            <button class="btn" id="cancelTaskBtn">Cancel</button>
        </div>
    </div>

    <script>
        const timer = {
            timeLeft: 25 * 60,
            interval: null,
            isRunning: false,
            display: document.getElementById('timer'),
            start() {
                if (!this.isRunning) {
                    this.interval = setInterval(() => {
                        this.timeLeft--;
                        this.display.textContent = this.formatTime(this.timeLeft);
                        if (this.timeLeft <= 0) {
                            clearInterval(this.interval);
                            this.finishWorkSession();
                        }
                    }, 1000);
                    this.isRunning = true;
                    document.getElementById('startBtn').disabled = true;
                    document.getElementById('pauseBtn').disabled = false;
                }
            },
            pause() {
                clearInterval(this.interval);
                this.isRunning = false;
                document.getElementById('startBtn').disabled = false;
                document.getElementById('pauseBtn').disabled = true;
            },
            reset() {
                clearInterval(this.interval);
                this.timeLeft = 25 * 60;
                this.display.textContent = this.formatTime(this.timeLeft);
                this.isRunning = false;
                document.getElementById('startBtn').disabled = false;
                document.getElementById('pauseBtn').disabled = true;
            },
            formatTime(timeInSeconds) {
                const minutes = Math.floor(timeInSeconds / 60);
                const seconds = timeInSeconds % 60;
                return `${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
            },
            finishWorkSession() {
                this.pause();
                alert('Work session finished! Take a short break.');
                // Simulate short break
                setTimeout(() => {
                    this.timeLeft = 5 * 60;
                    this.display.textContent = this.formatTime(this.timeLeft);
                    this.start();
                }, 5000);
            }
        };

        const taskList = [
            { id: 1, description: "Complete Pomodoro Tutorial", completed: false },
            { id: 2, description: "Work on Project", completed: false },
            { id: 3, description: "Study for Exam", completed: false }
        ];

        document.getElementById('startBtn').addEventListener('click', () => {
            timer.start();
        });

        document.getElementById('pauseBtn').addEventListener('click', () => {
            timer.pause();
        });

        document.getElementById('taskInput').addEventListener('keypress', (e) => {
            if (e.key === 'Enter') {
                const newTask = e.target.value;
                if (newTask.trim()) {
                    taskList.push({ id: taskList.length + 1, description: newTask, completed: false });
                    this.renderTasks();
                    e.target.value = '';
                }
            }
        });

        document.getElementById('saveTaskBtn').addEventListener('click', () => {
            const newTask = document.getElementById('newTaskInput').value;
            if (newTask.trim()) {
                taskList.push({ id: taskList.length + 1, description: newTask, completed: false });
                this.renderTasks();
                document.getElementById('taskModal').style.display = 'none';
                document.getElementById('newTaskInput').value = '';
            }
        });

        document.getElementById('cancelTaskBtn').addEventListener('click', () => {
            document.getElementById('taskModal').style.display = 'none';
        });

        function renderTasks() {
            const taskContainer = document.getElementById('taskList');
            taskContainer.innerHTML = '';
            taskList.forEach(task => {
                const taskElement = document.createElement('div');
                taskElement.className = `task-item ${task.completed ? 'completed' : ''}`;
                taskElement.textContent = task.description;
                taskElement.addEventListener('click', () => toggleTaskCompletion(task.id));
                taskContainer.appendChild(taskElement);
            });
        }

        function toggleTaskCompletion(taskId) {
            const task = taskList.find(t => t.id === taskId);
            if (task) {
                task.completed = !task.completed;
                renderTasks();
            }
        }

        // Initialize
        timer.display.textContent = timer.formatTime(25 * 60);
        renderTasks();
        document.getElementById('startBtn').addEventListener('click', () => timer.start());
        document.getElementById('pauseBtn').addEventListener('click', () => timer.pause());
    </script>
</body>
</html>