<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>How AI Agents Plan, Remember, and Collaborate</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            overflow: hidden;
            color: #2d3748;
        }

        .presentation-container {
            width: 100vw;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
        }

        .slide {
            width: 90%;
            max-width: 1200px;
            height: 85vh;
            background: white;
            border-radius: 20px;
            box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
            display: none;
            padding: 60px;
            position: relative;
            animation: slideIn 0.5s ease-out;
        }

        .slide.active {
            display: flex;
            flex-direction: column;
        }

        @keyframes slideIn {
            from {
                opacity: 0;
                transform: translateX(30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

        .slide-navigation {
            position: absolute;
            bottom: 30px;
            left: 50%;
            transform: translateX(-50%);
            display: flex;
            gap: 20px;
            z-index: 100;
        }

        .nav-btn {
            padding: 12px 24px;
            background: linear-gradient(135deg, #667eea, #764ba2);
            color: white;
            border: none;
            border-radius: 10px;
            cursor: pointer;
            font-size: 16px;
            font-weight: 600;
            transition: all 0.3s ease;
            box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3);
        }

        .nav-btn:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 20px rgba(102, 126, 234, 0.4);
        }

        .nav-btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        .slide-counter {
            position: absolute;
            top: 30px;
            right: 30px;
            background: rgba(102, 126, 234, 0.1);
            padding: 8px 16px;
            border-radius: 20px;
            font-weight: 600;
            color: #667eea;
        }

        /* Title Slide */
        .title-slide {
            justify-content: center;
            align-items: center;
            text-align: center;
            background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
        }

        .title-slide h1 {
            font-size: 4em;
            font-weight: 800;
            background: linear-gradient(135deg, #667eea, #764ba2);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin-bottom: 20px;
            line-height: 1.2;
            animation: fadeInUp 1s ease-out;
        }

        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* Content Slides */
        .slide h2 {
            font-size: 3em;
            color: #2d3748;
            margin-bottom: 40px;
            font-weight: 700;
            position: relative;
            padding-bottom: 15px;
        }

        .slide h2::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100px;
            height: 4px;
            background: linear-gradient(90deg, #667eea, #764ba2);
            border-radius: 2px;
        }

        .slide ul {
            list-style: none;
            padding: 0;
        }

        .slide li {
            margin: 20px 0;
            padding-left: 40px;
            position: relative;
            font-size: 1.4em;
            line-height: 1.6;
            animation: fadeIn 0.6s ease-out backwards;
        }

        .slide li:nth-child(1) { animation-delay: 0.1s; }
        .slide li:nth-child(2) { animation-delay: 0.2s; }
        .slide li:nth-child(3) { animation-delay: 0.3s; }
        .slide li:nth-child(4) { animation-delay: 0.4s; }

        @keyframes fadeIn {
            from {
                opacity: 0;
                transform: translateX(-20px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

        .slide li::before {
            content: '▸';
            position: absolute;
            left: 0;
            color: #667eea;
            font-size: 1.2em;
            font-weight: bold;
        }

        .slide .sub-item {
            margin-left: 40px;
            margin-top: 10px;
            font-size: 0.9em;
            color: #4a5568;
            padding-left: 30px;
        }

        .slide .sub-item::before {
            content: '–';
            position: absolute;
            left: 40px;
            color: #a0aec0;
        }

        /* Special styling for demo slides */
        .demo-slide {
            background: linear-gradient(135deg, #ffecd2 0%, #fcb69f 100%);
        }

        .demo-slide h2 {
            color: #744210;
        }

        /* Failure mode slide */
        .failure-slide {
            background: linear-gradient(135deg, #fbc2eb 0%, #a6c1ee 100%);
        }

        /* Responsible use slide */
        .responsible-slide {
            background: linear-gradient(135deg, #a8edea 0%, #fed6e3 100%);
        }

        /* Try it yourself slide */
        .try-slide {
            background: linear-gradient(135deg, #d299c2 0%, #fef9d7 100%);
            justify-content: center;
            align-items: center;
        }

        .try-slide h2 {
            text-align: center;
            margin-bottom: 60px;
        }

        .try-slide ul {
            text-align: center;
        }

        .try-slide li {
            padding-left: 0;
        }

        .try-slide li::before {
            display: none;
        }

        /* Animation for slide transitions */
        @keyframes slideOutLeft {
            to {
                opacity: 0;
                transform: translateX(-30px);
            }
        }

        @keyframes slideInRight {
            from {
                opacity: 0;
                transform: translateX(30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }
    </style>
</head>
<body>
    <div class="presentation-container">
        <div class="slide-counter">
            <span id="current-slide">1</span> / <span id="total-slides">9</span>
        </div>

        <!-- Slide 1: Title -->
        <div class="slide title-slide active">
            <h1>How AI Agents Plan, Remember, and Collaborate</h1>
        </div>

        <!-- Slide 2: Learning Goals -->
        <div class="slide">
            <h2>Learning goals</h2>
            <ul>
                <li>Define an AI agent in plain language</li>
                <li>See the agent loop
                    <div class="sub-item">Plan → Act → Observe → Update</div>
                </li>
                <li>Spot planning + feedback
                    <div class="sub-item">with a number-guessing demo</div>
                </li>
                <li>See multi-agent collaboration
                    <div class="sub-item">with a comedy duo demo</div>
                </li>
            </ul>
        </div>

        <!-- Slide 3: What is an AI agent? -->
        <div class="slide">
            <h2>What is an AI agent?</h2>
            <ul>
                <li>An entity that pursues a goal and decides what to do next</li>
                <li>Core loop
                    <div class="sub-item">Plan, Act, Observe, Update (with memory)</div>
                </li>
                <li>Common ingredients
                    <div class="sub-item">Short-term memory (state)</div>
                    <div class="sub-item">Optional tools (e.g., search, code, APIs)</div>
                </li>
                <li>More than a chatbot</li>
            </ul>
        </div>

        <!-- Slide 4: Demo 1 -->
        <div class="slide demo-slide">
            <h2>Demo 1 — Number guessing: planning + feedback</h2>
            <ul>
                <li>Setup
                    <div class="sub-item">Agent A holds a secret number (1–100)</div>
                    <div class="sub-item">Agent B guesses; feedback is 'too high/low'</div>
                </li>
                <li>Agentic view
                    <div class="sub-item">Plan: pick midpoint</div>
                    <div class="sub-item">Memory: track [low, high]</div>
                    <div class="sub-item">Observe: feedback</div>
                    <div class="sub-item">Update: shrink interval</div>
                </li>
            </ul>
        </div>

        <!-- Slide 5: Failure mode -->
        <div class="slide failure-slide">
            <h2>Failure mode: noisy feedback</h2>
            <ul>
                <li>Flip a hint (say 'too high' once when it's not)</li>
                <li>Effect
                    <div class="sub-item">Inconsistent interval; plan becomes brittle</div>
                    <div class="sub-item">Agent may recover slowly or fail</div>
                </li>
                <li>Lesson
                    <div class="sub-item">Agents inherit the reliability of their signals</div>
                </li>
            </ul>
        </div>

        <!-- Slide 6: Demo 2 -->
        <div class="slide demo-slide">
            <h2>Demo 2 — Comedy duo: coordination + roles</h2>
            <ul>
                <li>Setup
                    <div class="sub-item">Two agents alternate with a theme (e.g., coffee)</div>
                    <div class="sub-item">Short-term memory: build on prior line</div>
                </li>
                <li>Simple strategy
                    <div class="sub-item">Turn-taking + style guardrails = coherent output</div>
                </li>
                <li>Agentic view
                    <div class="sub-item">Roles steer behavior</div>
                    <div class="sub-item">State = last few lines</div>
                    <div class="sub-item">Coordination emerges without hard-coding jokes</div>
                </li>
            </ul>
        </div>

        <!-- Slide 7: From toy to real workflows -->
        <div class="slide">
            <h2>From toy to real workflows</h2>
            <ul>
                <li>Same loop scales to
                    <div class="sub-item">research helpers</div>
                    <div class="sub-item">data pipelines</div>
                    <div class="sub-item">classroom tutors, graders, lab partners</div>
                </li>
                <li>Design levers
                    <div class="sub-item">Explicit roles and goals</div>
                    <div class="sub-item">Tight feedback signals</div>
                    <div class="sub-item">State logging and resets</div>
                </li>
            </ul>
        </div>

        <!-- Slide 8: Responsible use & guardrails -->
        <div class="slide responsible-slide">
            <h2>Responsible use & guardrails</h2>
            <ul>
                <li>Validate feedback channels; detect contradictions</li>
                <li>Constrain roles, tone, topics (age-appropriate themes)</li>
                <li>Log interactions; reset state between runs</li>
            </ul>
        </div>

        <!-- Slide 9: Try it yourself -->
        <div class="slide try-slide">
            <h2>Try it yourself</h2>
            <ul>
                <li>Web app
                    <div class="sub-item">Number guessing + comedy duo</div>
                </li>
            </ul>
        </div>

        <!-- Navigation -->
        <div class="slide-navigation">
            <button class="nav-btn" id="prev-btn" onclick="changeSlide(-1)">← Previous</button>
            <button class="nav-btn" id="next-btn" onclick="changeSlide(1)">Next →</button>
        </div>

<!--         <div class="keyboard-hint">
            Use <kbd>←</kbd> <kbd>→</kbd> arrow keys or buttons to navigate
        </div> -->
    </div>

    <script>
        let currentSlide = 1;
        const totalSlides = 9;

        function showSlide(n) {
            const slides = document.getElementsByClassName('slide');
            const prevBtn = document.getElementById('prev-btn');
            const nextBtn = document.getElementById('next-btn');
            
            if (n > totalSlides) currentSlide = totalSlides;
            if (n < 1) currentSlide = 1;
            
            for (let i = 0; i < slides.length; i++) {
                slides[i].classList.remove('active');
            }
            
            slides[currentSlide - 1].classList.add('active');
            
            document.getElementById('current-slide').textContent = currentSlide;
            
            prevBtn.disabled = currentSlide === 1;
            nextBtn.disabled = currentSlide === totalSlides;
        }

        function changeSlide(n) {
            currentSlide += n;
            showSlide(currentSlide);
        }

        // Keyboard navigation
        document.addEventListener('keydown', function(event) {
            if (event.key === 'ArrowLeft') {
                changeSlide(-1);
            } else if (event.key === 'ArrowRight') {
                changeSlide(1);
            }
        });

        // Initialize
        showSlide(currentSlide);
    </script>
</body>
</html>