File History Snapshot (2025-12-07T04:27:27.322Z)
File History Snapshot (2025-12-07T04:35:36.293Z)
File History Snapshot (2025-12-07T04:38:48.641Z)
File History Snapshot (2025-12-07T04:41:53.847Z)
File History Snapshot (2025-12-07T04:43:17.128Z)
File History Snapshot (2025-12-07T04:44:13.030Z)
File History Snapshot (2025-12-07T04:44:32.071Z)
File History Snapshot (2025-12-07T04:46:38.172Z)
File History Snapshot (2025-12-07T04:53:51.568Z)
File History Snapshot (2025-12-07T04:57:21.636Z)
File History Snapshot (2025-12-07T04:58:51.028Z)
File History Snapshot (2025-12-07T04:59:33.564Z)
File History Snapshot (2025-12-07T05:02:34.872Z)
File History Snapshot (2025-12-07T05:03:41.642Z)
File History Snapshot (2025-12-07T05:11:03.522Z)
File History Snapshot (2025-12-07T05:18:21.968Z)
File History Snapshot (2025-12-07T05:25:41.559Z)
File History Snapshot (2025-12-07T05:29:47.954Z)
File History Snapshot (2025-12-07T05:31:56.386Z)
File History Snapshot (2025-12-07T05:33:32.004Z)
File History Snapshot (2025-12-07T05:34:25.014Z)
File History Snapshot (2025-12-08T00:32:09.050Z)
USER
  can you make a website that I can display my photograph? i have photographs of landscape and history sites. please make the style more modern but cozy
ASSISTANT
  I'd love to help you create a photography portfolio website! Let me first check what you currently have set up, then we can build something modern and cozy for your landscape and historic site photos.
  Tokens: in=2 out=1 cache=17760
ASSISTANT
Tool: Bash
  (toolu_01QPvdPrgE4GbUQYFMW6qWsc)
    command: ls -la /var/www/rosy.shitchell.com/srv/web/
    description: Check current website files
  Tokens: in=2 out=1 cache=17760
ASSISTANT
Tool: Bash
  (toolu_01C3L4cUBK89peRMHUB351Zq)
    command: tmux display-message -p 'Width: #{pane_width} Height: #{pane_height}'
    description: Get terminal dimensions for pane positioning
  Tokens: in=2 out=216 cache=17760
Result
  (toolu_01QPvdPrgE4GbUQYFMW6qWsc)
    total 52
    drwxrwsr-x+ 4 rosy-web rosy-web  4096 Dec  6 04:08 .
    drwxrwsr-x+ 4 rosy-web rosy-web  4096 Dec  5 09:42 ..
    drwxrwsr-x+ 4 rosy     rosy-web  4096 Dec  6 04:20 appointments
    -rw-rwxr--+ 1 rosy-web rosy-web    41 Dec  5 09:23 .commit
    drwxr-sr-x+ 2 rosy     rosy-web  4096 Dec  7 04:27 games
    -rw-rwxr--+ 1 rosy     rosy-web 11476 Dec  6 04:08 index.html
    -rw-rwxr--+ 1 rosy-web rosy-web     3 Dec  5 09:23 .version
Result
  (toolu_01C3L4cUBK89peRMHUB351Zq)
    Width: 147 Height: 28
ASSISTANT
Tool: Read
  (toolu_015xgoNQxGZXWcg3P15SPS8x)
    file_path: /var/www/rosy.shitchell.com/srv/web/index.html
  Tokens: in=0 out=74 cache=26041
Result
  (toolu_015xgoNQxGZXWcg3P15SPS8x)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's SQL Practice - Amazon Interview Prep</title>
         7→    <style>
         8→        * {
         9→            margin: 0;
        10→            padding: 0;
        11→            box-sizing: border-box;
        12→        }
        13→        body {
        14→            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
        15→            background: linear-gradient(135deg, #232f3e 0%, #37475a 100%);
        16→            min-height: 100vh;
        17→            padding: 20px;
        18→            color: #333;
        19→        }
        20→        .container {
    ... (325 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_012daUV2YmKwRLygPq2o16di)
    todos: [{'content': 'Create photography portfolio website structure', 'status': 'in_progress', 'activeForm': 'Creating photography portfolio website structure'}, {'content': 'Build modern cozy HTML/CSS desig...
  Tokens: in=0 out=176 cache=26569
Result
  (toolu_012daUV2YmKwRLygPq2o16di)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: AskUserQuestion
  (toolu_01PcPBXojQNjFZQGsUHnhqqm)
    questions: [{'question': 'Do you want your photography site as a separate page (like rosy.shitchell.com/photography) or replace the current homepage entirely?', 'header': 'Site location', 'options': [{'label': '...
  Tokens: in=0 out=241 cache=31179
Result
  (toolu_01PcPBXojQNjFZQGsUHnhqqm)
    User has answered your questions: "Do you want your photography site as a separate page (like rosy.shitchell.com/photography) or replace the current homepage entirely?"="rosy.shitchell.com/photography", "Do you already have photos ready to upload, or should I create placeholder spots for now?"="Use placeholders". You can now continue with the user's answers in mind.
ASSISTANT
  I'll create a separate `/photography` section with a modern, cozy design using placeholders. Let me build this out for you:
  Tokens: in=0 out=129 cache=31397
ASSISTANT
Tool: Bash
  (toolu_013QdqWovxQZ3cCtRaQFMn4f)
    command: mkdir -p /var/www/rosy.shitchell.com/srv/web/photography/images/{landscapes,historic}
    description: Create photography directory structure
  Tokens: in=0 out=129 cache=31397
Result
  (toolu_013QdqWovxQZ3cCtRaQFMn4f)
ASSISTANT
Tool: TodoWrite
  (toolu_014TCp7SewC3Mh6TiJWctDAL)
    todos: [{'content': 'Create photography portfolio website structure', 'status': 'completed', 'activeForm': 'Creating photography portfolio website structure'}, {'content': 'Build modern cozy HTML/CSS design'...
  Tokens: in=0 out=176 cache=31736
Result
  (toolu_014TCp7SewC3Mh6TiJWctDAL)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Write
  (toolu_01DgoNPrNhy46G7xDA5DuAhs)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    content: <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Rosy's Photography</title>
        <link rel="preco...
  Tokens: in=0 out=5059 cache=31891
Result
  (toolu_01DgoNPrNhy46G7xDA5DuAhs)
    File created successfully at: /var/www/rosy.shitchell.com/srv/web/photography/index.html
ASSISTANT
Tool: Bash
  (toolu_012M73wCdRMr7imR8847cahh)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Set file permissions for web access
  Tokens: in=0 out=101 cache=32109
Result
  (toolu_012M73wCdRMr7imR8847cahh)
ASSISTANT
Tool: TodoWrite
  (toolu_01W54BVw6uFJnRt8QMcDqv7G)
    todos: [{'content': 'Create photography portfolio website structure', 'status': 'completed', 'activeForm': 'Creating photography portfolio website structure'}, {'content': 'Build modern cozy HTML/CSS design'...
  Tokens: in=0 out=174 cache=37207
Result
  (toolu_01W54BVw6uFJnRt8QMcDqv7G)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Your photography portfolio is ready! Check it out at: **https://rosy.shitchell.com/photography**
  
  ## What I created:
  
  **Design style - Modern & Cozy:**
  - Warm cream and brown color palette with sage and terracotta accents
  - Elegant serif font (Playfair Display) for headings, clean sans-serif for body
  - Soft shadows, rounded corners, and smooth hover animations
  - Sticky navigation that follows as you scroll
  
  **Features:**
  - **Hero section** with a welcoming message
  - **Landscapes gallery** - 5 placeholder spots including one wide "featured" image
  - **Historic Sites gallery** - 5 placeholder spots with a wide panoramic option
  - **About section** you can customize
  - **Lightbox** - when you add real photos, clicking them will open a full-screen view
  - Works well on mobile too!
  
  ## To add your photos:
  
  1. Upload images to these folders:
     - `/var/www/rosy.shitchell.com/srv/web/photography/images/landscapes/`
     - `/var/www/rosy.shitchell.com/srv/web/photography/images/historic/`
  
  2. Then replace the `<div class="placeholder">...</div>` blocks with actual `<img>` tags, like:
     ```html
     <img src="images/landscapes/mountain-sunset.jpg" alt="Mountain Sunset">
     ```
  
  3. Update the `<h3>Title</h3>` and `<p>Location</p>` in each overlay
  
  Would you like me to:
  - Adjust the colors or fonts?
  - Show you a preview in a side pane?
  - Help you upload some photos once you have them?
  - Should I commit these changes to your git repo to make them permanent?
  Tokens: in=0 out=420 cache=37334
USER
  Can you make this less bright? and yes side pane is a good idea. I do have a photo where can i upload? Can i upload thru the web?
ASSISTANT
  I'll darken the color scheme and show you a preview. For uploading photos - you can't upload through the web directly right now, but let me show you a few easy options:
  Tokens: in=2 out=3 cache=37550
ASSISTANT
Tool: Read
  (toolu_01XshvnEPEMwgVTkMQdG4PBx)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
  Tokens: in=2 out=116 cache=37550
Result
  (toolu_01XshvnEPEMwgVTkMQdG4PBx)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #faf8f5;
        13→            --warm-white: #f5f2ed;
        14→            --soft-brown: #8b7355;
        15→            --deep-brown: #4a3f35;
        16→            --accent-sage: #7d8c7a;
        17→            --accent-terracotta: #c4967a;
        18→            --text-dark: #3d3530;
        19→            --text-light: #6b5e54;
        20→        }
    ... (602 lines total)
ASSISTANT
Tool: Edit
  (toolu_01CpjrWGckMRCCgxpuTbPQH6)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         :root {
                --cream: #faf8f5;
                --warm-white: #f5f2ed;
                --soft-brown: #8b7355;
                --deep-brown: #4a3f35;
                --accent-sage: #7d8c7a;
                -...
    new_string:         :root {
                --cream: #2a2520;
                --warm-white: #1e1b18;
                --soft-brown: #a89580;
                --deep-brown: #d4c4b0;
                --accent-sage: #6b7c68;
                -...
  Tokens: in=0 out=345 cache=38006
Result
  (toolu_01CpjrWGckMRCCgxpuTbPQH6)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #2a2520;
        13→            --warm-white: #1e1b18;
        14→            --soft-brown: #a89580;
        15→            --deep-brown: #d4c4b0;
        16→            --accent-sage: #6b7c68;
        17→            --accent-terracotta: #c4967a;
        18→            --text-dark: #e8e2dc;
        19→            --text-light: #b5a99a;
        20→        }
        21→
        22→        * {
        23→            margin: 0;
        24→            padding: 0;
ASSISTANT
Tool: Edit
  (toolu_01AKGpMkPnmu1VuoZkvR2ZPh)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                padding: 60px 20px 40px;
                text-align: center;
                background: linear-gradient(180deg, var(--warm-white) 0%, var(--cream) 100%);
       ...
    new_string:         /* Header */
            header {
                padding: 60px 20px 40px;
                text-align: center;
                background: linear-gradient(180deg, #1a1714 0%, var(--cream) 100%);
            }
  Tokens: in=0 out=236 cache=45040
Result
  (toolu_01AKGpMkPnmu1VuoZkvR2ZPh)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        35→            color: var(--text-dark);
        36→            line-height: 1.6;
        37→        }
        38→
        39→        /* Header */
        40→        header {
        41→            padding: 60px 20px 40px;
        42→            text-align: center;
        43→            background: linear-gradient(180deg, #1a1714 0%, var(--cream) 100%);
        44→        }
        45→
        46→        .logo {
        47→            font-family: 'Playfair Display', Georgia, serif;
        48→            font-size: 2.8rem;
ASSISTANT
Tool: Edit
  (toolu_01VVDFxENiYuPKAp6MztsKXT)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                background: var(--cream);
             ...
    new_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                background: var(--cream);
             ...
  Tokens: in=0 out=306 cache=45743
Result
  (toolu_01VVDFxENiYuPKAp6MztsKXT)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        59→            letter-spacing: 0.1em;
        60→            text-transform: uppercase;
        61→        }
        62→
        63→        /* Navigation */
        64→        nav {
        65→            display: flex;
        66→            justify-content: center;
        67→            gap: 40px;
        68→            padding: 20px;
        69→            background: var(--cream);
        70→            position: sticky;
        71→            top: 0;
        72→            z-index: 100;
        73→            border-bottom: 1px solid rgba(168, 149, 128, 0.2);
        74→        }
        75→
        76→        nav a {
        77→            color: var(--soft-brown);
    ... (21 lines total)
ASSISTANT
Tool: Edit
  (toolu_01Us6E465Ywj1JcntmNTinpR)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Hero Section */
            .hero {
                height: 70vh;
                min-height: 400px;
                display: flex;
                align-items: center;
                justify-content: center;
       ...
    new_string:         /* Hero Section */
            .hero {
                height: 70vh;
                min-height: 400px;
                display: flex;
                align-items: center;
                justify-content: center;
       ...
  Tokens: in=0 out=304 cache=46205
Result
  (toolu_01Us6E465Ywj1JcntmNTinpR)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       103→        nav a:hover::after {
       104→            width: 100%;
       105→        }
       106→
       107→        /* Hero Section */
       108→        .hero {
       109→            height: 70vh;
       110→            min-height: 400px;
       111→            display: flex;
       112→            align-items: center;
       113→            justify-content: center;
       114→            background: linear-gradient(135deg, #3d4a3a 0%, #4a4035 100%);
       115→            position: relative;
       116→            overflow: hidden;
       117→        }
       118→
       119→        .hero::before {
       120→            content: '';
       121→            position: absolute;
ASSISTANT
Tool: Edit
  (toolu_01PCyZvPFV1hYK8qHGcherXK)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Placeholder styling */
            .placeholder {
                width: 100%;
                height: 100%;
                background: linear-gradient(135deg, var(--warm-white) 0%, #e8e4de 100%);
           ...
    new_string:         /* Placeholder styling */
            .placeholder {
                width: 100%;
                height: 100%;
                background: linear-gradient(135deg, #353028 0%, #2a2520 100%);
                displ...
  Tokens: in=0 out=307 cache=46882
Result
  (toolu_01PCyZvPFV1hYK8qHGcherXK)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       218→        .gallery-item:hover img {
       219→            transform: scale(1.05);
       220→        }
       221→
       222→        /* Placeholder styling */
       223→        .placeholder {
       224→            width: 100%;
       225→            height: 100%;
       226→            background: linear-gradient(135deg, #353028 0%, #2a2520 100%);
       227→            display: flex;
       228→            flex-direction: column;
       229→            align-items: center;
       230→            justify-content: center;
       231→            color: var(--soft-brown);
       232→        }
       233→
       234→        .placeholder-icon {
       235→            font-size: 3rem;
       236→            margin-bottom: 10px;
ASSISTANT
Tool: Edit
  (toolu_01StPAZX2GG3Tq1pqSyB7cmj)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .gallery-item:hover {
                transform: translateY(-5px);
                box-shadow: 0 12px 40px rgba(74, 63, 53, 0.2);
            }
    new_string:         .gallery-item:hover {
                transform: translateY(-5px);
                box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
            }
  Tokens: in=0 out=212 cache=47438
Result
  (toolu_01StPAZX2GG3Tq1pqSyB7cmj)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       202→            box-shadow: 0 4px 20px rgba(74, 63, 53, 0.1);
       203→            transition: transform 0.4s ease, box-shadow 0.4s ease;
       204→        }
       205→
       206→        .gallery-item:hover {
       207→            transform: translateY(-5px);
       208→            box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
       209→        }
       210→
       211→        .gallery-item img {
       212→            width: 100%;
       213→            height: 100%;
ASSISTANT
Tool: Edit
  (toolu_018uib7AqgAYSpJNj5vwY9qQ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Footer */
            footer {
                background: var(--deep-brown);
                color: rgba(255, 255, 255, 0.8);
                text-align: center;
                padding: 50px 20px;
            }
    ...
    new_string:         /* Footer */
            footer {
                background: #151311;
                color: rgba(255, 255, 255, 0.8);
                text-align: center;
                padding: 50px 20px;
            }
    
            f...
  Tokens: in=0 out=308 cache=48010
Result
  (toolu_018uib7AqgAYSpJNj5vwY9qQ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       298→            line-height: 1.8;
       299→            color: var(--text-light);
       300→        }
       301→
       302→        /* Footer */
       303→        footer {
       304→            background: #151311;
       305→            color: rgba(255, 255, 255, 0.8);
       306→            text-align: center;
       307→            padding: 50px 20px;
       308→        }
       309→
       310→        footer .logo {
       311→            color: var(--deep-brown);
       312→            font-size: 1.8rem;
       313→            margin-bottom: 15px;
       314→        }
       315→
       316→        footer p {
    ... (22 lines total)
ASSISTANT
  Now let me open a preview in a side pane for you:
  Tokens: in=0 out=1 cache=48551
ASSISTANT
Tool: Bash
  (toolu_01NLtu1cVemQ6Vyw6TEJzs6u)
    command: claude-pane --position side --command 'echo "
    Photography Portfolio - Dark Theme Preview
    ============================================
    
    Visit: https://rosy.shitchell.com/photography
    
    Color Palette (now...
    description: Show preview pane with dark theme info
  Tokens: in=0 out=360 cache=48551
Error
  (toolu_01NLtu1cVemQ6Vyw6TEJzs6u)
    Exit code 1
    [31merror:[0m unknown command: --position (try 'run', 'kill', or 'list')
ASSISTANT
Tool: Bash
  (toolu_01J95GZ5Pq5m2pePDp8dY2Dr)
    command: claude-pane run --position side --page --command 'echo "
    Photography Portfolio - Dark Theme Preview
    ============================================
    
    Visit: https://rosy.shitchell.com/photography
    
    Color P...
    description: Show preview pane with upload options
  Tokens: in=0 out=340 cache=49136
Error
  (toolu_01J95GZ5Pq5m2pePDp8dY2Dr)
    Exit code 1
    [31merror:[0m unknown option: --position
ASSISTANT
Tool: Bash
  (toolu_01NeNfUxH16Cmtgpu6jkK3Y4)
    command: claude-pane --help 2>&1 | head -40
    description: Check claude-pane usage
  Tokens: in=0 out=88 cache=49651
Result
  (toolu_01NeNfUxH16Cmtgpu6jkK3Y4)
    claude-pane: tmux pane manager for teaching sessions
    
    USAGE:
      claude-pane <command> [args]
    
    COMMANDS:
      run <position> [options]   Create or replace pane at position
      kill <position>            Close pane at position
      list                       Show active panes
    
    Run 'claude-pane <command> --help' for command-specific help.
ASSISTANT
Tool: Bash
  (toolu_016RQkpeKYgPZZPEvjCQuMB2)
    command: claude-pane run --help 2>&1
    description: Check run command options
  Tokens: in=0 out=82 cache=50028
Result
  (toolu_016RQkpeKYgPZZPEvjCQuMB2)
    claude-pane run: Create or replace pane at position
    
    USAGE:
      claude-pane run <position> [options] <content-source>
    
    REQUIRED:
      position <side|below>       Where to open the pane
    
    CONTENT SOURCE (one required):
      --command '<cmd>'           Run arbitrary command (use '-' to read from stdin)
      --follow <file>             Shorthand for tail -f <file>
      --run-in-blocks <script>    Run script via block-run (notebook-style)
    
    OPTIONS:
      --title "..."               Label shown at top of pane
      --page                      Pipe through less -R with mouse scrolling
      --log                       Capture output via script(1)
      --interactive               Skip script(1) wrapping (for interactive commands)
      --full                      Pane spans full window width/height
      --no-full                   Pane splits current pane only (default)
    ... (32 lines total)
ASSISTANT
Tool: Bash
  (toolu_01LbMka5rnWaUr935QdFac3a)
    command: claude-pane run side --title "Photo Upload Options" --page --command - << 'EOF'
    echo "
    ╔══════════════════════════════════════════════════════════════╗
    ║         Photography Portfolio - Dark Theme App...
    description: Show side pane with upload options
  Tokens: in=0 out=535 cache=50218
Result
  (toolu_01LbMka5rnWaUr935QdFac3a)
    opened pane %40 at position 'side'
ASSISTANT
  I've opened a pane on the side showing the upload options. Use the arrow keys to scroll if needed, and press `q` to close it when you're done.
  
  **I've darkened the site** - it now has a warm charcoal background with deep brown-black sections. Check it out at: **https://rosy.shitchell.com/photography**
  
  ## To upload your photo:
  
  The easiest way is to just **tell me where the file is**. For example:
  - `~/Downloads/sunset.jpg`
  - Or drag the file into your terminal window - it'll show the path
  
  Once I know where your photo is, I'll:
  1. Copy it to the website's images folder
  2. Add it to the gallery with proper sizing
  3. Ask you for a title and location to display
  
  **Where is your photo located?** (file path or drag it into the terminal)
  Tokens: in=0 out=203 cache=50768
USER
  drag
ASSISTANT
  When you drag a file into the terminal, it will paste the full file path where your cursor is. Just drag and drop the photo file right here, and the path will appear - then hit Enter and I'll see it!
  
  Go ahead and try it now - drag your photo into this terminal window.
  Tokens: in=2 out=65 cache=51327
USER
  where can i put?
ASSISTANT
  Just drag the photo file directly into this chat window - drop it right where you'd normally type your message. The file path will appear as text, then press Enter to send it to me.
  
  Like this:
  1. Find your photo file on your computer
  2. Click and drag it
  3. Drop it right here in the terminal where we're chatting
  4. You'll see something like `/Users/rosy/Photos/landscape.jpg` appear
  5. Press Enter
  
  Try it now! Drag your photo here.
  Tokens: in=2 out=115 cache=51532
USER
  i can't drag to this window
ASSISTANT
  Ah, that's okay! Let me give you another easy option.
  
  **Where is your photo right now?** Is it:
  
  1. **On this server already?** (like in `~/Downloads/` or somewhere else)
  2. **On your local computer?** (your laptop/desktop)
  
  If it's on your **local computer**, you can upload it using `scp`. Here's how:
  
  1. Open a **new terminal window** on your local machine
  2. Run this command (replace with your actual file):
     ```bash
     scp /path/to/your/photo.jpg rosy@files.shitchell.com:~/public/
     ```
  3. Then come back here and tell me the filename, and I'll add it to your site!
  
  Or if you tell me where the photo is on your computer, I can give you the exact command to copy-paste.
  
  **Which situation are you in?** Local computer or already on the server?
  Tokens: in=2 out=220 cache=51708
USER
  i'm fine i will add later
ASSISTANT
  Sounds good! When you're ready to add photos, just let me know the file path and I'll add them to the gallery for you.
  
  **Quick recap of your photography site:**
  - **URL:** https://rosy.shitchell.com/photography
  - **Style:** Dark, cozy theme with warm charcoal tones
  - **Sections:** Landscapes and Historic Sites galleries
  - **Photo folders ready at:**
    - `/var/www/rosy.shitchell.com/srv/web/photography/images/landscapes/`
    - `/var/www/rosy.shitchell.com/srv/web/photography/images/historic/`
  
  Let me close that side pane for you:
  Tokens: in=2 out=2 cache=51833
ASSISTANT
Tool: Bash
  (toolu_0164jd2xRj2FUE1KSMXYbgfK)
    command: claude-pane kill side
    description: Close the side pane
  Tokens: in=2 out=242 cache=51833
Result
  (toolu_0164jd2xRj2FUE1KSMXYbgfK)
    killed pane %40 at position 'side'
ASSISTANT
  Would you like me to commit these changes to your git repo so they're saved permanently? Or want me to adjust the colors/design first?
  Tokens: in=0 out=32 cache=52063
USER
  can you put the color lighter
ASSISTANT
Tool: Read
  (toolu_01GdCv6874kRXdwV1zizN9mL)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    limit: 50
  Tokens: in=2 out=93 cache=52434
Result
  (toolu_01GdCv6874kRXdwV1zizN9mL)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #2a2520;
        13→            --warm-white: #1e1b18;
        14→            --soft-brown: #a89580;
        15→            --deep-brown: #d4c4b0;
        16→            --accent-sage: #6b7c68;
        17→            --accent-terracotta: #c4967a;
        18→            --text-dark: #e8e2dc;
        19→            --text-light: #b5a99a;
        20→        }
    ... (55 lines total)
ASSISTANT
  I'll lighten it up - going for a middle ground between the original bright version and the dark one. A warm, muted tone that's still cozy:
  Tokens: in=0 out=3 cache=52473
ASSISTANT
Tool: Edit
  (toolu_012cNbe9ZY4Wahd8kTRNRGWU)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         :root {
                --cream: #2a2520;
                --warm-white: #1e1b18;
                --soft-brown: #a89580;
                --deep-brown: #d4c4b0;
                --accent-sage: #6b7c68;
                -...
    new_string:         :root {
                --cream: #e8e2d9;
                --warm-white: #d9d2c7;
                --soft-brown: #7a6b5a;
                --deep-brown: #4a3f35;
                --accent-sage: #6b7c68;
                -...
  Tokens: in=0 out=382 cache=52473
Result
  (toolu_012cNbe9ZY4Wahd8kTRNRGWU)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #e8e2d9;
        13→            --warm-white: #d9d2c7;
        14→            --soft-brown: #7a6b5a;
        15→            --deep-brown: #4a3f35;
        16→            --accent-sage: #6b7c68;
        17→            --accent-terracotta: #b8856a;
        18→            --text-dark: #3d3530;
        19→            --text-light: #5c524a;
        20→        }
        21→
        22→        * {
        23→            margin: 0;
        24→            padding: 0;
ASSISTANT
Tool: Edit
  (toolu_01W86MXfHgE5kw5mctaBHMoC)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             background: linear-gradient(180deg, #1a1714 0%, var(--cream) 100%);
    new_string:             background: linear-gradient(180deg, #d4cdc2 0%, var(--cream) 100%);
  Tokens: in=0 out=165 cache=53335
Result
  (toolu_01W86MXfHgE5kw5mctaBHMoC)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        39→        /* Header */
        40→        header {
        41→            padding: 60px 20px 40px;
        42→            text-align: center;
        43→            background: linear-gradient(180deg, #d4cdc2 0%, var(--cream) 100%);
        44→        }
        45→
        46→        .logo {
        47→            font-family: 'Playfair Display', Georgia, serif;
ASSISTANT
Tool: Edit
  (toolu_01SMf5WqxQkmSRYPH4zaB2Ww)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             background: linear-gradient(135deg, #3d4a3a 0%, #4a4035 100%);
    new_string:             background: linear-gradient(135deg, #7d8c7a 0%, #8b7d6b 100%);
  Tokens: in=0 out=170 cache=54182
Result
  (toolu_01SMf5WqxQkmSRYPH4zaB2Ww)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       110→            min-height: 400px;
       111→            display: flex;
       112→            align-items: center;
       113→            justify-content: center;
       114→            background: linear-gradient(135deg, #7d8c7a 0%, #8b7d6b 100%);
       115→            position: relative;
       116→            overflow: hidden;
       117→        }
       118→
ASSISTANT
Tool: Edit
  (toolu_01WBdXZJY81SHGrsZmxGQPHs)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             background: linear-gradient(135deg, #353028 0%, #2a2520 100%);
    new_string:             background: linear-gradient(135deg, #d4cdc2 0%, #c9c1b5 100%);
  Tokens: in=0 out=165 cache=54521
Result
  (toolu_01WBdXZJY81SHGrsZmxGQPHs)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       222→        /* Placeholder styling */
       223→        .placeholder {
       224→            width: 100%;
       225→            height: 100%;
       226→            background: linear-gradient(135deg, #d4cdc2 0%, #c9c1b5 100%);
       227→            display: flex;
       228→            flex-direction: column;
       229→            align-items: center;
       230→            justify-content: center;
ASSISTANT
Tool: Edit
  (toolu_01GyLwwpdmbYybioMSpowe1K)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
    new_string:             box-shadow: 0 12px 40px rgba(74, 63, 53, 0.25);
  Tokens: in=0 out=168 cache=54859
Result
  (toolu_01GyLwwpdmbYybioMSpowe1K)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       204→        }
       205→
       206→        .gallery-item:hover {
       207→            transform: translateY(-5px);
       208→            box-shadow: 0 12px 40px rgba(74, 63, 53, 0.25);
       209→        }
       210→
       211→        .gallery-item img {
       212→            width: 100%;
ASSISTANT
Tool: Edit
  (toolu_01HKFJF5xnVSkkkQFpRE7kJa)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Footer */
            footer {
                background: #151311;
                color: rgba(255, 255, 255, 0.8);
                text-align: center;
                padding: 50px 20px;
            }
    
            f...
    new_string:         /* Footer */
            footer {
                background: #4a4035;
                color: rgba(255, 255, 255, 0.85);
                text-align: center;
                padding: 50px 20px;
            }
    
            ...
  Tokens: in=0 out=313 cache=55302
Result
  (toolu_01HKFJF5xnVSkkkQFpRE7kJa)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       298→            line-height: 1.8;
       299→            color: var(--text-light);
       300→        }
       301→
       302→        /* Footer */
       303→        footer {
       304→            background: #4a4035;
       305→            color: rgba(255, 255, 255, 0.85);
       306→            text-align: center;
       307→            padding: 50px 20px;
       308→        }
       309→
       310→        footer .logo {
       311→            color: #e8e2d9;
       312→            font-size: 1.8rem;
       313→            margin-bottom: 15px;
       314→        }
       315→
       316→        footer p {
    ... (22 lines total)
ASSISTANT
  Done! I've lightened it to a warm, muted palette - think coffee with cream tones. Refresh the page to see the changes: **https://rosy.shitchell.com/photography**
  
  **New colors:**
  - Background: warm taupe/beige (#e8e2d9)
  - Hero: soft sage green → warm brown gradient
  - Footer: deep brown (not black)
  - Text: dark brown tones for easy reading
  
  Take a look and let me know if you want it adjusted more - lighter, darker, different colors?
  Tokens: in=0 out=126 cache=55629
USER
  can you make the user can upload the pic directly to the web?
ASSISTANT
  Good idea! I can add a photo upload feature to the site. Before I build it, let me ask a couple questions:
  Tokens: in=2 out=1 cache=56222
ASSISTANT
Tool: AskUserQuestion
  (toolu_016pcMcpWrEBxjG4dPEhd9wi)
    questions: [{'question': 'Should anyone be able to upload, or just you with a password?', 'header': 'Access', 'options': [{'label': 'Password protected', 'description': 'Only you can upload (requires a password)...
  Tokens: in=2 out=159 cache=56222
Result
  (toolu_016pcMcpWrEBxjG4dPEhd9wi)
    User has answered your questions: "Should anyone be able to upload, or just you with a password?"="Password protected". You can now continue with the user's answers in mind.
ASSISTANT
Tool: TodoWrite
  (toolu_01XWpVZXAyJKzsY9s9s5t4VT)
    todos: [{'content': 'Create PHP upload script with password protection', 'status': 'in_progress', 'activeForm': 'Creating PHP upload script with password protection'}, {'content': 'Create upload form page', ...
  Tokens: in=0 out=168 cache=56466
Result
  (toolu_01XWpVZXAyJKzsY9s9s5t4VT)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  I'll create a password-protected upload page for you. Let me check what's available on the server and set this up:
  Tokens: in=0 out=1 cache=56675
ASSISTANT
Tool: Bash
  (toolu_01NAna9bfqK6SYXHk6gzK21u)
    command: which php && php -v | head -1
    description: Check if PHP is available
  Tokens: in=0 out=1 cache=56675
ASSISTANT
Tool: Bash
  (toolu_01RXSw43Fm9MeJgqrW5jWaUd)
    command: ls -la /var/www/rosy.shitchell.com/srv/
    description: Check server directory structure
  Tokens: in=0 out=183 cache=56675
Error
  (toolu_01NAna9bfqK6SYXHk6gzK21u)
    Exit code 1
Result
  (toolu_01RXSw43Fm9MeJgqrW5jWaUd)
    total 28
    drwxrwsr-x+ 4 rosy-web rosy-web 4096 Dec  5 09:42 .
    drwxr-sr-x  6 rosy-web rosy-web 4096 Dec  5 09:06 ..
    drwxrwsr-x+ 4 rosy-web rosy-web 4096 Dec  5 09:26 api
    drwxrwsr-x+ 5 rosy-web rosy-web 4096 Dec  7 04:29 web
ASSISTANT
Tool: Bash
  (toolu_01Nygb6DpqvTrYnaBeu6pZ1U)
    command: cat /etc/nginx/sites-available/rosy.shitchell.com | head -60
    description: Check nginx config for PHP support
  Tokens: in=0 out=96 cache=56885
Result
  (toolu_01Nygb6DpqvTrYnaBeu6pZ1U)
    # Nginx Configuration for rosy.shitchell.com
    
    server {
        access_log /var/www/rosy.shitchell.com/logs/access.log;
        error_log /var/www/rosy.shitchell.com/logs/error.log;
        server_name rosy.shitchell.com;
    
        location /.well-known/acme-challenge/ {
            root /var/www/certbot;
        }
    
        root /var/www/rosy.shitchell.com/srv/web;
        index index.html;
    
        location / {
            try_files $uri $uri/ =404;
        }
    
        location = / {
            try_files /index.html =404;
    ... (51 lines total)
ASSISTANT
  The server doesn't have PHP set up for the web directory. Let me check what's in the API folder - there might be a Docker setup we can use:
  Tokens: in=0 out=1 cache=57271
ASSISTANT
Tool: Bash
  (toolu_011Pt2SGcqohRw9cVbYSvHkk)
    command: ls -la /var/www/rosy.shitchell.com/srv/api/
    description: Check API directory
  Tokens: in=0 out=126 cache=57271
Result
  (toolu_011Pt2SGcqohRw9cVbYSvHkk)
    total 48
    drwxrwsr-x+ 4 rosy-web rosy-web 4096 Dec  5 09:26 .
    drwxrwsr-x+ 4 rosy-web rosy-web 4096 Dec  5 09:42 ..
    -rw-rwxr--+ 1 rosy-web rosy-web   41 Dec  5 09:25 .commit
    -rw-rwxr--+ 1 rosy-web rosy-web  900 Dec  5 09:25 docker-compose.yml
    -rw-rwxr--+ 1 rosy-web rosy-web   87 Dec  1 01:51 .env
    drwxrwsr-x+ 3 rosy-web rosy-web 4096 Dec  5 09:25 .github
    drwxrwsr-x+ 2 rosy-web rosy-web 4096 Dec  5 09:25 init
    -rw-rwxr--+ 1 rosy-web rosy-web    3 Dec  5 09:25 .version
ASSISTANT
  Since PHP isn't set up, I'll create a simple Node.js upload server using Docker - this is cleaner and more secure. Let me set this up:
  Tokens: in=0 out=1 cache=57869
ASSISTANT
Tool: Bash
  (toolu_0124czyDbKV95ZLpBU75k8ru)
    command: docker ps --format "table {{.Names}}\t{{.Ports}}" | head -10
    description: Check running Docker containers
  Tokens: in=0 out=128 cache=57869
Result
  (toolu_0124czyDbKV95ZLpBU75k8ru)
    NAMES          PORTS
    rosy-mariadb   3306/tcp
    rosy-adminer   127.0.0.1:8082->8080/tcp
ASSISTANT
  I'll create a lightweight upload service. First, let me set up the upload directory and create the upload API:
  Tokens: in=0 out=2 cache=58449
ASSISTANT
Tool: Bash
  (toolu_019HPLDxfRiUaHygyhLL4C9i)
    command: mkdir -p /var/www/rosy.shitchell.com/srv/web/photography/uploads
    description: Create uploads directory
  Tokens: in=0 out=119 cache=58449
Result
  (toolu_019HPLDxfRiUaHygyhLL4C9i)
ASSISTANT
Tool: Write
  (toolu_019M9k8SK6tnE7wPUNMYsrzg)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    content: const http = require('http');
    const fs = require('fs');
    const path = require('path');
    const crypto = require('crypto');
    
    // Configuration
    const UPLOAD_PASSWORD = process.env.UPLOAD_PASSWORD || 'rosy-p...
  Tokens: in=0 out=1947 cache=58628
Result
  (toolu_019M9k8SK6tnE7wPUNMYsrzg)
    File created successfully at: /var/www/rosy.shitchell.com/srv/upload-api/server.js
ASSISTANT
Tool: Write
  (toolu_01MeCNMjpZDajFdH8axpD6rx)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/Dockerfile
    content: FROM node:20-alpine
    WORKDIR /app
    COPY server.js .
    EXPOSE 3000
    CMD ["node", "server.js"]
    
  Tokens: in=0 out=127 cache=58920
Result
  (toolu_01MeCNMjpZDajFdH8axpD6rx)
    File created successfully at: /var/www/rosy.shitchell.com/srv/upload-api/Dockerfile
ASSISTANT
Tool: Write
  (toolu_01EEKPbQXEQqAUbrt6dF8LWP)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml
    content: services:
      upload-api:
        build: .
        container_name: rosy-upload
        restart: unless-stopped
        ports:
          - "127.0.0.1:8083:3000"
        volumes:
          - /var/www/rosy.shitchell.com/srv/web/photo...
  Tokens: in=0 out=197 cache=60910
Result
  (toolu_01EEKPbQXEQqAUbrt6dF8LWP)
    File created successfully at: /var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml
ASSISTANT
Tool: TodoWrite
  (toolu_015uDwHke36uek4ec5CJN4YY)
    todos: [{'content': 'Create upload API server', 'status': 'completed', 'activeForm': 'Creating upload API server'}, {'content': 'Create upload form page', 'status': 'in_progress', 'activeForm': 'Creating upl...
  Tokens: in=0 out=187 cache=61077
Result
  (toolu_015uDwHke36uek4ec5CJN4YY)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me create the upload page with flexible image sizing:
  Tokens: in=0 out=1 cache=61480
ASSISTANT
Tool: Write
  (toolu_01HekpqDNxNsfEgxFRYLFj9g)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    content: <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Upload Photos - Rosy's Photography</title>
        ...
  Tokens: in=0 out=3700 cache=61480
Result
  (toolu_01HekpqDNxNsfEgxFRYLFj9g)
    File created successfully at: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
ASSISTANT
Tool: TodoWrite
  (toolu_01UTCx9RQZR5pcRTe93rNco4)
    todos: [{'content': 'Create upload API server', 'status': 'completed', 'activeForm': 'Creating upload API server'}, {'content': 'Create upload form page', 'status': 'completed', 'activeForm': 'Creating uploa...
  Tokens: in=0 out=187 cache=61709
Result
  (toolu_01UTCx9RQZR5pcRTe93rNco4)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me update nginx to proxy the upload API:
  Tokens: in=0 out=1 cache=67956
ASSISTANT
Tool: Read
  (toolu_01PMZMs4uxtX9xbWxd9B3EiL)
    file_path: /etc/nginx/sites-available/rosy.shitchell.com
  Tokens: in=0 out=82 cache=67956
Result
  (toolu_01PMZMs4uxtX9xbWxd9B3EiL)
         1→# Nginx Configuration for rosy.shitchell.com
         2→
         3→server {
         4→    access_log /var/www/rosy.shitchell.com/logs/access.log;
         5→    error_log /var/www/rosy.shitchell.com/logs/error.log;
         6→    server_name rosy.shitchell.com;
         7→
         8→    location /.well-known/acme-challenge/ {
         9→        root /var/www/certbot;
        10→    }
        11→
        12→    root /var/www/rosy.shitchell.com/srv/web;
        13→    index index.html;
        14→
        15→    location / {
        16→        try_files $uri $uri/ =404;
        17→    }
        18→
        19→    location = / {
        20→        try_files /index.html =404;
    ... (56 lines total)
ASSISTANT
Tool: Edit
  (toolu_01S21NB9Yv8en3UtwsaQioSd)
    file_path: /etc/nginx/sites-available/rosy.shitchell.com
    old_string:     location /adminer/ {
            proxy_pass http://127.0.0.1:8082/;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    new_string:     location /adminer/ {
            proxy_pass http://127.0.0.1:8082/;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    
        # Photo upload API
        location /up...
  Tokens: in=0 out=298 cache=68185
Result
  (toolu_01S21NB9Yv8en3UtwsaQioSd)
    The file /etc/nginx/sites-available/rosy.shitchell.com has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        19→    location = / {
        20→        try_files /index.html =404;
        21→    }
        22→
        23→    location /adminer/ {
        24→        proxy_pass http://127.0.0.1:8082/;
        25→        proxy_set_header Host $host;
        26→        proxy_set_header X-Real-IP $remote_addr;
        27→    }
        28→
        29→    # Photo upload API
        30→    location /upload-api/ {
        31→        proxy_pass http://127.0.0.1:8083/;
        32→        proxy_set_header Host $host;
        33→        proxy_set_header X-Real-IP $remote_addr;
        34→        client_max_body_size 25M;
        35→    }
        36→
        37→    listen [::]:443 ssl; # managed by Certbot
    ... (22 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_01NUgjb76Sx9fzzzgDvTJcAE)
    todos: [{'content': 'Create upload API server', 'status': 'completed', 'activeForm': 'Creating upload API server'}, {'content': 'Create upload form page', 'status': 'completed', 'activeForm': 'Creating uploa...
  Tokens: in=0 out=187 cache=69018
Result
  (toolu_01NUgjb76Sx9fzzzgDvTJcAE)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me start the upload service and restart nginx:
  Tokens: in=0 out=1 cache=69661
ASSISTANT
Tool: Bash
  (toolu_01HmDvGVdxgzknfCWrciDL5t)
    command: mkdir -p /var/www/rosy.shitchell.com/srv/web/photography/uploads/{landscapes,historic} && chmod 755 /var/www/rosy.shitchell.com/srv/web/photography/uploads /var/www/rosy.shitchell.com/srv/web/photogra...
    description: Create upload directories
  Tokens: in=0 out=162 cache=69661
Result
  (toolu_01HmDvGVdxgzknfCWrciDL5t)
ASSISTANT
Tool: Bash
  (toolu_01N8wZcxs34ihURdRhAPaei4)
    command: cd /var/www/rosy.shitchell.com/srv/upload-api && docker compose up -d --build 2>&1
    description: Build and start upload container
  Tokens: in=0 out=105 cache=69890
Result
  (toolu_01N8wZcxs34ihURdRhAPaei4)
    time="2025-12-07T04:51:20Z" level=warning msg="Docker Compose is configured to build using Bake, but buildx isn't installed"
    #0 building with "default" instance using docker driver
    
    #1 [upload-api internal] load build definition from Dockerfile
    #1 transferring dockerfile: 206B 0.0s done
    #1 DONE 0.1s
    
    #2 [upload-api internal] load metadata for docker.io/library/node:20-alpine
    #2 DONE 0.7s
    
    #3 [upload-api internal] load .dockerignore
    #3 transferring context: 2B done
    #3 DONE 0.0s
    
    #4 [upload-api internal] load build context
    #4 transferring context: 6.46kB 0.1s done
    #4 DONE 0.1s
    
    #5 [upload-api 1/3] FROM docker.io/library/node:20-alpine@sha256:643e7036aa985317ebfee460005e322aa550c6b6883000d01daefb58689a58e2
    #5 resolve docker.io/library/node:20-alpine@sha256:643e7036aa985317ebfee460005e322aa550c6b6883000d01daefb58689a58e2 0.1s done
    ... (66 lines total)
ASSISTANT
Tool: Bash
  (toolu_01UAdxZ2QQ7u3fucRZXFU6k1)
    command: sudo /usr/sbin/nginx-restart 2>&1
    description: Restart nginx
  Tokens: in=0 out=84 cache=70078
Result
  (toolu_01UAdxZ2QQ7u3fucRZXFU6k1)
    nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
    nginx: configuration file /etc/nginx/nginx.conf test is successful
    nginx reloaded successfully
ASSISTANT
Tool: Bash
  (toolu_01DhuTSK1Fotdagz6FHqZEfw)
    command: docker logs rosy-upload 2>&1
    description: Check upload server logs
  Tokens: in=0 out=81 cache=72027
Result
  (toolu_01DhuTSK1Fotdagz6FHqZEfw)
    Upload server running on port 3000
ASSISTANT
Tool: TodoWrite
  (toolu_01FuVZc5EERwp6ZLSBaiGMQC)
    todos: [{'content': 'Create upload API server', 'status': 'completed', 'activeForm': 'Creating upload API server'}, {'content': 'Create upload form page', 'status': 'completed', 'activeForm': 'Creating uploa...
  Tokens: in=0 out=185 cache=72161
Result
  (toolu_01FuVZc5EERwp6ZLSBaiGMQC)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  All set! Your photo upload feature is ready.
  
  ## What I created:
  
  **Upload page:** https://rosy.shitchell.com/photography/upload.html
  
  **Features:**
  - Password protected (only you can upload)
  - Drag & drop or click to browse
  - Accepts JPG, PNG, GIF, WebP up to 20MB
  - Any image dimensions - completely flexible
  - Shows preview with file size and dimensions before uploading
  - Choose category: Landscapes or Historic Sites
  
  **Your upload password is:** `rosy-photo-2024`
  
  (You can change this later in the Docker config if you want)
  
  ## How to use it:
  
  1. Go to https://rosy.shitchell.com/photography/upload.html
  2. Enter the password
  3. Choose a category (Landscapes or Historic Sites)
  4. Drag your photo onto the page (or click to browse)
  5. Click "Upload Photo"
  
  The photos will be saved to `/photography/uploads/landscapes/` or `/photography/uploads/historic/` - I can then help you add them to the main gallery page when you're ready.
  
  Want to try it out now? Let me know if you have any questions or want to change the password!
  Tokens: in=0 out=282 cache=72262
USER
  also can you make the website look more like a Photobook?
ASSISTANT
  Great idea! A photobook style would be really nice - think clean, minimal, letting the photos be the focus. Let me redesign the gallery page:
  Tokens: in=2 out=1 cache=72489
ASSISTANT
Tool: Read
  (toolu_01KkvqeVfHxGm4WdSuj9yzZ3)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
  Tokens: in=2 out=109 cache=72489
Result
  (toolu_01KkvqeVfHxGm4WdSuj9yzZ3)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #e8e2d9;
        13→            --warm-white: #d9d2c7;
        14→            --soft-brown: #7a6b5a;
        15→            --deep-brown: #4a3f35;
        16→            --accent-sage: #6b7c68;
        17→            --accent-terracotta: #b8856a;
        18→            --text-dark: #3d3530;
        19→            --text-light: #5c524a;
        20→        }
    ... (602 lines total)
ASSISTANT
Tool: Write
  (toolu_01KECXak8uc2o3emZ1KAGWEP)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    content: <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Rosy's Photography</title>
        <link rel="preco...
  Tokens: in=0 out=6661 cache=72786
Result
  (toolu_01KECXak8uc2o3emZ1KAGWEP)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #f7f5f2;
        13→            --paper: #fffefa;
        14→            --ink: #2c2825;
        15→            --ink-light: #6b635c;
        16→            --ink-faint: #a39d96;
        17→            --accent: #8b7355;
        18→            --shadow: rgba(44, 40, 37, 0.08);
        19→            --shadow-deep: rgba(44, 40, 37, 0.15);
    ... (762 lines total)
ASSISTANT
  Done! Check out the new photobook design at: **https://rosy.shitchell.com/photography**
  
  ## New Photobook Style:
  
  **Cover page:**
  - Full-screen elegant cover with your name
  - "A Collection of Photographs" subtitle
  - Delicate border frame like a real book
  - Animated "Scroll to explore" hint
  
  **Chapter pages:**
  - "Chapter One: Landscapes" and "Chapter Two: Historic Sites"
  - Elegant serif font (Cormorant Garamond) - very bookish
  - Italic descriptions for each chapter
  - Page numbers at the bottom
  
  **Photo layouts - like a magazine/book spread:**
  - **Full-width** - for hero/featured shots
  - **Duo** - two photos side by side
  - **Triple** - three square photos in a row  
  - **Asymmetric** - large + small (2:1 ratio)
  - Portrait, landscape, wide, and square frame options
  
  **Afterword section** - like the back of a photobook with a personal note
  
  **Features:**
  - Subtle hover animations on photos
  - Captions fade in when you hover
  - Lightbox with left/right arrow navigation
  - Keyboard navigation (arrows + Escape)
  
  Take a look and let me know what you think! The upload page is still at: https://rosy.shitchell.com/photography/upload.html
  Tokens: in=0 out=321 cache=79819
USER
  the link shows 403
ASSISTANT
  Let me check the permissions:
  Tokens: in=2 out=1 cache=95471
ASSISTANT
Tool: Bash
  (toolu_01YJJJmKxDiXnNueaZdeQ4SP)
    command: ls -la /var/www/rosy.shitchell.com/srv/web/photography/
    description: Check photography directory permissions
  Tokens: in=2 out=102 cache=95471
Result
  (toolu_01YJJJmKxDiXnNueaZdeQ4SP)
    total 72
    drwxrwsr-x+ 4 rosy     rosy-web  4096 Dec  7 04:56 .
    drwxrwsr-x+ 5 rosy-web rosy-web  4096 Dec  7 04:29 ..
    drwxrwsr-x+ 4 rosy     rosy-web  4096 Dec  7 04:29 images
    -rw-r--r--+ 1 rosy     rosy-web 23132 Dec  7 04:56 index.html
    -rw-------+ 1 rosy     rosy-web 13207 Dec  7 04:50 upload.html
    drwxr-sr-x+ 4 rosy     rosy-web  4096 Dec  7 04:51 uploads
ASSISTANT
  Found it - the `upload.html` file has restricted permissions (`-rw-------`). Let me fix that:
  Tokens: in=0 out=1 cache=95798
ASSISTANT
Tool: Bash
  (toolu_01PrRJ3uarV9qKsD6LbMhshL)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/upload.html /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Fix file permissions
  Tokens: in=0 out=148 cache=95798
Result
  (toolu_01PrRJ3uarV9qKsD6LbMhshL)
ASSISTANT
Tool: Bash
  (toolu_01DZzbZrfBUyRs5mxuekfgAY)
    command: ls -la /var/www/rosy.shitchell.com/srv/web/photography/*.html
    description: Verify permissions fixed
  Tokens: in=0 out=96 cache=96219
Result
  (toolu_01DZzbZrfBUyRs5mxuekfgAY)
    -rw-r--r--+ 1 rosy rosy-web 23132 Dec  7 04:56 /var/www/rosy.shitchell.com/srv/web/photography/index.html
    -rw-r--r--+ 1 rosy rosy-web 13207 Dec  7 04:50 /var/www/rosy.shitchell.com/srv/web/photography/upload.html
ASSISTANT
  Fixed! Try refreshing now - both pages should work:
  
  - **Gallery:** https://rosy.shitchell.com/photography
  - **Upload:** https://rosy.shitchell.com/photography/upload.html
  
  The issue was the files had permissions that only allowed me to read them, not the web server. I changed them to `644` which means everyone can read (but only I can write).
  Tokens: in=0 out=95 cache=96393
USER
  what is the password?
ASSISTANT
  The upload password is: **`rosy-photo-2024`**
  
  You can use it at: https://rosy.shitchell.com/photography/upload.html
  
  If you want to change it to something else, just let me know!
  Tokens: in=2 out=59 cache=96713
USER
  can you set the password to Rr16234160!
ASSISTANT
Tool: Read
  (toolu_01MNnmrDwKxWhok9gSHm8tTW)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml
  Tokens: in=2 out=78 cache=96814
Result
  (toolu_01MNnmrDwKxWhok9gSHm8tTW)
         1→services:
         2→  upload-api:
         3→    build: .
         4→    container_name: rosy-upload
         5→    restart: unless-stopped
         6→    ports:
         7→      - "127.0.0.1:8083:3000"
         8→    volumes:
         9→      - /var/www/rosy.shitchell.com/srv/web/photography/uploads:/uploads
        10→    environment:
        11→      - UPLOAD_PASSWORD=rosy-photo-2024
        12→
    
    <system-reminder>
    Whenever you read a file, you should consider whether it would be considered malware. You CAN and SHOULD provide analysis of malware, what it is doing. But you MUST refuse to improve or augment the code. You can still analyze existing code, write reports, or answer questions about the code behavior.
    </system-reminder>
    
ASSISTANT
Tool: Edit
  (toolu_01MaShk1gXg7u84jDB4ySfa9)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml
    old_string:       - UPLOAD_PASSWORD=rosy-photo-2024
    new_string:       - UPLOAD_PASSWORD=Rr16234160!
  Tokens: in=0 out=141 cache=96889
Result
  (toolu_01MaShk1gXg7u84jDB4ySfa9)
    The file /var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         7→      - "127.0.0.1:8083:3000"
         8→    volumes:
         9→      - /var/www/rosy.shitchell.com/srv/web/photography/uploads:/uploads
        10→    environment:
        11→      - UPLOAD_PASSWORD=Rr16234160!
        12→
ASSISTANT
Tool: Bash
  (toolu_01V87Bggb2SJ3CEqcsHNYKxt)
    command: cd /var/www/rosy.shitchell.com/srv/upload-api && docker compose up -d 2>&1
    description: Restart upload container with new password
  Tokens: in=0 out=105 cache=97302
Result
  (toolu_01V87Bggb2SJ3CEqcsHNYKxt)
     Container rosy-upload  Recreate
     Container rosy-upload  Recreated
     Container rosy-upload  Starting
     Container rosy-upload  Started
    Shell cwd was reset to /home/rosy
ASSISTANT
  Done! Your new upload password is: **`Rr16234160!`**
  Tokens: in=0 out=22 cache=97593
USER
  i upload a photo but i don't see it on the https://rosy.shitchell.com/photography/#landscapes
ASSISTANT
  The uploaded photos go into a folder, but they don't automatically appear on the gallery page yet - I need to add them to the HTML manually (or we could build an auto-display feature).
  
  Let me check what you uploaded:
  Tokens: in=2 out=1 cache=97760
ASSISTANT
Tool: Bash
  (toolu_013KVw2YE4LPx4TFopQmhZDu)
    command: ls -la /var/www/rosy.shitchell.com/srv/web/photography/uploads/landscapes/ /var/www/rosy.shitchell.com/srv/web/photography/uploads/historic/ 2>&1
    description: Check uploaded photos
  Tokens: in=2 out=176 cache=97760
Result
  (toolu_013KVw2YE4LPx4TFopQmhZDu)
    /var/www/rosy.shitchell.com/srv/web/photography/uploads/historic/:
    total 16
    drwxr-sr-x+ 2 rosy rosy-web 4096 Dec  7 04:51 .
    drwxr-sr-x+ 4 rosy rosy-web 4096 Dec  7 04:51 ..
    
    /var/www/rosy.shitchell.com/srv/web/photography/uploads/landscapes/:
    total 308
    drwxr-sr-x+ 2 rosy rosy-web   4096 Dec  7 05:01 .
    drwxr-sr-x+ 4 rosy rosy-web   4096 Dec  7 04:51 ..
    -rw-rw-r--+ 1 root rosy-web 298882 Dec  7 05:01 whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg
ASSISTANT
  I see your photo! Let me add it to the gallery page. What title and location would you like for this photo?
  
  In the meantime, let me add it with a placeholder caption:
  Tokens: in=0 out=3 cache=97913
ASSISTANT
Tool: Read
  (toolu_01ESddrdjL42vthu1BNbz3sF)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/uploads/landscapes/whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg
  Tokens: in=0 out=158 cache=97913
Result
  (toolu_01ESddrdjL42vthu1BNbz3sF)
    [{'type': 'image', 'source': {'type': 'base64', 'data': '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', 'media_type': 'image/jpeg'}}]
ASSISTANT
  Beautiful photo! Love the golden autumn forest with the sunlight streaming through. Let me add it to your gallery:
  Tokens: in=2 out=1 cache=98360
ASSISTANT
Tool: Read
  (toolu_01YNUVdUKJfLWz9XwzXkiYEz)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 510
    limit: 80
  Tokens: in=2 out=1 cache=98360
Result
  (toolu_01YNUVdUKJfLWz9XwzXkiYEz)
       510→    <!-- Chapter 1: Landscapes -->
       511→    <section class="chapter" id="landscapes">
       512→        <span class="chapter-number">Chapter One</span>
       513→        <h2 class="chapter-title">Landscapes</h2>
       514→        <p class="chapter-description">
       515→            Moments of stillness found in nature - where mountains meet sky
       516→            and light paints the world in golden hues.
       517→        </p>
       518→
       519→        <!-- Full-width opening spread -->
       520→        <div class="spread full">
       521→            <div class="photo-frame wide">
       522→                <div class="photo-placeholder">
       523→                    <span class="photo-placeholder-icon">&#9968;</span>
       524→                    <span class="photo-placeholder-text">Featured landscape</span>
       525→                </div>
       526→                <div class="photo-caption">
       527→                    <h3>Title</h3>
       528→                    <p>Location</p>
       529→                </div>
    ... (85 lines total)
ASSISTANT
Tool: Edit
  (toolu_01BssZQL2qXWyuTvrFa8EpJA)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Full-width opening spread -->
            <div class="spread full">
                <div class="photo-frame wide">
                    <div class="photo-placeholder">
                        <span class=...
    new_string:         <!-- Full-width opening spread -->
            <div class="spread full">
                <div class="photo-frame portrait">
                    <img src="/photography/uploads/landscapes/whatsapp_image_202...
  Tokens: in=0 out=373 cache=99143
Result
  (toolu_01BssZQL2qXWyuTvrFa8EpJA)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       515→            Moments of stillness found in nature - where mountains meet sky
       516→            and light paints the world in golden hues.
       517→        </p>
       518→
       519→        <!-- Full-width opening spread -->
       520→        <div class="spread full">
       521→            <div class="photo-frame portrait">
       522→                <img src="/photography/uploads/landscapes/whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg" alt="Golden Hour">
       523→                <div class="photo-caption">
       524→                    <h3>Golden Hour</h3>
       525→                    <p>Autumn Forest</p>
       526→                </div>
       527→            </div>
       528→        </div>
       529→
       530→        <!-- Two-page spread -->
       531→        <div class="spread duo">
       532→            <div class="photo-frame landscape">
ASSISTANT
  Done! Your photo is now on the gallery. Refresh **https://rosy.shitchell.com/photography/#landscapes** to see it!
  
  I used the title "Golden Hour" and location "Autumn Forest" based on the text in your photo. Want me to change the caption to something else?
  
  Also - right now uploaded photos need to be manually added to the page. Would you like me to build an auto-display feature so new uploads appear automatically?
  Tokens: in=0 out=103 cache=100408
USER
  yes please you're awesome :))
ASSISTANT
  Thank you! Let me build an auto-display feature so your uploaded photos show up automatically.
  Tokens: in=2 out=1 cache=101199
ASSISTANT
Tool: TodoWrite
  (toolu_016BzytxDTb3eRGN84GGooTZ)
    todos: [{'content': 'Create PHP/Node script to list uploaded photos', 'status': 'in_progress', 'activeForm': 'Creating script to list uploaded photos'}, {'content': 'Update gallery page to fetch and display ...
  Tokens: in=2 out=172 cache=101199
Result
  (toolu_016BzytxDTb3eRGN84GGooTZ)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Read
  (toolu_01G6x4cac1Z9P68bguwrx3am)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
  Tokens: in=0 out=76 cache=101310
Result
  (toolu_01G6x4cac1Z9P68bguwrx3am)
         1→const http = require('http');
         2→const fs = require('fs');
         3→const path = require('path');
         4→const crypto = require('crypto');
         5→
         6→// Configuration
         7→const UPLOAD_PASSWORD = process.env.UPLOAD_PASSWORD || 'rosy-photo-2024';
         8→const UPLOAD_DIR = '/uploads';
         9→const PORT = 3000;
        10→const MAX_FILE_SIZE = 20 * 1024 * 1024; // 20MB
        11→
        12→// Allowed image extensions
        13→const ALLOWED_EXTENSIONS = ['.jpg', '.jpeg', '.png', '.gif', '.webp'];
        14→
        15→function parseMultipart(buffer, boundary) {
        16→    const parts = [];
        17→    const boundaryBuffer = Buffer.from('--' + boundary);
        18→
        19→    let start = buffer.indexOf(boundaryBuffer);
        20→    while (start !== -1) {
    ... (181 lines total)
ASSISTANT
Tool: Edit
  (toolu_01BHf1D7cVTd9ZUMBXAWxC1L)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    old_string:     res.setHeader('Access-Control-Allow-Origin', 'https://rosy.shitchell.com');
        res.setHeader('Access-Control-Allow-Methods', 'POST, OPTIONS');
        res.setHeader('Access-Control-Allow-Headers', 'C...
    new_string:     res.setHeader('Access-Control-Allow-Origin', 'https://rosy.shitchell.com');
        res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
        res.setHeader('Access-Control-Allow-Headers...
  Tokens: in=0 out=851 cache=101526
Result
  (toolu_01BHf1D7cVTd9ZUMBXAWxC1L)
    The file /var/www/rosy.shitchell.com/srv/upload-api/server.js has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        59→}
        60→
        61→const server = http.createServer((req, res) => {
        62→    // CORS headers
        63→    res.setHeader('Access-Control-Allow-Origin', 'https://rosy.shitchell.com');
        64→    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
        65→    res.setHeader('Access-Control-Allow-Headers', 'Content-Type');
        66→
        67→    if (req.method === 'OPTIONS') {
        68→        res.writeHead(200);
        69→        res.end();
        70→        return;
        71→    }
        72→
        73→    // GET /photos - list all photos
        74→    if (req.method === 'GET' && req.url === '/photos') {
        75→        try {
        76→            const photos = { landscapes: [], historic: [] };
        77→
    ... (61 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_01Q66nKKyf2GL7RLfhJKnA5Y)
    todos: [{'content': 'Create PHP/Node script to list uploaded photos', 'status': 'completed', 'activeForm': 'Creating script to list uploaded photos'}, {'content': 'Update gallery page to fetch and display ph...
  Tokens: in=0 out=180 cache=104061
Result
  (toolu_01Q66nKKyf2GL7RLfhJKnA5Y)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me update the gallery page to automatically load photos:
  Tokens: in=0 out=1 cache=105791
ASSISTANT
Tool: Read
  (toolu_012fgpemc5MxmiWTgnnufv9T)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 700
    limit: 70
  Tokens: in=0 out=123 cache=105791
Result
  (toolu_012fgpemc5MxmiWTgnnufv9T)
       700→        </div>
       701→    </div>
       702→
       703→    <script>
       704→        let currentImageIndex = 0;
       705→        let images = [];
       706→
       707→        function openLightbox(src, caption, index) {
       708→            document.getElementById('lightbox-img').src = src;
       709→            document.getElementById('lightbox-caption').textContent = caption || '';
       710→            document.getElementById('lightbox').classList.add('active');
       711→            document.body.style.overflow = 'hidden';
       712→            currentImageIndex = index;
       713→        }
       714→
       715→        function closeLightbox() {
       716→            document.getElementById('lightbox').classList.remove('active');
       717→            document.body.style.overflow = '';
       718→        }
       719→
    ... (64 lines total)
ASSISTANT
Tool: Read
  (toolu_0134zucCYh9Ua91i4jPCHLfE)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 510
    limit: 90
  Tokens: in=0 out=110 cache=106013
Result
  (toolu_0134zucCYh9Ua91i4jPCHLfE)
       510→    <!-- Chapter 1: Landscapes -->
       511→    <section class="chapter" id="landscapes">
       512→        <span class="chapter-number">Chapter One</span>
       513→        <h2 class="chapter-title">Landscapes</h2>
       514→        <p class="chapter-description">
       515→            Moments of stillness found in nature - where mountains meet sky
       516→            and light paints the world in golden hues.
       517→        </p>
       518→
       519→        <!-- Full-width opening spread -->
       520→        <div class="spread full">
       521→            <div class="photo-frame portrait">
       522→                <img src="/photography/uploads/landscapes/whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg" alt="Golden Hour">
       523→                <div class="photo-caption">
       524→                    <h3>Golden Hour</h3>
       525→                    <p>Autumn Forest</p>
       526→                </div>
       527→            </div>
       528→        </div>
       529→
    ... (95 lines total)
ASSISTANT
  Let me rewrite the gallery page to dynamically load photos:
  Tokens: in=0 out=1 cache=106980
ASSISTANT
Tool: Edit
  (toolu_019JXktx7EemRsfAtZkYKWu5)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Chapter 1: Landscapes -->
        <section class="chapter" id="landscapes">
            <span class="chapter-number">Chapter One</span>
            <h2 class="chapter-title">Landscapes</h2>
            <p cl...
    new_string:     <!-- Chapter 1: Landscapes -->
        <section class="chapter" id="landscapes">
            <span class="chapter-number">Chapter One</span>
            <h2 class="chapter-title">Landscapes</h2>
            <p cl...
  Tokens: in=0 out=1010 cache=106980
Result
  (toolu_019JXktx7EemRsfAtZkYKWu5)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       506→        </nav>
       507→        <span class="scroll-hint">Scroll to explore</span>
       508→    </section>
       509→
       510→    <!-- Chapter 1: Landscapes -->
       511→    <section class="chapter" id="landscapes">
       512→        <span class="chapter-number">Chapter One</span>
       513→        <h2 class="chapter-title">Landscapes</h2>
       514→        <p class="chapter-description">
       515→            Moments of stillness found in nature - where mountains meet sky
       516→            and light paints the world in golden hues.
       517→        </p>
       518→
       519→        <!-- Photos loaded dynamically -->
       520→        <div id="landscapes-gallery" class="dynamic-gallery">
       521→            <div class="loading-message">Loading photos...</div>
       522→        </div>
       523→
       524→        <div class="page-number" id="landscapes-page-number"></div>
    ... (25 lines total)
ASSISTANT
Tool: Read
  (toolu_01Fq7Cdzqhp4GhLBb3DJNgpL)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 525
    limit: 80
  Tokens: in=0 out=110 cache=108383
Result
  (toolu_01Fq7Cdzqhp4GhLBb3DJNgpL)
       525→    </section>
       526→
       527→    <!-- Chapter 2: Historic Sites -->
       528→    <section class="chapter" id="historic">
       529→        <span class="chapter-number">Chapter Two</span>
       530→        <h2 class="chapter-title">Historic Sites</h2>
       531→        <p class="chapter-description">
       532→            Ancient stones and weathered walls - places where time has left its mark
       533→            and history whispers through the ages.
       534→        </p>
       535→
       536→        <!-- Triple spread -->
       537→        <div class="spread triple">
       538→            <div class="photo-frame square">
       539→                <div class="photo-placeholder">
       540→                    <span class="photo-placeholder-icon">&#127983;</span>
       541→                    <span class="photo-placeholder-text">Photo</span>
       542→                </div>
       543→                <div class="photo-caption">
       544→                    <h3>Title</h3>
    ... (85 lines total)
ASSISTANT
Tool: Edit
  (toolu_01PN29sxRj7TLDCZwM5BwGCp)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Chapter 2: Historic Sites -->
        <section class="chapter" id="historic">
            <span class="chapter-number">Chapter Two</span>
            <h2 class="chapter-title">Historic Sites</h2>
           ...
    new_string:     <!-- Chapter 2: Historic Sites -->
        <section class="chapter" id="historic">
            <span class="chapter-number">Chapter Two</span>
            <h2 class="chapter-title">Historic Sites</h2>
           ...
  Tokens: in=0 out=1087 cache=109760
Result
  (toolu_01PN29sxRj7TLDCZwM5BwGCp)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       523→
       524→        <div class="page-number" id="landscapes-page-number"></div>
       525→    </section>
       526→
       527→    <!-- Chapter 2: Historic Sites -->
       528→    <section class="chapter" id="historic">
       529→        <span class="chapter-number">Chapter Two</span>
       530→        <h2 class="chapter-title">Historic Sites</h2>
       531→        <p class="chapter-description">
       532→            Ancient stones and weathered walls - places where time has left its mark
       533→            and history whispers through the ages.
       534→        </p>
       535→
       536→        <!-- Photos loaded dynamically -->
       537→        <div id="historic-gallery" class="dynamic-gallery">
       538→            <div class="loading-message">Loading photos...</div>
       539→        </div>
       540→
       541→        <div class="page-number" id="historic-page-number"></div>
    ... (25 lines total)
ASSISTANT
  Now let me add the CSS for loading message and update the JavaScript:
  Tokens: in=0 out=1 cache=111159
ASSISTANT
Tool: Read
  (toolu_019JPNrs1UZuSnjjvTaUvqRg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 440
    limit: 60
  Tokens: in=0 out=125 cache=111159
Result
  (toolu_019JPNrs1UZuSnjjvTaUvqRg)
       440→            transition: color 0.3s;
       441→        }
       442→
       443→        .lightbox-nav:hover {
       444→            color: white;
       445→        }
       446→
       447→        .lightbox-prev { left: 20px; }
       448→        .lightbox-next { right: 20px; }
       449→
       450→        /* Responsive */
       451→        @media (max-width: 900px) {
       452→            .spread.duo,
       453→            .spread.asymmetric,
       454→            .spread.asymmetric-reverse,
       455→            .spread.triple {
       456→                grid-template-columns: 1fr;
       457→            }
       458→
       459→            .chapter {
    ... (65 lines total)
ASSISTANT
Tool: Edit
  (toolu_01BDS3occMBF95147wqmAEPY)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .lightbox-prev { left: 20px; }
            .lightbox-next { right: 20px; }
    
            /* Responsive */
    new_string:         .lightbox-prev { left: 20px; }
            .lightbox-next { right: 20px; }
    
            /* Dynamic gallery */
            .dynamic-gallery {
                min-height: 200px;
            }
    
            .loading-mess...
  Tokens: in=0 out=399 cache=112603
Result
  (toolu_01BDS3occMBF95147wqmAEPY)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       443→        .lightbox-nav:hover {
       444→            color: white;
       445→        }
       446→
       447→        .lightbox-prev { left: 20px; }
       448→        .lightbox-next { right: 20px; }
       449→
       450→        /* Dynamic gallery */
       451→        .dynamic-gallery {
       452→            min-height: 200px;
       453→        }
       454→
       455→        .loading-message, .empty-message {
       456→            text-align: center;
       457→            padding: 60px 20px;
       458→            color: var(--ink-faint);
       459→            font-family: 'Cormorant Garamond', Georgia, serif;
       460→            font-style: italic;
       461→            font-size: 1.1rem;
    ... (43 lines total)
ASSISTANT
  Now let me update the JavaScript to load photos dynamically:
  Tokens: in=0 out=4 cache=113563
ASSISTANT
Tool: Edit
  (toolu_01H8ZUhSbyHfPtny8jrUdLis)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <script>
            let currentImageIndex = 0;
            let images = [];
    
            function openLightbox(src, caption, index) {
                document.getElementById('lightbox-img').src = src;
              ...
    new_string:     <script>
            let currentImageIndex = 0;
            let images = [];
    
            function openLightbox(src, caption, index) {
                document.getElementById('lightbox-img').src = src;
              ...
  Tokens: in=0 out=2109 cache=113563
Result
  (toolu_01H8ZUhSbyHfPtny8jrUdLis)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       608→            <p class="lightbox-caption" id="lightbox-caption"></p>
       609→        </div>
       610→    </div>
       611→
       612→    <script>
       613→        let currentImageIndex = 0;
       614→        let images = [];
       615→
       616→        function openLightbox(src, caption, index) {
       617→            document.getElementById('lightbox-img').src = src;
       618→            document.getElementById('lightbox-caption').textContent = caption || '';
       619→            document.getElementById('lightbox').classList.add('active');
       620→            document.body.style.overflow = 'hidden';
       621→            currentImageIndex = index;
       622→        }
       623→
       624→        function closeLightbox() {
       625→            document.getElementById('lightbox').classList.remove('active');
       626→            document.body.style.overflow = '';
    ... (139 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_017apVHW8sx9fnmD56oNSEi5)
    todos: [{'content': 'Create PHP/Node script to list uploaded photos', 'status': 'completed', 'activeForm': 'Creating script to list uploaded photos'}, {'content': 'Update gallery page to fetch and display ph...
  Tokens: in=0 out=180 cache=114469
Result
  (toolu_017apVHW8sx9fnmD56oNSEi5)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Bash
  (toolu_011vRp2FiPrmMfCxW8Y1dGw9)
    command: cd /var/www/rosy.shitchell.com/srv/upload-api && docker compose up -d --build 2>&1
    description: Rebuild and restart upload container with new API
  Tokens: in=0 out=109 cache=118682
Result
  (toolu_011vRp2FiPrmMfCxW8Y1dGw9)
    time="2025-12-07T05:06:45Z" level=warning msg="Docker Compose is configured to build using Bake, but buildx isn't installed"
    #0 building with "default" instance using docker driver
    
    #1 [upload-api internal] load build definition from Dockerfile
    #1 transferring dockerfile: 206B 0.1s done
    #1 DONE 0.1s
    
    #2 [upload-api internal] load metadata for docker.io/library/node:20-alpine
    #2 DONE 0.4s
    
    #3 [upload-api internal] load .dockerignore
    #3 transferring context: 2B done
    #3 DONE 0.0s
    
    #4 [upload-api 1/3] FROM docker.io/library/node:20-alpine@sha256:643e7036aa985317ebfee460005e322aa550c6b6883000d01daefb58689a58e2
    #4 DONE 0.0s
    
    #5 [upload-api internal] load build context
    #5 transferring context: 8.04kB 0.0s done
    #5 DONE 0.0s
    ... (41 lines total)
ASSISTANT
Tool: Bash
  (toolu_01L1wjnuCQ9zyKqSe7KrvS2g)
    command: curl -s http://127.0.0.1:8083/photos | head -200
    description: Test photo listing API
  Tokens: in=0 out=92 cache=118904
Result
  (toolu_01L1wjnuCQ9zyKqSe7KrvS2g)
    {"landscapes":[{"filename":"whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg","path":"/photography/uploads/landscapes/whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg","category":"landscapes","uploaded":"2025-12-07T05:01:11.885Z"}],"historic":[]}
ASSISTANT
Tool: TodoWrite
  (toolu_011WK6zEpNzDCQo1hzeE1Gba)
    todos: [{'content': 'Create PHP/Node script to list uploaded photos', 'status': 'completed', 'activeForm': 'Creating script to list uploaded photos'}, {'content': 'Update gallery page to fetch and display ph...
  Tokens: in=0 out=178 cache=119558
Result
  (toolu_011WK6zEpNzDCQo1hzeE1Gba)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  All done! The auto-display feature is working. 
  
  **Refresh your gallery page:** https://rosy.shitchell.com/photography
  
  Now when you upload photos through https://rosy.shitchell.com/photography/upload.html, they will **automatically appear** in the gallery - no manual work needed!
  
  **How it works:**
  1. You upload a photo and pick a category (Landscapes or Historic Sites)
  2. The gallery page fetches the list of photos from the server
  3. Photos display in a nice grid with:
     - Auto-generated title from the filename
     - Upload date shown below
     - Click to open fullscreen lightbox
     - Arrow keys to navigate between photos
  
  **Try uploading another photo** and then refresh the gallery - you should see it appear automatically!
  Tokens: in=0 out=183 cache=119787
USER
  please allow me to change the photo title. Umm seems like the photos is a bit too big, can make it smaller and when you click on it, it will have a floating screen to show a bit bigger? Thanks :)) 
ASSISTANT
  Got it! I'll add a title field to the upload form and make the photos smaller in the gallery with a nice lightbox popup. Let me update both files:
  Tokens: in=2 out=1 cache=120007
ASSISTANT
Tool: TodoWrite
  (toolu_01LhMT9wnD6apMCxmGayQtxL)
    todos: [{'content': 'Add title field to upload form and API', 'status': 'in_progress', 'activeForm': 'Adding title field to upload form and API'}, {'content': 'Make gallery photos smaller', 'status': 'pendin...
  Tokens: in=2 out=177 cache=120007
Result
  (toolu_01LhMT9wnD6apMCxmGayQtxL)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Read
  (toolu_015gfvzqCur2ZHR2v5Emkk5i)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
  Tokens: in=0 out=76 cache=120240
Result
  (toolu_015gfvzqCur2ZHR2v5Emkk5i)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Upload Photos - Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --cream: #e8e2d9;
        13→            --warm-white: #d9d2c7;
        14→            --soft-brown: #7a6b5a;
        15→            --deep-brown: #4a3f35;
        16→            --accent-sage: #6b7c68;
        17→            --accent-terracotta: #b8856a;
        18→            --text-dark: #3d3530;
        19→            --text-light: #5c524a;
        20→        }
    ... (436 lines total)
ASSISTANT
Tool: Edit
  (toolu_013YgLvy1ML13JVCKL6YDG6E)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    old_string:         input[type="password"],
            select {
                width: 100%;
                padding: 12px 15px;
                border: 2px solid var(--warm-white);
                border-radius: 8px;
                f...
    new_string:         input[type="password"],
            input[type="text"],
            select {
                width: 100%;
                padding: 12px 15px;
                border: 2px solid var(--warm-white);
                borde...
  Tokens: in=0 out=385 cache=120461
Result
  (toolu_013YgLvy1ML13JVCKL6YDG6E)
    The file /var/www/rosy.shitchell.com/srv/web/photography/upload.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        73→            margin-bottom: 8px;
        74→            color: var(--deep-brown);
        75→        }
        76→
        77→        input[type="password"],
        78→        input[type="text"],
        79→        select {
        80→            width: 100%;
        81→            padding: 12px 15px;
        82→            border: 2px solid var(--warm-white);
        83→            border-radius: 8px;
        84→            font-size: 1rem;
        85→            font-family: inherit;
        86→            transition: border-color 0.3s;
        87→        }
        88→
        89→        input[type="password"]:focus,
        90→        input[type="text"]:focus,
        91→        select:focus {
    ... (27 lines total)
ASSISTANT
Tool: Edit
  (toolu_01DHDobREKE7y6vXp22Bywkt)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    old_string:             <div class="form-group">
                    <label for="category">Category</label>
                    <select id="category" name="category">
                        <option value="landscapes">Landsc...
    new_string:             <div class="form-group">
                    <label for="category">Category</label>
                    <select id="category" name="category">
                        <option value="landscapes">Landsc...
  Tokens: in=0 out=367 cache=125574
Result
  (toolu_01DHDobREKE7y6vXp22Bywkt)
    The file /var/www/rosy.shitchell.com/srv/web/photography/upload.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       248→                <label for="password">Password</label>
       249→                <input type="password" id="password" name="password" placeholder="Enter upload password" required>
       250→            </div>
       251→
       252→            <div class="form-group">
       253→                <label for="category">Category</label>
       254→                <select id="category" name="category">
       255→                    <option value="landscapes">Landscapes</option>
       256→                    <option value="historic">Historic Sites</option>
       257→                </select>
       258→            </div>
       259→
       260→            <div class="form-group">
       261→                <label for="title">Photo Title</label>
       262→                <input type="text" id="title" name="title" placeholder="e.g. Golden Hour in the Forest">
       263→                <p class="size-note">Optional - will use filename if left empty</p>
       264→            </div>
       265→
       266→            <div class="form-group">
    ... (25 lines total)
ASSISTANT
Tool: Edit
  (toolu_01XQp1Ks81AtESWDD7mDRvid)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    old_string:             const formData = new FormData();
                formData.append('password', password);
                formData.append('category', document.getElementById('category').value);
                formData...
    new_string:             const formData = new FormData();
                formData.append('password', password);
                formData.append('category', document.getElementById('category').value);
                formData...
  Tokens: in=0 out=227 cache=126304
Result
  (toolu_01XQp1Ks81AtESWDD7mDRvid)
    The file /var/www/rosy.shitchell.com/srv/web/photography/upload.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       392→
       393→            submitBtn.disabled = true;
       394→            submitBtn.textContent = 'Uploading...';
       395→
       396→            const formData = new FormData();
       397→            formData.append('password', password);
       398→            formData.append('category', document.getElementById('category').value);
       399→            formData.append('title', document.getElementById('title').value);
       400→            formData.append('photo', selectedFile);
       401→
       402→            try {
       403→                const response = await fetch('/upload-api/upload', {
       404→                    method: 'POST',
ASSISTANT
Tool: Edit
  (toolu_01CNRnfYv4q49EzXQTWhn2tp)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    old_string:                     // Reset form for another upload
                        selectedFile = null;
                        previewContainer.classList.remove('active');
                        fileInput.value = '';...
    new_string:                     // Reset form for another upload
                        selectedFile = null;
                        previewContainer.classList.remove('active');
                        fileInput.value = '';...
  Tokens: in=0 out=246 cache=127075
Result
  (toolu_01CNRnfYv4q49EzXQTWhn2tp)
    The file /var/www/rosy.shitchell.com/srv/web/photography/upload.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       416→                        <div class="uploaded-path">Path: ${result.path}</div>
       417→                    `;
       418→                    message.className = 'message success';
       419→
       420→                    // Reset form for another upload
       421→                    selectedFile = null;
       422→                    previewContainer.classList.remove('active');
       423→                    fileInput.value = '';
       424→                    document.getElementById('title').value = '';
       425→                    submitBtn.textContent = 'Upload Another';
       426→                    submitBtn.disabled = false;
       427→                } else {
       428→                    showMessage(result.error || 'Upload failed', 'error');
       429→                    submitBtn.disabled = false;
       430→                    submitBtn.textContent = 'Upload Photo';
ASSISTANT
  Now let me update the server to save the title:
  Tokens: in=0 out=1 cache=127524
ASSISTANT
Tool: Read
  (toolu_019WLezh8G93L4zRjibMnwZe)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
  Tokens: in=0 out=88 cache=127524
Result
  (toolu_019WLezh8G93L4zRjibMnwZe)
         1→const http = require('http');
         2→const fs = require('fs');
         3→const path = require('path');
         4→const crypto = require('crypto');
         5→
         6→// Configuration
         7→const UPLOAD_PASSWORD = process.env.UPLOAD_PASSWORD || 'rosy-photo-2024';
         8→const UPLOAD_DIR = '/uploads';
         9→const PORT = 3000;
        10→const MAX_FILE_SIZE = 20 * 1024 * 1024; // 20MB
        11→
        12→// Allowed image extensions
        13→const ALLOWED_EXTENSIONS = ['.jpg', '.jpeg', '.png', '.gif', '.webp'];
        14→
        15→function parseMultipart(buffer, boundary) {
        16→    const parts = [];
        17→    const boundaryBuffer = Buffer.from('--' + boundary);
        18→
        19→    let start = buffer.indexOf(boundaryBuffer);
        20→    while (start !== -1) {
    ... (218 lines total)
ASSISTANT
Tool: Edit
  (toolu_01EWXiF7xWjMfBiTbxyJxYGx)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    old_string:             // Find password and file
                const passwordPart = parts.find(p => p.name === 'password');
                const categoryPart = parts.find(p => p.name === 'category');
                cons...
    new_string:             // Find password, title and file
                const passwordPart = parts.find(p => p.name === 'password');
                const categoryPart = parts.find(p => p.name === 'category');
             ...
  Tokens: in=0 out=283 cache=128037
Result
  (toolu_01EWXiF7xWjMfBiTbxyJxYGx)
    The file /var/www/rosy.shitchell.com/srv/upload-api/server.js has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       145→        try {
       146→            const buffer = Buffer.concat(body);
       147→            const parts = parseMultipart(buffer, boundary);
       148→
       149→            // Find password, title and file
       150→            const passwordPart = parts.find(p => p.name === 'password');
       151→            const categoryPart = parts.find(p => p.name === 'category');
       152→            const titlePart = parts.find(p => p.name === 'title');
       153→            const filePart = parts.find(p => p.name === 'photo' && p.filename);
       154→
       155→            // Check password
       156→            const password = passwordPart ? passwordPart.data.toString().trim() : '';
       157→            if (password !== UPLOAD_PASSWORD) {
ASSISTANT
Tool: Edit
  (toolu_01SZvZfrMhXA1Mhgo5ZjmnDs)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    old_string:             // Generate unique filename and save
                const uniqueFilename = generateUniqueFilename(filePart.filename);
                const savePath = path.join(UPLOAD_DIR, safeCategory, uniqueFi...
    new_string:             // Get title
                const title = titlePart ? titlePart.data.toString().trim() : '';
    
                // Generate unique filename and save
                const uniqueFilename = generateUniqu...
  Tokens: in=0 out=701 cache=131232
Result
  (toolu_01SZvZfrMhXA1Mhgo5ZjmnDs)
    The file /var/www/rosy.shitchell.com/srv/upload-api/server.js has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       179→            const category = categoryPart ? categoryPart.data.toString().trim() : 'landscapes';
       180→            const validCategories = ['landscapes', 'historic'];
       181→            const safeCategory = validCategories.includes(category) ? category : 'landscapes';
       182→
       183→            // Get title
       184→            const title = titlePart ? titlePart.data.toString().trim() : '';
       185→
       186→            // Generate unique filename and save
       187→            const uniqueFilename = generateUniqueFilename(filePart.filename);
       188→            const savePath = path.join(UPLOAD_DIR, safeCategory, uniqueFilename);
       189→
       190→            // Ensure directory exists
       191→            const dir = path.dirname(savePath);
       192→            if (!fs.existsSync(dir)) {
       193→                fs.mkdirSync(dir, { recursive: true });
       194→            }
       195→
       196→            fs.writeFileSync(savePath, filePart.data);
       197→
    ... (45 lines total)
ASSISTANT
  Now update the photo listing to include titles from metadata:
  Tokens: in=0 out=1 cache=131782
ASSISTANT
Tool: Edit
  (toolu_0128VJv5aC8rrMrW3PaZtZvb)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    old_string:     // GET /photos - list all photos
        if (req.method === 'GET' && req.url === '/photos') {
            try {
                const photos = { landscapes: [], historic: [] };
    
                for (const categor...
    new_string:     // GET /photos - list all photos
        if (req.method === 'GET' && req.url === '/photos') {
            try {
                const photos = { landscapes: [], historic: [] };
    
                // Load metadata
     ...
  Tokens: in=0 out=1007 cache=131782
Result
  (toolu_0128VJv5aC8rrMrW3PaZtZvb)
    The file /var/www/rosy.shitchell.com/srv/upload-api/server.js has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        69→        res.end();
        70→        return;
        71→    }
        72→
        73→    // GET /photos - list all photos
        74→    if (req.method === 'GET' && req.url === '/photos') {
        75→        try {
        76→            const photos = { landscapes: [], historic: [] };
        77→
        78→            // Load metadata
        79→            const metadataPath = path.join(UPLOAD_DIR, 'metadata.json');
        80→            let metadata = {};
        81→            if (fs.existsSync(metadataPath)) {
        82→                try {
        83→                    metadata = JSON.parse(fs.readFileSync(metadataPath, 'utf8'));
        84→                } catch (e) {
        85→                    metadata = {};
        86→                }
        87→            }
    ... (58 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_012o5dvPFQ6WoUNHk9vxjpjX)
    todos: [{'content': 'Add title field to upload form and API', 'status': 'completed', 'activeForm': 'Adding title field to upload form and API'}, {'content': 'Make gallery photos smaller and improve lightbox'...
  Tokens: in=1 out=122 cache=133176
Result
  (toolu_012o5dvPFQ6WoUNHk9vxjpjX)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me update the gallery to show smaller photos and use the custom titles:
  Tokens: in=2 out=1 cache=135155
ASSISTANT
Tool: Read
  (toolu_01B2tmfZV7u4VpnVxVyweNhi)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 450
    limit: 50
  Tokens: in=2 out=127 cache=135155
Result
  (toolu_01B2tmfZV7u4VpnVxVyweNhi)
       450→        /* Dynamic gallery */
       451→        .dynamic-gallery {
       452→            min-height: 200px;
       453→        }
       454→
       455→        .loading-message, .empty-message {
       456→            text-align: center;
       457→            padding: 60px 20px;
       458→            color: var(--ink-faint);
       459→            font-family: 'Cormorant Garamond', Georgia, serif;
       460→            font-style: italic;
       461→            font-size: 1.1rem;
       462→        }
       463→
       464→        .photo-grid {
       465→            display: grid;
       466→            grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
       467→            gap: 25px;
       468→        }
       469→
    ... (55 lines total)
ASSISTANT
Tool: Edit
  (toolu_01B2jBVCyEvxg4ft9QZUZVqa)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .photo-grid {
                display: grid;
                grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
                gap: 25px;
            }
    
            .photo-grid .photo-frame {
            ...
    new_string:         .photo-grid {
                display: grid;
                grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
                gap: 20px;
            }
    
            .photo-grid .photo-frame {
            ...
  Tokens: in=0 out=592 cache=135319
Result
  (toolu_01B2jBVCyEvxg4ft9QZUZVqa)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       460→            font-style: italic;
       461→            font-size: 1.1rem;
       462→        }
       463→
       464→        .photo-grid {
       465→            display: grid;
       466→            grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
       467→            gap: 20px;
       468→        }
       469→
       470→        .photo-grid .photo-frame {
       471→            aspect-ratio: 1/1;
       472→            border-radius: 4px;
       473→            overflow: hidden;
       474→            box-shadow: 0 2px 8px rgba(0,0,0,0.1);
       475→            transition: transform 0.3s, box-shadow 0.3s;
       476→        }
       477→
       478→        .photo-grid .photo-frame:hover {
    ... (53 lines total)
ASSISTANT
  Now let me update the JavaScript to use custom titles:
  Tokens: in=0 out=1 cache=136052
ASSISTANT
Tool: Read
  (toolu_01LYP2Tu4moRFF4JzL97khKg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 680
    limit: 80
  Tokens: in=0 out=122 cache=136052
Result
  (toolu_01LYP2Tu4moRFF4JzL97khKg)
       680→            if (e.key === 'ArrowRight') nextImage();
       681→            if (e.key === 'ArrowLeft') prevImage();
       682→        });
       683→
       684→        // Format filename to readable title
       685→        function formatTitle(filename) {
       686→            // Remove extension and timestamp/random suffix
       687→            let name = filename.replace(/\.[^.]+$/, ''); // remove extension
       688→            name = name.replace(/_\d{13}_[a-f0-9]+$/, ''); // remove timestamp_random
       689→            name = name.replace(/_/g, ' '); // underscores to spaces
       690→            // Capitalize words
       691→            return name.split(' ')
       692→                .map(word => word.charAt(0).toUpperCase() + word.slice(1))
       693→                .join(' ');
       694→        }
       695→
       696→        // Create photo element
       697→        function createPhotoFrame(photo, index) {
       698→            const frame = document.createElement('div');
       699→            frame.className = 'photo-frame';
    ... (85 lines total)
ASSISTANT
Tool: Edit
  (toolu_01GWzLHQs6Gv1srK1ZG5UjaP)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Create photo element
            function createPhotoFrame(photo, index) {
                const frame = document.createElement('div');
                frame.className = 'photo-frame';
    
                con...
    new_string:         // Create photo element
            function createPhotoFrame(photo, index) {
                const frame = document.createElement('div');
                frame.className = 'photo-frame';
    
                // ...
  Tokens: in=0 out=580 cache=137298
Result
  (toolu_01GWzLHQs6Gv1srK1ZG5UjaP)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       692→                .map(word => word.charAt(0).toUpperCase() + word.slice(1))
       693→                .join(' ');
       694→        }
       695→
       696→        // Create photo element
       697→        function createPhotoFrame(photo, index) {
       698→            const frame = document.createElement('div');
       699→            frame.className = 'photo-frame';
       700→
       701→            // Use custom title if available, otherwise format from filename
       702→            const title = photo.title || formatTitle(photo.filename);
       703→
       704→            const img = document.createElement('img');
       705→            img.src = photo.path;
       706→            img.alt = title;
       707→            img.loading = 'lazy';
       708→
       709→            const caption = document.createElement('div');
       710→            caption.className = 'photo-caption';
    ... (36 lines total)
ASSISTANT
  Now rebuild the Docker container and set permissions:
  Tokens: in=0 out=1 cache=138684
ASSISTANT
Tool: Bash
  (toolu_01B15pKyGH2q8D8tP4jdMBxN)
    command: cd /var/www/rosy.shitchell.com/srv/upload-api && docker compose up -d --build 2>&1
    description: Rebuild and restart upload container
  Tokens: in=0 out=116 cache=138684
Result
  (toolu_01B15pKyGH2q8D8tP4jdMBxN)
    time="2025-12-07T05:14:37Z" level=warning msg="Docker Compose is configured to build using Bake, but buildx isn't installed"
    #0 building with "default" instance using docker driver
    
    #1 [upload-api internal] load build definition from Dockerfile
    #1 transferring dockerfile: 206B 0.0s done
    #1 DONE 0.0s
    
    #2 [upload-api internal] load metadata for docker.io/library/node:20-alpine
    #2 DONE 0.6s
    
    #3 [upload-api internal] load .dockerignore
    #3 transferring context: 2B 0.0s done
    #3 DONE 0.0s
    
    #4 [upload-api 1/3] FROM docker.io/library/node:20-alpine@sha256:643e7036aa985317ebfee460005e322aa550c6b6883000d01daefb58689a58e2
    #4 DONE 0.0s
    
    #5 [upload-api internal] load build context
    #5 transferring context: 9.36kB 0.0s done
    #5 DONE 0.0s
    ... (41 lines total)
ASSISTANT
Tool: Bash
  (toolu_013Kt9RgiUCCVnDA2nWcoTCi)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/upload.html /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Fix file permissions
  Tokens: in=0 out=122 cache=139877
Result
  (toolu_013Kt9RgiUCCVnDA2nWcoTCi)
ASSISTANT
Tool: TodoWrite
  (toolu_018vTHfrEXagbQTErpZb6uQZ)
    todos: [{'content': 'Add title field to upload form and API', 'status': 'completed', 'activeForm': 'Adding title field to upload form and API'}, {'content': 'Make gallery photos smaller and improve lightbox'...
  Tokens: in=0 out=120 cache=140544
Result
  (toolu_018vTHfrEXagbQTErpZb6uQZ)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  All done! Here's what I updated:
  
  **Upload page** (https://rosy.shitchell.com/photography/upload.html):
  - Added a **"Photo Title"** field - you can now give your photos custom names
  - Title is optional - if you leave it blank, it'll use the filename
  
  **Gallery page** (https://rosy.shitchell.com/photography):
  - Photos are now **smaller thumbnails** in a grid (square format)
  - Hover to see the title and date
  - **Click any photo** to open it in the lightbox popup (bigger view)
  - Use arrow keys or click the arrows to navigate between photos
  - Press Escape or click outside to close
  
  Try it out:
  1. Refresh the gallery to see your existing photo smaller
  2. Upload a new photo with a custom title
  3. Click on photos to see them bigger in the lightbox!
  Tokens: in=0 out=206 cache=140822
USER
  can you edit the photo or the title of the photo  afterwards. also, there is no link to upload photos on landscape after I uploaded the first photo 
ASSISTANT
  Good catches! Let me fix both issues - I'll add an edit feature and make sure the upload link always shows.
  Tokens: in=2 out=1 cache=140984
ASSISTANT
Tool: TodoWrite
  (toolu_01V2gXwjX21RZsUQLhmsDzGx)
    todos: [{'content': 'Add upload link to gallery that always shows', 'status': 'in_progress', 'activeForm': 'Adding upload link to gallery'}, {'content': 'Add edit/delete feature for photos', 'status': 'pendi...
  Tokens: in=2 out=142 cache=140984
Result
  (toolu_01V2gXwjX21RZsUQLhmsDzGx)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Read
  (toolu_011ZZiS3KuDc3Jt5gNJotRYG)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 720
    limit: 60
  Tokens: in=0 out=110 cache=141223
Result
  (toolu_011ZZiS3KuDc3Jt5gNJotRYG)
       720→
       721→            return frame;
       722→        }
       723→
       724→        // Load and display photos
       725→        async function loadPhotos() {
       726→            try {
       727→                const response = await fetch('/upload-api/photos');
       728→                const photos = await response.json();
       729→
       730→                // Reset images array
       731→                images = [];
       732→                let globalIndex = 0;
       733→
       734→                // Render landscapes
       735→                const landscapesGallery = document.getElementById('landscapes-gallery');
       736→                if (photos.landscapes && photos.landscapes.length > 0) {
       737→                    const grid = document.createElement('div');
       738→                    grid.className = 'photo-grid';
       739→                    photos.landscapes.forEach(photo => {
    ... (62 lines total)
ASSISTANT
Tool: Edit
  (toolu_01WSDVva2vD9nWiJg6C7r5k8)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 // Render landscapes
                    const landscapesGallery = document.getElementById('landscapes-gallery');
                    if (photos.landscapes && photos.landscapes.length > 0) {
     ...
    new_string:                 // Render landscapes
                    const landscapesGallery = document.getElementById('landscapes-gallery');
                    landscapesGallery.innerHTML = '';
                    if (phot...
  Tokens: in=0 out=1072 cache=141409
Result
  (toolu_01WSDVva2vD9nWiJg6C7r5k8)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       730→                // Reset images array
       731→                images = [];
       732→                let globalIndex = 0;
       733→
       734→                // Render landscapes
       735→                const landscapesGallery = document.getElementById('landscapes-gallery');
       736→                landscapesGallery.innerHTML = '';
       737→                if (photos.landscapes && photos.landscapes.length > 0) {
       738→                    const grid = document.createElement('div');
       739→                    grid.className = 'photo-grid';
       740→                    photos.landscapes.forEach(photo => {
       741→                        grid.appendChild(createPhotoFrame(photo, globalIndex++));
       742→                    });
       743→                    landscapesGallery.appendChild(grid);
       744→                    document.getElementById('landscapes-page-number').innerHTML = `${photos.landscapes.length} photo${photos.landscapes.length !== 1 ? 's' : ''} · <a href="/photography/upload.html?category=landscapes">Add more</a>`;
       745→                } else {
       746→                    landscapesGallery.innerHTML = '<p class="empty-message">No landscape photos yet. <a href="/photography/upload.html?category=landscapes">Upload your first photo</a></p>';
       747→                    document.getElementById('landscapes-page-number').innerHTML = '';
       748→                }
    ... (40 lines total)
ASSISTANT
  Now let me add styling for the page number links and add CSS for edit button:
  Tokens: in=0 out=1 cache=142412
ASSISTANT
Tool: Edit
  (toolu_01PPtxjexexWwDT3x4Lvp3Qu)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .empty-message a {
                color: var(--accent);
            }
    new_string:         .empty-message a, .page-number a {
                color: var(--accent);
                text-decoration: none;
            }
    
            .empty-message a:hover, .page-number a:hover {
                text-decor...
  Tokens: in=0 out=997 cache=142412
Result
  (toolu_01PPtxjexexWwDT3x4Lvp3Qu)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       501→            font-size: 0.7rem;
       502→            color: rgba(255,255,255,0.7);
       503→        }
       504→
       505→        .empty-message a, .page-number a {
       506→            color: var(--accent);
       507→            text-decoration: none;
       508→        }
       509→
       510→        .empty-message a:hover, .page-number a:hover {
       511→            text-decoration: underline;
       512→        }
       513→
       514→        /* Edit button on photos */
       515→        .photo-frame .edit-btn {
       516→            position: absolute;
       517→            top: 8px;
       518→            right: 8px;
       519→            background: rgba(255,255,255,0.9);
    ... (130 lines total)
ASSISTANT
  Now let me add the edit modal HTML and update JavaScript:
  Tokens: in=0 out=5 cache=17760
ASSISTANT
Tool: Read
  (toolu_019sgsxWGRYtGXUbR7sxwZe3)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 700
    limit: 30
  Tokens: in=0 out=123 cache=17760
Result
  (toolu_019sgsxWGRYtGXUbR7sxwZe3)
       700→
       701→        <div class="page-number" id="landscapes-page-number"></div>
       702→    </section>
       703→
       704→    <!-- Chapter 2: Historic Sites -->
       705→    <section class="chapter" id="historic">
       706→        <span class="chapter-number">Chapter Two</span>
       707→        <h2 class="chapter-title">Historic Sites</h2>
       708→        <p class="chapter-description">
       709→            Ancient stones and weathered walls - places where time has left its mark
       710→            and history whispers through the ages.
       711→        </p>
       712→
       713→        <!-- Photos loaded dynamically -->
       714→        <div id="historic-gallery" class="dynamic-gallery">
       715→            <div class="loading-message">Loading photos...</div>
       716→        </div>
       717→
       718→        <div class="page-number" id="historic-page-number"></div>
       719→    </section>
    ... (35 lines total)
ASSISTANT
Tool: Read
  (toolu_01Jx3vouVFq5WeJYNqqsZ7w5)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 755
    limit: 30
  Tokens: in=0 out=110 cache=119909
Result
  (toolu_01Jx3vouVFq5WeJYNqqsZ7w5)
       755→            <p class="lightbox-caption" id="lightbox-caption"></p>
       756→        </div>
       757→    </div>
       758→
       759→    <script>
       760→        let currentImageIndex = 0;
       761→        let images = [];
       762→
       763→        function openLightbox(src, caption, index) {
       764→            document.getElementById('lightbox-img').src = src;
       765→            document.getElementById('lightbox-caption').textContent = caption || '';
       766→            document.getElementById('lightbox').classList.add('active');
       767→            document.body.style.overflow = 'hidden';
       768→            currentImageIndex = index;
       769→        }
       770→
       771→        function closeLightbox() {
       772→            document.getElementById('lightbox').classList.remove('active');
       773→            document.body.style.overflow = '';
       774→        }
    ... (35 lines total)
ASSISTANT
Tool: Edit
  (toolu_01A5YSe6MkMzxE65JetXSpbd)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             <p class="lightbox-caption" id="lightbox-caption"></p>
            </div>
        </div>
    
        <script>
    new_string:             <p class="lightbox-caption" id="lightbox-caption"></p>
            </div>
        </div>
    
        <!-- Edit Modal -->
        <div class="edit-modal" id="editModal">
            <div class="edit-modal-content...
  Tokens: in=0 out=403 cache=120648
Result
  (toolu_01A5YSe6MkMzxE65JetXSpbd)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       751→        <span class="lightbox-nav lightbox-prev" onclick="prevImage()">&#8249;</span>
       752→        <span class="lightbox-nav lightbox-next" onclick="nextImage()">&#8250;</span>
       753→        <div class="lightbox-content">
       754→            <img src="" alt="Full size" id="lightbox-img">
       755→            <p class="lightbox-caption" id="lightbox-caption"></p>
       756→        </div>
       757→    </div>
       758→
       759→    <!-- Edit Modal -->
       760→    <div class="edit-modal" id="editModal">
       761→        <div class="edit-modal-content">
       762→            <h3>Edit Photo</h3>
       763→            <label for="editTitle">Title</label>
       764→            <input type="text" id="editTitle" placeholder="Photo title">
       765→            <label for="editPassword">Password (required)</label>
       766→            <input type="password" id="editPassword" placeholder="Enter password">
       767→            <div class="edit-modal-buttons">
       768→                <button class="cancel-btn" onclick="closeEditModal()">Cancel</button>
       769→                <button class="save-btn" onclick="saveEdit()">Save</button>
    ... (32 lines total)
ASSISTANT
Tool: TodoWrite
  (toolu_01BZXpLFYkgQ1H34pyng7eQB)
    todos: [{'content': 'Add upload link to gallery that always shows', 'status': 'completed', 'activeForm': 'Adding upload link to gallery'}, {'content': 'Add edit/delete feature for photos', 'status': 'in_prog...
  Tokens: in=0 out=143 cache=121215
Result
  (toolu_01BZXpLFYkgQ1H34pyng7eQB)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  Now let me update the JavaScript to add the edit button and functions:
  Tokens: in=0 out=4 cache=122194
ASSISTANT
Tool: Read
  (toolu_01TwfuidPSrtvJfMcDfEYbJz)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 810
    limit: 50
  Tokens: in=0 out=125 cache=122194
Result
  (toolu_01TwfuidPSrtvJfMcDfEYbJz)
       810→        document.getElementById('lightbox').addEventListener('click', function(e) {
       811→            if (e.target === this) closeLightbox();
       812→        });
       813→
       814→        document.addEventListener('keydown', function(e) {
       815→            if (e.key === 'Escape') closeLightbox();
       816→            if (e.key === 'ArrowRight') nextImage();
       817→            if (e.key === 'ArrowLeft') prevImage();
       818→        });
       819→
       820→        // Format filename to readable title
       821→        function formatTitle(filename) {
       822→            // Remove extension and timestamp/random suffix
       823→            let name = filename.replace(/\.[^.]+$/, ''); // remove extension
       824→            name = name.replace(/_\d{13}_[a-f0-9]+$/, ''); // remove timestamp_random
       825→            name = name.replace(/_/g, ' '); // underscores to spaces
       826→            // Capitalize words
       827→            return name.split(' ')
       828→                .map(word => word.charAt(0).toUpperCase() + word.slice(1))
       829→                .join(' ');
    ... (55 lines total)
ASSISTANT
Tool: Edit
  (toolu_01EzFDf53BCvx7saTJjSvGCu)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         document.addEventListener('keydown', function(e) {
                if (e.key === 'Escape') closeLightbox();
                if (e.key === 'ArrowRight') nextImage();
                if (e.key === 'ArrowLef...
    new_string:         document.addEventListener('keydown', function(e) {
                if (e.key === 'Escape') {
                    closeLightbox();
                    closeEditModal();
                }
                if (e.key ...
  Tokens: in=0 out=853 cache=122379
Result
  (toolu_01EzFDf53BCvx7saTJjSvGCu)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       810→        document.getElementById('lightbox').addEventListener('click', function(e) {
       811→            if (e.target === this) closeLightbox();
       812→        });
       813→
       814→        document.addEventListener('keydown', function(e) {
       815→            if (e.key === 'Escape') {
       816→                closeLightbox();
       817→                closeEditModal();
       818→            }
       819→            if (e.key === 'ArrowRight') nextImage();
       820→            if (e.key === 'ArrowLeft') prevImage();
       821→        });
       822→
       823→        // Edit modal functions
       824→        function openEditModal(filename, category, currentTitle) {
       825→            document.getElementById('editFilename').value = filename;
       826→            document.getElementById('editCategory').value = category;
       827→            document.getElementById('editTitle').value = currentTitle;
       828→            document.getElementById('editPassword').value = '';
    ... (89 lines total)
ASSISTANT
  Now update the createPhotoFrame function to add the edit button:
  Tokens: in=0 out=2 cache=123247
ASSISTANT
Tool: Edit
  (toolu_01XpSMQCTLBYgPns9T7NRaNZ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Create photo element
            function createPhotoFrame(photo, index) {
                const frame = document.createElement('div');
                frame.className = 'photo-frame';
    
                // ...
    new_string:         // Create photo element
            function createPhotoFrame(photo, index) {
                const frame = document.createElement('div');
                frame.className = 'photo-frame';
    
                // ...
  Tokens: in=0 out=712 cache=123247
Result
  (toolu_01XpSMQCTLBYgPns9T7NRaNZ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       903→                .map(word => word.charAt(0).toUpperCase() + word.slice(1))
       904→                .join(' ');
       905→        }
       906→
       907→        // Create photo element
       908→        function createPhotoFrame(photo, index) {
       909→            const frame = document.createElement('div');
       910→            frame.className = 'photo-frame';
       911→
       912→            // Use custom title if available, otherwise format from filename
       913→            const title = photo.title || formatTitle(photo.filename);
       914→
       915→            const img = document.createElement('img');
       916→            img.src = photo.path;
       917→            img.alt = title;
       918→            img.loading = 'lazy';
       919→
       920→            const caption = document.createElement('div');
       921→            caption.className = 'photo-caption';
    ... (47 lines total)
ASSISTANT
  Now let me add the edit and delete endpoints to the server:
  Tokens: in=0 out=3 cache=125173
ASSISTANT
Tool: Read
  (toolu_01PXauPnuH1gRibk8bmKwJoY)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    offset: 118
    limit: 30
  Tokens: in=0 out=124 cache=125173
Result
  (toolu_01PXauPnuH1gRibk8bmKwJoY)
       118→            res.end(JSON.stringify({ error: 'Server error' }));
       119→            return;
       120→        }
       121→    }
       122→
       123→    if (req.method !== 'POST' || req.url !== '/upload') {
       124→        res.writeHead(404, { 'Content-Type': 'application/json' });
       125→        res.end(JSON.stringify({ error: 'Not found' }));
       126→        return;
       127→    }
       128→
       129→    const contentType = req.headers['content-type'] || '';
       130→    if (!contentType.includes('multipart/form-data')) {
       131→        res.writeHead(400, { 'Content-Type': 'application/json' });
       132→        res.end(JSON.stringify({ error: 'Invalid content type' }));
       133→        return;
       134→    }
       135→
       136→    const boundary = contentType.split('boundary=')[1];
       137→    if (!boundary) {
    ... (35 lines total)
ASSISTANT
Tool: Edit
  (toolu_018XtmqM86py4ceN5PksEjGn)
    file_path: /var/www/rosy.shitchell.com/srv/upload-api/server.js
    old_string:     if (req.method !== 'POST' || req.url !== '/upload') {
            res.writeHead(404, { 'Content-Type': 'application/json' });
            res.end(JSON.stringify({ error: 'Not found' }));
            return;
     ...
    new_string:     // POST /edit - edit photo title
        if (req.method === 'POST' && req.url === '/edit') {
            let body = '';
            req.on('data', chunk => body += chunk);
            req.on('end', () => {
          ...
  Tokens: in=0 out=1114 cache=126497
Result
  (toolu_018XtmqM86py4ceN5PksEjGn)
    The file /var/www/rosy.shitchell.com/srv/upload-api/server.js has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       119→            return;
       120→        }
       121→    }
       122→
       123→    // POST /edit - edit photo title
       124→    if (req.method === 'POST' && req.url === '/edit') {
       125→        let body = '';
       126→        req.on('data', chunk => body += chunk);
       127→        req.on('end', () => {
       128→            try {
       129→                const { filename, category, title, password } = JSON.parse(body);
       130→
       131→                if (password !== UPLOAD_PASSWORD) {
       132→                    res.writeHead(401, { 'Content-Type': 'application/json' });
       133→                    res.end(JSON.stringify({ error: 'Invalid password' }));
       134→                    return;
       135→                }
       136→
       137→                const metadataPath = path.join(UPLOAD_DIR, 'metadata.json');
    ... (93 lines total)
ASSISTANT
  Now let me darken the page colors:
  Tokens: in=0 out=4 cache=127247
ASSISTANT
Tool: Read
  (toolu_01DRYxbb6wyNrH3UMiYSoMiy)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 1
    limit: 25
  Tokens: in=0 out=120 cache=127247
Result
  (toolu_01DRYxbb6wyNrH3UMiYSoMiy)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #f7f5f2;
        13→            --paper: #fffefa;
        14→            --ink: #2c2825;
        15→            --ink-light: #6b635c;
        16→            --ink-faint: #a39d96;
        17→            --accent: #8b7355;
        18→            --shadow: rgba(44, 40, 37, 0.08);
        19→            --shadow-deep: rgba(44, 40, 37, 0.15);
        20→        }
    ... (30 lines total)
ASSISTANT
Tool: Edit
  (toolu_01B5vvTMAgw47aATBXoJrrp7)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         :root {
                --page-bg: #f7f5f2;
                --paper: #fffefa;
                --ink: #2c2825;
                --ink-light: #6b635c;
                --ink-faint: #a39d96;
                --accent: #8b7...
    new_string:         :root {
                --page-bg: #d8d3cc;
                --paper: #eae6e0;
                --ink: #2c2825;
                --ink-light: #5a534d;
                --ink-faint: #8a847d;
                --accent: #7a6...
  Tokens: in=0 out=359 cache=129693
Result
  (toolu_01B5vvTMAgw47aATBXoJrrp7)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #d8d3cc;
        13→            --paper: #eae6e0;
        14→            --ink: #2c2825;
        15→            --ink-light: #5a534d;
        16→            --ink-faint: #8a847d;
        17→            --accent: #7a6348;
        18→            --shadow: rgba(44, 40, 37, 0.12);
        19→            --shadow-deep: rgba(44, 40, 37, 0.2);
        20→        }
        21→
        22→        * {
        23→            margin: 0;
        24→            padding: 0;
ASSISTANT
  Now rebuild the container and fix permissions:
  Tokens: in=0 out=1 cache=130477
ASSISTANT
Tool: Bash
  (toolu_01Y6fjpURgM8BVm8PWD85Jgk)
    command: cd /var/www/rosy.shitchell.com/srv/upload-api && docker compose up -d --build 2>&1
    description: Rebuild upload container with edit/delete endpoints
  Tokens: in=0 out=118 cache=130477
Result
  (toolu_01Y6fjpURgM8BVm8PWD85Jgk)
    time="2025-12-07T05:21:08Z" level=warning msg="Docker Compose is configured to build using Bake, but buildx isn't installed"
    #0 building with "default" instance using docker driver
    
    #1 [upload-api internal] load build definition from Dockerfile
    #1 transferring dockerfile: 206B 0.0s done
    #1 DONE 0.0s
    
    #2 [upload-api internal] load metadata for docker.io/library/node:20-alpine
    #2 DONE 0.5s
    
    #3 [upload-api internal] load .dockerignore
    #3 transferring context: 2B done
    #3 DONE 0.0s
    
    #4 [upload-api 1/3] FROM docker.io/library/node:20-alpine@sha256:643e7036aa985317ebfee460005e322aa550c6b6883000d01daefb58689a58e2
    #4 DONE 0.0s
    
    #5 [upload-api internal] load build context
    #5 transferring context: 12.48kB 0.0s done
    #5 DONE 0.0s
    ... (41 lines total)
ASSISTANT
Tool: Bash
  (toolu_018T9MGhK3TKRjeiicQwS35Z)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/index.html /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    description: Fix file permissions
  Tokens: in=1 out=122 cache=131223
Result
  (toolu_018T9MGhK3TKRjeiicQwS35Z)
ASSISTANT
Tool: TodoWrite
  (toolu_01Qi5mTnhQLn6t8f6HqinPAR)
    todos: [{'content': 'Add upload link to gallery that always shows', 'status': 'completed', 'activeForm': 'Adding upload link to gallery'}, {'content': 'Add edit/delete feature for photos', 'status': 'complet...
  Tokens: in=0 out=141 cache=132039
Result
  (toolu_01Qi5mTnhQLn6t8f6HqinPAR)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
  All done! Refresh the page to see the changes: **https://rosy.shitchell.com/photography**
  
  **What I fixed/added:**
  
  1. **"Add more" link** - Now shows below each gallery section even after you've uploaded photos
  
  2. **Edit photos** - Hover over any photo and you'll see a pencil icon (✎) in the top right corner. Click it to:
     - Change the photo title
     - Delete the photo
     - (Requires your password)
  
  3. **Less bright colors** - Darkened the background from white to a warmer grayish-tan tone
  
  Try hovering over your photo and clicking the pencil icon to edit the title!
  Tokens: in=0 out=162 cache=132187
USER
  Top section where you say Rosy is too big make it much smaller thanks :)))
ASSISTANT
Tool: Read
  (toolu_01WhhNFW9EEppSoojGtFrnah)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 40
    limit: 50
  Tokens: in=2 out=110 cache=132370
Result
  (toolu_01WhhNFW9EEppSoojGtFrnah)
        40→        /* Book Cover */
        41→        .cover {
        42→            min-height: 100vh;
        43→            display: flex;
        44→            flex-direction: column;
        45→            align-items: center;
        46→            justify-content: center;
        47→            background: var(--paper);
        48→            position: relative;
        49→            padding: 60px 40px;
        50→            box-shadow: 0 0 60px var(--shadow);
        51→        }
        52→
        53→        .cover::before {
        54→            content: '';
        55→            position: absolute;
        56→            top: 30px;
        57→            left: 30px;
        58→            right: 30px;
        59→            bottom: 30px;
    ... (55 lines total)
ASSISTANT
Tool: Edit
  (toolu_017BwdRo2vQa2fu6susufbGR)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Cover */
            .cover {
                min-height: 100vh;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: ce...
    new_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
            ...
  Tokens: in=0 out=918 cache=132551
Result
  (toolu_017BwdRo2vQa2fu6susufbGR)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        36→            line-height: 1.6;
        37→            font-weight: 300;
        38→        }
        39→
        40→        /* Book Cover - Compact header */
        41→        .cover {
        42→            display: flex;
        43→            flex-direction: column;
        44→            align-items: center;
        45→            justify-content: center;
        46→            background: var(--paper);
        47→            position: relative;
        48→            padding: 40px 30px;
        49→            box-shadow: 0 2px 20px var(--shadow);
        50→        }
        51→
        52→        .cover::before {
        53→            content: '';
        54→            position: absolute;
    ... (58 lines total)
ASSISTANT
  Let me also remove the "scroll to explore" text and shrink the nav spacing:
  Tokens: in=0 out=1 cache=133322
ASSISTANT
Tool: Read
  (toolu_01LCe4G7rb3kYcGCktk8q1yY)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 90
    limit: 40
  Tokens: in=0 out=129 cache=133322
Result
  (toolu_01LCe4G7rb3kYcGCktk8q1yY)
        90→        .cover-nav {
        91→            display: flex;
        92→            gap: 50px;
        93→        }
        94→
        95→        .cover-nav a {
        96→            font-size: 0.8rem;
        97→            letter-spacing: 0.2em;
        98→            text-transform: uppercase;
        99→            color: var(--ink-light);
       100→            text-decoration: none;
       101→            padding: 10px 0;
       102→            position: relative;
       103→            transition: color 0.3s;
       104→        }
       105→
       106→        .cover-nav a::after {
       107→            content: '';
       108→            position: absolute;
       109→            bottom: 0;
    ... (45 lines total)
ASSISTANT
Tool: Edit
  (toolu_01KqBsXGaeDft3FddsbPvWpC)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-nav {
                display: flex;
                gap: 50px;
            }
    
            .cover-nav a {
                font-size: 0.8rem;
                letter-spacing: 0.2em;
                text-transform: u...
    new_string:         .cover-nav {
                display: flex;
                gap: 30px;
            }
    
            .cover-nav a {
                font-size: 0.75rem;
                letter-spacing: 0.15em;
                text-transform:...
  Tokens: in=0 out=336 cache=134916
Result
  (toolu_01KqBsXGaeDft3FddsbPvWpC)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        86→            background: var(--accent);
        87→            margin-bottom: 20px;
        88→        }
        89→
        90→        .cover-nav {
        91→            display: flex;
        92→            gap: 30px;
        93→        }
        94→
        95→        .cover-nav a {
        96→            font-size: 0.75rem;
        97→            letter-spacing: 0.15em;
        98→            text-transform: uppercase;
        99→            color: var(--ink-light);
       100→            text-decoration: none;
       101→            padding: 5px 0;
       102→            position: relative;
       103→            transition: color 0.3s;
       104→        }
    ... (24 lines total)
ASSISTANT
  Now let me hide the "scroll to explore" text since the header is compact now:
  Tokens: in=0 out=1 cache=135536
ASSISTANT
Tool: Read
  (toolu_01JvavbYGyDYbMjny5Pfs6cj)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 125
    limit: 20
  Tokens: in=0 out=129 cache=135536
Result
  (toolu_01JvavbYGyDYbMjny5Pfs6cj)
       125→        .scroll-hint {
       126→            position: absolute;
       127→            bottom: 40px;
       128→            font-size: 0.7rem;
       129→            letter-spacing: 0.15em;
       130→            text-transform: uppercase;
       131→            color: var(--ink-faint);
       132→            animation: float 2s ease-in-out infinite;
       133→        }
       134→
       135→        @keyframes float {
       136→            0%, 100% { transform: translateY(0); }
       137→            50% { transform: translateY(5px); }
       138→        }
       139→
       140→        /* Chapter/Section Pages */
       141→        .chapter {
       142→            min-height: 100vh;
       143→            background: var(--paper);
       144→            margin: 40px auto;
    ... (25 lines total)
ASSISTANT
Tool: Edit
  (toolu_01CsefHWugfrzCDX2WtcnVUC)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .scroll-hint {
                position: absolute;
                bottom: 40px;
                font-size: 0.7rem;
                letter-spacing: 0.15em;
                text-transform: uppercase;
                c...
    new_string:         .scroll-hint {
                display: none;
            }
  Tokens: in=0 out=249 cache=136264
Result
  (toolu_01CsefHWugfrzCDX2WtcnVUC)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       121→        .cover-nav a:hover::after {
       122→            width: 100%;
       123→        }
       124→
       125→        .scroll-hint {
       126→            display: none;
       127→        }
       128→
       129→        /* Chapter/Section Pages */
       130→        .chapter {
       131→            min-height: 100vh;
ASSISTANT
Tool: Bash
  (toolu_0123uzVFQ2gr1cYsXTEM15nk)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Fix permissions
  Tokens: in=0 out=97 cache=136710
Result
  (toolu_0123uzVFQ2gr1cYsXTEM15nk)
ASSISTANT
  Done! Refresh the page - the header is now much smaller and compact. The "ROSY" title and navigation all fit in a slim bar at the top now instead of taking up the full screen.
  Tokens: in=0 out=46 cache=137219
USER
  for the hearder, make space smaller and shorter
ASSISTANT
Tool: Edit
  (toolu_017NeNyAciiicsLAo7u54hzs)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
            ...
    new_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
        ...
  Tokens: in=2 out=824 cache=137342
Result
  (toolu_017NeNyAciiicsLAo7u54hzs)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        36→            line-height: 1.6;
        37→            font-weight: 300;
        38→        }
        39→
        40→        /* Book Cover - Compact header */
        41→        .cover {
        42→            display: flex;
        43→            flex-direction: row;
        44→            align-items: center;
        45→            justify-content: space-between;
        46→            background: var(--paper);
        47→            padding: 15px 30px;
        48→            box-shadow: 0 2px 10px var(--shadow);
        49→        }
        50→
        51→        .cover::before {
        52→            display: none;
        53→        }
        54→
    ... (52 lines total)
ASSISTANT
  Now let me update the HTML to match this new layout:
  Tokens: in=0 out=1 cache=137399
ASSISTANT
Tool: Read
  (toolu_01R4Jmwg7M9Gu1LZ4THc8EbU)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 670
    limit: 25
  Tokens: in=0 out=123 cache=137399
Result
  (toolu_01R4Jmwg7M9Gu1LZ4THc8EbU)
       670→    <section class="chapter" id="landscapes">
       671→        <span class="chapter-number">Chapter One</span>
       672→        <h2 class="chapter-title">Landscapes</h2>
       673→        <p class="chapter-description">
       674→            Moments of stillness found in nature - where mountains meet sky
       675→            and light paints the world in golden hues.
       676→        </p>
       677→
       678→        <!-- Photos loaded dynamically -->
       679→        <div id="landscapes-gallery" class="dynamic-gallery">
       680→            <div class="loading-message">Loading photos...</div>
       681→        </div>
       682→
       683→        <div class="page-number" id="landscapes-page-number"></div>
       684→    </section>
       685→
       686→    <!-- Chapter 2: Historic Sites -->
       687→    <section class="chapter" id="historic">
       688→        <span class="chapter-number">Chapter Two</span>
       689→        <h2 class="chapter-title">Historic Sites</h2>
    ... (30 lines total)
ASSISTANT
Tool: Read
  (toolu_01Ga9hWaF9cqqQvgjnrxRtL6)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 655
    limit: 20
  Tokens: in=0 out=110 cache=138913
Result
  (toolu_01Ga9hWaF9cqqQvgjnrxRtL6)
       655→<body>
       656→    <!-- Cover Page -->
       657→    <section class="cover">
       658→        <h1 class="cover-title">Rosy</h1>
       659→        <p class="cover-subtitle">A Collection of Photographs</p>
       660→        <div class="cover-line"></div>
       661→        <nav class="cover-nav">
       662→            <a href="#landscapes">Landscapes</a>
       663→            <a href="#historic">Historic Sites</a>
       664→            <a href="#about">About</a>
       665→        </nav>
       666→        <span class="scroll-hint">Scroll to explore</span>
       667→    </section>
       668→
       669→    <!-- Chapter 1: Landscapes -->
       670→    <section class="chapter" id="landscapes">
       671→        <span class="chapter-number">Chapter One</span>
       672→        <h2 class="chapter-title">Landscapes</h2>
       673→        <p class="chapter-description">
       674→            Moments of stillness found in nature - where mountains meet sky
    ... (25 lines total)
ASSISTANT
Tool: Edit
  (toolu_01GuYjVUXfk4EDLJqPPEjpVV)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Cover Page -->
        <section class="cover">
            <h1 class="cover-title">Rosy</h1>
            <p class="cover-subtitle">A Collection of Photographs</p>
            <div class="cover-line"></div>
     ...
    new_string:     <!-- Header -->
        <header class="cover">
            <div class="cover-brand">
                <h1 class="cover-title">Rosy</h1>
                <p class="cover-subtitle">Photography</p>
            </div>
        ...
  Tokens: in=0 out=365 cache=139459
Result
  (toolu_01GuYjVUXfk4EDLJqPPEjpVV)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       652→        }
       653→    </style>
       654→</head>
       655→<body>
       656→    <!-- Header -->
       657→    <header class="cover">
       658→        <div class="cover-brand">
       659→            <h1 class="cover-title">Rosy</h1>
       660→            <p class="cover-subtitle">Photography</p>
       661→        </div>
       662→        <nav class="cover-nav">
       663→            <a href="#landscapes">Landscapes</a>
       664→            <a href="#historic">Historic Sites</a>
       665→            <a href="#about">About</a>
       666→        </nav>
       667→    </header>
       668→
       669→    <!-- Chapter 1: Landscapes -->
       670→    <section class="chapter" id="landscapes">
    ... (21 lines total)
ASSISTANT
Tool: Bash
  (toolu_018eDsDXbcQe2JQ3JopWSyY5)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Fix permissions
  Tokens: in=0 out=97 cache=140044
Result
  (toolu_018eDsDXbcQe2JQ3JopWSyY5)
ASSISTANT
  Done! Refresh the page - the header is now a slim horizontal bar with:
  - "ROSY" and "Photography" on the left
  - Navigation links on the right
  - Much shorter and more compact!
  Tokens: in=0 out=49 cache=140702
USER
  I would love to see "Rosy" and "photography"have the same font whihc match the scene and cozy and warm
ASSISTANT
Tool: Edit
  (toolu_018fWPAKJoEjXASZmGAEfZjv)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.4rem;
                font-weight: 400;
                letter-spacing: 0.1em;
                text-t...
    new_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.5rem;
                font-weight: 400;
                letter-spacing: 0.02em;
                color...
  Tokens: in=2 out=460 cache=140825
Result
  (toolu_018fWPAKJoEjXASZmGAEfZjv)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        57→            align-items: center;
        58→            gap: 12px;
        59→        }
        60→
        61→        .cover-title {
        62→            font-family: 'Cormorant Garamond', Georgia, serif;
        63→            font-size: 1.5rem;
        64→            font-weight: 400;
        65→            letter-spacing: 0.02em;
        66→            color: var(--ink);
        67→            margin: 0;
        68→        }
        69→
        70→        .cover-subtitle {
        71→            font-family: 'Cormorant Garamond', Georgia, serif;
        72→            font-size: 1.1rem;
        73→            font-weight: 300;
        74→            color: var(--ink-light);
        75→            margin: 0;
    ... (30 lines total)
ASSISTANT
Tool: Edit
  (toolu_01EitGL3BEKnU5DEtfvAimF8)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Header -->
        <header class="cover">
            <div class="cover-brand">
                <h1 class="cover-title">Rosy</h1>
                <p class="cover-subtitle">Photography</p>
            </div>
        ...
    new_string:     <!-- Header -->
        <header class="cover">
            <div class="cover-brand">
                <span class="cover-title">Rosy</span>
                <span class="cover-brand-divider">·</span>
                <s...
  Tokens: in=0 out=264 cache=141007
Result
  (toolu_01EitGL3BEKnU5DEtfvAimF8)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       655→        }
       656→    </style>
       657→</head>
       658→<body>
       659→    <!-- Header -->
       660→    <header class="cover">
       661→        <div class="cover-brand">
       662→            <span class="cover-title">Rosy</span>
       663→            <span class="cover-brand-divider">·</span>
       664→            <span class="cover-subtitle">Photography</span>
       665→        </div>
       666→        <nav class="cover-nav">
       667→            <a href="#landscapes">Landscapes</a>
       668→            <a href="#historic">Historic Sites</a>
       669→            <a href="#about">About</a>
       670→        </nav>
ASSISTANT
Tool: Bash
  (toolu_0154djEHE65YKWja4gxwTJd1)
    command: chmod 644 /var/www/rosy.shitchell.com/srv/web/photography/index.html
    description: Fix permissions
  Tokens: in=0 out=97 cache=141841
Result
  (toolu_0154djEHE65YKWja4gxwTJd1)
ASSISTANT
  Done! Refresh the page - now "Rosy" and "Photography" both use the same elegant Cormorant Garamond serif font with a little dot (·) between them. It's a warm, classic look that fits the cozy photobook style.
  Tokens: in=0 out=61 cache=142357
USER
  Hey can you remove the "return home" link on bottom of the page?
ASSISTANT
Tool: Grep
  (toolu_01JEiDgnDpdvBcVrHnjetENy)
    pattern: Return Home
    path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    output_mode: content
  Tokens: in=2 out=112 cache=142567
Result
  (toolu_01JEiDgnDpdvBcVrHnjetENy)
    731:        <p style="margin-top: 20px;"><a href="/">Return Home</a> &middot; <a href="/photography/upload.html">Upload Photos</a></p>
    
    [Showing results with pagination = limit: 100, offset: 0]
ASSISTANT
Tool: Edit
  (toolu_01VHdPoGXr8Ye76YezdtDo6f)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <p style="margin-top: 20px;"><a href="/">Return Home</a> &middot; <a href="/photography/upload.html">Upload Photos</a></p>
    new_string:         <p style="margin-top: 20px;"><a href="/photography/upload.html">Upload Photos</a></p>
  Tokens: in=0 out=184 cache=142645
Result
  (toolu_01VHdPoGXr8Ye76YezdtDo6f)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       727→    <!-- Back Cover -->
       728→    <footer class="back-cover">
       729→        <p class="back-cover-title">Rosy</p>
       730→        <p>&copy; 2024 &middot; All photographs by Rosy</p>
       731→        <p style="margin-top: 20px;"><a href="/photography/upload.html">Upload Photos</a></p>
       732→    </footer>
       733→
       734→    <!-- Lightbox -->
       735→    <div class="lightbox" id="lightbox">
ASSISTANT
  Done! Removed the "Return Home" link - now just "Upload Photos" remains at the bottom.
  Tokens: in=0 out=25 cache=142836
USER
  make the bottom space 1/2  smaller 
ASSISTANT
Tool: Grep
  (toolu_01GKCjEnnvY2eA8A28wBrCNw)
    pattern: back-cover
    path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    output_mode: content
    -n: True
  Tokens: in=2 out=131 cache=143327
Result
  (toolu_01GKCjEnnvY2eA8A28wBrCNw)
    330:        .back-cover {
    338:        .back-cover-title {
    346:        .back-cover p {
    352:        .back-cover a {
    357:        .back-cover a:hover {
    728:    <footer class="back-cover">
    729:        <p class="back-cover-title">Rosy</p>
    
    [Showing results with pagination = limit: 100, offset: 0]
ASSISTANT
Tool: Read
  (toolu_01QoZtLMq3NsKAiPghitzVMh)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 328
    limit: 35
  Tokens: in=0 out=110 cache=143364
Result
  (toolu_01QoZtLMq3NsKAiPghitzVMh)
       328→
       329→        /* Back cover / Footer */
       330→        .back-cover {
       331→            background: var(--ink);
       332→            color: var(--paper);
       333→            text-align: center;
       334→            padding: 80px 40px;
       335→            margin-top: 40px;
       336→        }
       337→
       338→        .back-cover-title {
       339→            font-family: 'Cormorant Garamond', Georgia, serif;
       340→            font-size: 2rem;
       341→            font-weight: 300;
       342→            letter-spacing: 0.1em;
       343→            margin-bottom: 20px;
       344→        }
       345→
       346→        .back-cover p {
       347→            font-size: 0.8rem;
    ... (40 lines total)
ASSISTANT
Tool: Edit
  (toolu_01UjcHQNrSnriqtJknEzw69R)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Back cover / Footer */
            .back-cover {
                background: var(--ink);
                color: var(--paper);
                text-align: center;
                padding: 80px 40px;
               ...
    new_string:         /* Back cover / Footer */
            .back-cover {
                background: var(--ink);
                color: var(--paper);
                text-align: center;
                padding: 40px 40px;
               ...
  Tokens: in=0 out=390 cache=143611
Result
  (toolu_01UjcHQNrSnriqtJknEzw69R)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       325→            color: var(--ink-light);
       326→            margin-bottom: 20px;
       327→        }
       328→
       329→        /* Back cover / Footer */
       330→        .back-cover {
       331→            background: var(--ink);
       332→            color: var(--paper);
       333→            text-align: center;
       334→            padding: 40px 40px;
       335→            margin-top: 20px;
       336→        }
       337→
       338→        .back-cover-title {
       339→            font-family: 'Cormorant Garamond', Georgia, serif;
       340→            font-size: 1.5rem;
       341→            font-weight: 300;
       342→            letter-spacing: 0.1em;
       343→            margin-bottom: 10px;
    ... (25 lines total)
ASSISTANT
  Done! The footer is now half the size - padding reduced from 80px to 40px, and the title is smaller too.
  Tokens: in=0 out=31 cache=144270
USER
  Can you change the title landscape to Nature. historic sites to city?
ASSISTANT
Tool: Read
  (toolu_011rZSvpRKtxMQYieviggnE7)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 505
    limit: 45
  Tokens: in=2 out=110 cache=12598
Result
  (toolu_011rZSvpRKtxMQYieviggnE7)
       505→            border: none;
       506→            border-radius: 50%;
       507→            width: 28px;
       508→            height: 28px;
       509→            cursor: pointer;
       510→            opacity: 0;
       511→            transition: opacity 0.3s;
       512→            font-size: 14px;
       513→            display: flex;
       514→            align-items: center;
       515→            justify-content: center;
       516→        }
       517→
       518→        .photo-frame:hover .edit-btn {
       519→            opacity: 1;
       520→        }
       521→
       522→        .photo-frame .edit-btn:hover {
       523→            background: white;
       524→        }
    ... (50 lines total)
ASSISTANT
Tool: Grep
  (toolu_01BDLfPfLi9n4Anmgjw3St9p)
    pattern: Landscapes|Historic Sites
    path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    output_mode: content
    -n: True
  Tokens: in=0 out=133 cache=141594
Result
  (toolu_01BDLfPfLi9n4Anmgjw3St9p)
    667:            <a href="#landscapes">Landscapes</a>
    668:            <a href="#historic">Historic Sites</a>
    673:    <!-- Chapter 1: Landscapes -->
    676:        <h2 class="chapter-title">Landscapes</h2>
    690:    <!-- Chapter 2: Historic Sites -->
    693:        <h2 class="chapter-title">Historic Sites</h2>
    
    [Showing results with pagination = limit: 100, offset: 0]
ASSISTANT
Tool: Edit
  (toolu_01LmEGxHWhm8bdYG3q6KuTqa)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             <a href="#landscapes">Landscapes</a>
                <a href="#historic">Historic Sites</a>
    new_string:             <a href="#landscapes">Nature</a>
                <a href="#historic">City</a>
  Tokens: in=0 out=158 cache=142242
Result
  (toolu_01LmEGxHWhm8bdYG3q6KuTqa)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       663→            <span class="cover-brand-divider">·</span>
       664→            <span class="cover-subtitle">Photography</span>
       665→        </div>
       666→        <nav class="cover-nav">
       667→            <a href="#landscapes">Nature</a>
       668→            <a href="#historic">City</a>
       669→            <a href="#about">About</a>
       670→        </nav>
       671→    </header>
       672→
ASSISTANT
Tool: Edit
  (toolu_01XadfKqLUoFw7SP9tbEFQCg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Chapter 1: Landscapes -->
        <section class="chapter" id="landscapes">
            <span class="chapter-number">Chapter One</span>
            <h2 class="chapter-title">Landscapes</h2>
    new_string:     <!-- Chapter 1: Nature -->
        <section class="chapter" id="landscapes">
            <span class="chapter-number">Chapter One</span>
            <h2 class="chapter-title">Nature</h2>
  Tokens: in=0 out=216 cache=142498
Result
  (toolu_01XadfKqLUoFw7SP9tbEFQCg)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       669→            <a href="#about">About</a>
       670→        </nav>
       671→    </header>
       672→
       673→    <!-- Chapter 1: Nature -->
       674→    <section class="chapter" id="landscapes">
       675→        <span class="chapter-number">Chapter One</span>
       676→        <h2 class="chapter-title">Nature</h2>
       677→        <p class="chapter-description">
       678→            Moments of stillness found in nature - where mountains meet sky
       679→            and light paints the world in golden hues.
       680→        </p>
ASSISTANT
Tool: Edit
  (toolu_019sKr71wy35bhqyLjyEjFCp)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Chapter 2: Historic Sites -->
        <section class="chapter" id="historic">
            <span class="chapter-number">Chapter Two</span>
            <h2 class="chapter-title">Historic Sites</h2>
    new_string:     <!-- Chapter 2: City -->
        <section class="chapter" id="historic">
            <span class="chapter-number">Chapter Two</span>
            <h2 class="chapter-title">City</h2>
  Tokens: in=0 out=216 cache=142943
Result
  (toolu_019sKr71wy35bhqyLjyEjFCp)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       686→
       687→        <div class="page-number" id="landscapes-page-number"></div>
       688→    </section>
       689→
       690→    <!-- Chapter 2: City -->
       691→    <section class="chapter" id="historic">
       692→        <span class="chapter-number">Chapter Two</span>
       693→        <h2 class="chapter-title">City</h2>
       694→        <p class="chapter-description">
       695→            Ancient stones and weathered walls - places where time has left its mark
       696→            and history whispers through the ages.
       697→        </p>
ASSISTANT
  Now let me also update the upload page to match:
  Tokens: in=0 out=1 cache=143374
ASSISTANT
Tool: Grep
  (toolu_01VKsVTBbQFMeiu7xtoBz9FS)
    pattern: Landscapes|Historic Sites
    path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    output_mode: content
    -n: True
  Tokens: in=0 out=145 cache=143374
Result
  (toolu_01VKsVTBbQFMeiu7xtoBz9FS)
    255:                    <option value="landscapes">Landscapes</option>
    256:                    <option value="historic">Historic Sites</option>
    
    [Showing results with pagination = limit: 100, offset: 0]
ASSISTANT
Tool: Edit
  (toolu_01F7QrkCBBaghM8k36S1JFct)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/upload.html
    old_string:                     <option value="landscapes">Landscapes</option>
                        <option value="historic">Historic Sites</option>
    new_string:                     <option value="landscapes">Nature</option>
                        <option value="historic">City</option>
  Tokens: in=0 out=162 cache=143807
Result
  (toolu_01F7QrkCBBaghM8k36S1JFct)
    The file /var/www/rosy.shitchell.com/srv/web/photography/upload.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       251→
       252→            <div class="form-group">
       253→                <label for="category">Category</label>
       254→                <select id="category" name="category">
       255→                    <option value="landscapes">Nature</option>
       256→                    <option value="historic">City</option>
       257→                </select>
       258→            </div>
       259→
       260→            <div class="form-group">
ASSISTANT
  Done! Changed:
  - "Landscapes" → "Nature"
  - "Historic Sites" → "City"
  
  Both the gallery page and upload page are updated. Refresh to see the changes!
  Tokens: in=0 out=1 cache=144116
File History Snapshot (2025-12-08T00:37:15.696Z)
USER
  do you have any dynamic header and background design reccomendations?
ASSISTANT
  Great question! Here are some ideas that would fit your cozy photobook style:
  
  ## Header Ideas
  
  1. **Sticky header with blur** - Header stays at top as you scroll, with a frosted glass effect
  2. **Hide on scroll down, show on scroll up** - Saves space while browsing photos
  3. **Color shift** - Header background subtly changes color as you scroll through sections
  
  ## Background Ideas
  
  1. **Subtle gradient animation** - Slow-moving warm gradient (creams, tans, soft browns) that shifts gently
  2. **Paper texture** - Add a subtle paper/canvas texture overlay for that photobook feel
  3. **Parallax sections** - Sections move at different speeds as you scroll for depth
  4. **Ambient particles** - Very subtle floating dust/light particles (like sunlight through a window)
  
  ## My Top Recommendations for Your Style
  
  | Feature | Why it fits |
  |---------|-------------|
  | **Sticky blur header** | Modern but cozy, keeps navigation accessible |
  | **Paper texture background** | Reinforces the photobook/journal aesthetic |
  | **Subtle warm gradient** | Adds life without distracting from photos |
  
  Would you like me to implement any of these? I can do:
  - Just one feature
  - A combination
  - Show you a preview first
  
  Which sounds interesting to you?
  Tokens: in=2 out=306 cache=144450
File History Snapshot (2025-12-08T00:37:56.566Z)
USER
  Paper texture background
ASSISTANT
Tool: Read
  (toolu_01ShoE2yqL2rSzxx5AoUZEEA)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 30
    limit: 20
  Tokens: in=2 out=110 cache=144510
Result
  (toolu_01ShoE2yqL2rSzxx5AoUZEEA)
        30→        }
        31→
        32→        body {
        33→            font-family: 'Montserrat', sans-serif;
        34→            background-color: var(--page-bg);
        35→            color: var(--ink);
        36→            line-height: 1.6;
        37→            font-weight: 300;
        38→        }
        39→
        40→        /* Book Cover - Compact header */
        41→        .cover {
        42→            display: flex;
        43→            flex-direction: row;
        44→            align-items: center;
        45→            justify-content: space-between;
        46→            background: var(--paper);
        47→            padding: 15px 30px;
        48→            box-shadow: 0 2px 10px var(--shadow);
        49→        }
    ... (25 lines total)
Queue: enqueue
  show me preview
Queue: remove
ASSISTANT
Tool: Edit
  (toolu_01HoZZ4aTPwPs1XkrQXpM8dP)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         body {
                font-family: 'Montserrat', sans-serif;
                background-color: var(--page-bg);
                color: var(--ink);
                line-height: 1.6;
                font-weight: 30...
    new_string:         body {
                font-family: 'Montserrat', sans-serif;
                background-color: var(--page-bg);
                color: var(--ink);
                line-height: 1.6;
                font-weight: 30...
  Tokens: in=0 out=563 cache=144925
Result
  (toolu_01HoZZ4aTPwPs1XkrQXpM8dP)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→        html {
        29→            scroll-behavior: smooth;
        30→        }
        31→
        32→        body {
        33→            font-family: 'Montserrat', sans-serif;
        34→            background-color: var(--page-bg);
        35→            color: var(--ink);
        36→            line-height: 1.6;
        37→            font-weight: 300;
        38→            background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
        39→            background-blend-mode: overlay;
        40→            background-size: 200px 200px;
        41→        }
        42→
        43→        body::before {
        44→            content: '';
        45→            position: fixed;
        46→            top: 0;
    ... (33 lines total)
ASSISTANT
  Done! Refresh the page to see the paper texture background.
  
  **What I added:**
  - **Subtle paper/noise texture** - A fine grain overlay that looks like real paper
  - **Warm vignette effect** - Very subtle warm tones in the corners for that aged photobook feel
  
  The texture is light enough not to distract from your photos but adds that cozy, tactile quality. Take a look at https://rosy.shitchell.com/photography and let me know if you want it more visible, less visible, or a different style!
  Tokens: in=0 out=126 cache=145349
ASSISTANT
Tool: Bash
  (toolu_01NzCHwMQxCpkKiUCDDXS6Qp)
    command: tmux display-message -p 'Width: #{pane_width} Height: #{pane_height}'
    description: Get terminal dimensions
  Tokens: in=2 out=95 cache=146527
Result
  (toolu_01NzCHwMQxCpkKiUCDDXS6Qp)
    Width: 147 Height: 28
ASSISTANT
Tool: Bash
  (toolu_01QWnTxNVtTixWEY1yZfPxnJ)
    command: claude-pane run side --title "Paper Texture Preview" --page --command 'echo "
    ╔═══════════════════════════════════════════════════════════╗
    ║           PAPER TEXTURE BACKGROUND - PREVIEW              ...
    description: Show preview pane
  Tokens: in=0 out=678 cache=146657
Result
  (toolu_01QWnTxNVtTixWEY1yZfPxnJ)
    opened pane %43 at position 'side'
ASSISTANT
  I opened a preview description in the side pane. The best way to see the paper texture is to visit the live site: **https://rosy.shitchell.com/photography**
  
  The texture is subtle - look closely at the background areas between sections. You'll see a fine grain that gives it that real paper/photobook feel.
  
  Let me know if you want:
  - **More visible** - stronger grain
  - **Less visible** - even more subtle
  - **Different texture** - linen, canvas, or watercolor style
  - **Remove it** - back to plain
  
  Press `q` to close the side pane when you're done!
  Tokens: in=0 out=145 cache=146879
File History Snapshot (2025-12-08T00:39:27.593Z)
USER
  dynamic header?
ASSISTANT
Tool: Edit
  (toolu_01Xi2msXub2EQz81wUkfCKZS)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
        ...
    new_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
        ...
  Tokens: in=2 out=455 cache=146651
Result
  (toolu_01Xi2msXub2EQz81wUkfCKZS)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        53→            pointer-events: none;
        54→            z-index: -1;
        55→        }
        56→
        57→        /* Book Cover - Compact header */
        58→        .cover {
        59→            display: flex;
        60→            flex-direction: row;
        61→            align-items: center;
        62→            justify-content: space-between;
        63→            background: rgba(234, 230, 224, 0.85);
        64→            backdrop-filter: blur(10px);
        65→            -webkit-backdrop-filter: blur(10px);
        66→            padding: 15px 30px;
        67→            box-shadow: 0 2px 10px var(--shadow);
        68→            position: sticky;
        69→            top: 0;
        70→            z-index: 100;
        71→            transition: transform 0.3s ease, background 0.3s ease, padding 0.3s ease;
    ... (35 lines total)
ASSISTANT
  Now let me add the JavaScript to control the header behavior:
  Tokens: in=0 out=1 cache=147721
ASSISTANT
Tool: Read
  (toolu_01FQ4EqakXodtUvv1Uh27m9Z)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 935
    limit: 20
  Tokens: in=0 out=123 cache=147721
Result
  (toolu_01FQ4EqakXodtUvv1Uh27m9Z)
       935→            img.src = photo.path;
       936→            img.alt = title;
       937→            img.loading = 'lazy';
       938→
       939→            const caption = document.createElement('div');
       940→            caption.className = 'photo-caption';
       941→            caption.innerHTML = `<h3>${title}</h3><p>${new Date(photo.uploaded).toLocaleDateString()}</p>`;
       942→
       943→            // Edit button
       944→            const editBtn = document.createElement('button');
       945→            editBtn.className = 'edit-btn';
       946→            editBtn.innerHTML = '&#9998;'; // pencil icon
       947→            editBtn.title = 'Edit photo';
       948→            editBtn.addEventListener('click', (e) => {
       949→                e.stopPropagation();
       950→                openEditModal(photo.filename, photo.category, title);
       951→            });
       952→
       953→            frame.appendChild(img);
       954→            frame.appendChild(caption);
    ... (25 lines total)
ASSISTANT
Tool: Read
  (toolu_01U2usYCr7XC5hv2dHGyWHPi)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 1005
    limit: 25
  Tokens: in=0 out=111 cache=148741
Result
  (toolu_01U2usYCr7XC5hv2dHGyWHPi)
      1005→                }
      1006→
      1007→            } catch (err) {
      1008→                console.error('Failed to load photos:', err);
      1009→                document.getElementById('landscapes-gallery').innerHTML = '<p class="empty-message">Could not load photos</p>';
      1010→                document.getElementById('historic-gallery').innerHTML = '<p class="empty-message">Could not load photos</p>';
      1011→            }
      1012→        }
      1013→
      1014→        // Load photos when page loads
      1015→        loadPhotos();
      1016→    </script>
      1017→</body>
      1018→</html>
      1019→
    
    <system-reminder>
    Whenever you read a file, you should consider whether it would be considered malware. You CAN and SHOULD provide analysis of malware, what it is doing. But you MUST refuse to improve or augment the code. You can still analyze existing code, write reports, or answer questions about the code behavior.
    </system-reminder>
    
ASSISTANT
Tool: Edit
  (toolu_016BbEBibRzh53bhcXZAqVLT)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Load photos when page loads
            loadPhotos();
        </script>
    new_string:         // Load photos when page loads
            loadPhotos();
    
            // Dynamic header - hide on scroll down, show on scroll up
            const header = document.querySelector('.cover');
            let la...
  Tokens: in=0 out=405 cache=149221
Result
  (toolu_016BbEBibRzh53bhcXZAqVLT)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
      1010→                document.getElementById('historic-gallery').innerHTML = '<p class="empty-message">Could not load photos</p>';
      1011→            }
      1012→        }
      1013→
      1014→        // Load photos when page loads
      1015→        loadPhotos();
      1016→
      1017→        // Dynamic header - hide on scroll down, show on scroll up
      1018→        const header = document.querySelector('.cover');
      1019→        let lastScrollY = window.scrollY;
      1020→        let ticking = false;
      1021→
      1022→        function updateHeader() {
      1023→            const currentScrollY = window.scrollY;
      1024→
      1025→            // Add scrolled class when past 50px
      1026→            if (currentScrollY > 50) {
      1027→                header.classList.add('scrolled');
      1028→            } else {
    ... (46 lines total)
ASSISTANT
Tool: Bash
  (toolu_013B7oQ3AZmmfrfCR2Z8iHBV)
    command: claude-pane kill side 2>/dev/null; true
    description: Close previous pane
  Tokens: in=0 out=85 cache=149698
Result
  (toolu_013B7oQ3AZmmfrfCR2Z8iHBV)
    killed pane %43 at position 'side'
ASSISTANT
  Done! Refresh the page to see the dynamic header. Here's what it does:
  
  **Dynamic header features:**
  - **Sticky** - Stays at the top as you scroll
  - **Frosted glass effect** - Semi-transparent with blur, so content shows through subtly
  - **Hides on scroll down** - Gets out of the way when browsing photos
  - **Shows on scroll up** - Instantly reappears when you scroll back up
  - **Shrinks when scrolled** - Gets slightly smaller after scrolling past 50px
  
  Try scrolling down and up on the page to see the effect!
  Tokens: in=0 out=139 cache=150671
File History Snapshot (2025-12-08T00:40:42.823Z)
USER
  glass effect
ASSISTANT
  The frosted glass effect is already added! But let me make it more visible so you can really see it:
  Tokens: in=2 out=1 cache=150780
ASSISTANT
Tool: Edit
  (toolu_01N3hyFEnmCvfaxQKD8TewwZ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
        ...
    new_string:         /* Book Cover - Compact header */
            .cover {
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
        ...
  Tokens: in=2 out=661 cache=150780
Result
  (toolu_01N3hyFEnmCvfaxQKD8TewwZ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        53→            pointer-events: none;
        54→            z-index: -1;
        55→        }
        56→
        57→        /* Book Cover - Compact header */
        58→        .cover {
        59→            display: flex;
        60→            flex-direction: row;
        61→            align-items: center;
        62→            justify-content: space-between;
        63→            background: rgba(234, 230, 224, 0.6);
        64→            backdrop-filter: blur(12px) saturate(180%);
        65→            -webkit-backdrop-filter: blur(12px) saturate(180%);
        66→            border-bottom: 1px solid rgba(255, 255, 255, 0.3);
        67→            padding: 15px 30px;
        68→            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
        69→            position: sticky;
        70→            top: 0;
        71→            z-index: 100;
    ... (32 lines total)
ASSISTANT
  Done! Refresh the page - the glass effect is now more noticeable:
  
  - **More transparent** (60% opacity instead of 85%)
  - **Stronger blur** (12px)
  - **Color saturation boost** - makes colors behind it pop slightly
  - **Subtle white border** at the bottom for that glass edge look
  - **Softer shadow**
  
  Scroll down the page so content goes behind the header - you'll see the frosted glass blur effect!
  Tokens: in=0 out=108 cache=151025
File History Snapshot (2025-12-08T00:42:28.763Z)
USER
  can you make a fisrt page like a book and nature second page and third page is city. make a "flipping pages" effect?
ASSISTANT
  That sounds amazing! A book with page-flip animations. Let me build that for you:
  Tokens: in=2 out=1 cache=152176
ASSISTANT
Tool: TodoWrite
  (toolu_014KAhFQwDCWwVtRSyLaGNSK)
    todos: [{'content': 'Create book structure with cover, nature, and city pages', 'status': 'in_progress', 'activeForm': 'Creating book structure with pages'}, {'content': 'Add CSS page flip animation', 'statu...
  Tokens: in=2 out=165 cache=152176
Result
  (toolu_014KAhFQwDCWwVtRSyLaGNSK)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
ASSISTANT
Tool: Write
  (toolu_01C4DVyeKypLU7T3RhhnwzkB)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    content: <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Rosy's Photography</title>
        <link rel="preco...
  Tokens: in=0 out=8982 cache=152417
Result
  (toolu_01C4DVyeKypLU7T3RhhnwzkB)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #d8d3cc;
        13→            --paper: #eae6e0;
        14→            --paper-dark: #ddd8d0;
        15→            --ink: #2c2825;
        16→            --ink-light: #5a534d;
        17→            --ink-faint: #8a847d;
        18→            --accent: #7a6348;
        19→            --shadow: rgba(44, 40, 37, 0.12);
    ... (973 lines total)
SYSTEM (compact_boundary)
  Conversation compacted (161608 tokens before compaction)
USER
  This session is being continued from a previous conversation that ran out of context. The conversation is summarized below:
  Analysis:
  Let me chronologically analyze the conversation:
  
  1. **Initial Request**: User asked for a photography portfolio website with landscapes and historic sites sections, modern but cozy style.
  
  2. **First Implementation**: Created a photography gallery page at `/var/www/rosy.shitchell.com/srv/web/photography/index.html` with a photobook-style design, warm cream/brown colors, serif fonts (Cormorant Garamond).
  
  3. **Color Adjustments**: 
     - User said "too bright" → darkened to charcoal tones
     - User said "put the color lighter" → adjusted to warm taupe/beige middle ground
  
  4. **Upload Feature**: User wanted to upload photos directly through web. Created:
     - Node.js upload server in Docker (`/var/www/rosy.shitchell.com/srv/upload-api/`)
     - Upload page at `/photography/upload.html`
     - Password protection with initial password `rosy-photo-2024`, later changed to `Rr16234160!`
     - Nginx proxy config for `/upload-api/`
  
  5. **Photobook Style**: User requested "look more like a Photobook" → redesigned with chapter pages, book-style layout, page numbers, elegant typography.
  
  6. **Photo Auto-Display**: Added API endpoint `/photos` to list uploaded photos, JavaScript to dynamically load and display them in gallery.
  
  7. **403 Error Fix**: Files had wrong permissions (`-rw-------`), fixed with `chmod 644`.
  
  8. **Photo Title Feature**: Added title field to upload form and metadata storage in `metadata.json`.
  
  9. **Photo Size & Layout**: User said photos too big → made smaller thumbnails (180px grid), improved lightbox.
  
  10. **Edit/Delete Feature**: Added edit button on photos, modal for editing title, delete functionality. Added `/edit` and `/delete` API endpoints.
  
  11. **Upload Link Fix**: User noted no "Add more" link after uploading → fixed to always show.
  
  12. **Header Adjustments**: Multiple iterations:
      - Made header much smaller and compact
      - Changed to horizontal layout with "Rosy · Photography"
      - Made fonts match (both Cormorant Garamond)
      - Removed "Return Home" link from footer
      - Made footer 1/2 smaller
  
  13. **Category Rename**: Changed "Landscapes" → "Nature", "Historic Sites" → "City" in both gallery and upload pages.
  
  14. **Dynamic Effects**:
      - Added paper texture background (SVG noise pattern)
      - Added dynamic sticky header with frosted glass effect, hide on scroll down, show on scroll up
  
  15. **Final Request - Book with Page Flip**: User wanted a book with first page as cover, second as Nature, third as City, with "flipping pages" effect. This was the most recent and significant change.
  
  Key files:
  - `/var/www/rosy.shitchell.com/srv/web/photography/index.html` - main gallery (completely rewritten for book effect)
  - `/var/www/rosy.shitchell.com/srv/web/photography/upload.html` - upload page
  - `/var/www/rosy.shitchell.com/srv/upload-api/server.js` - Node.js upload server
  - `/var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml` - Docker config
  - `/etc/nginx/sites-available/rosy.shitchell.com` - Nginx config
  
  The most recent work was implementing the book with page-flip animation, which I completed just before the summary request.
  
  Summary:
  1. Primary Request and Intent:
     User requested a photography portfolio website to display landscape and historic site photographs with a modern but cozy style. Over the conversation, this evolved into:
     - A photobook-style design with warm colors and elegant typography
     - Password-protected photo upload functionality via web interface
     - Auto-display of uploaded photos
     - Edit/delete capabilities for photos with title customization
     - Dynamic header with frosted glass effect
     - Paper texture background
     - Finally: A book-style layout with page-flipping animation (cover page, Nature page, City page)
  
  2. Key Technical Concepts:
     - CSS 3D transforms for page-flip animation (`transform-style: preserve-3d`, `backface-visibility: hidden`, `rotateY`)
     - Node.js HTTP server for file uploads with multipart form parsing
     - Docker containerization for the upload API
     - Nginx reverse proxy configuration
     - CSS backdrop-filter for frosted glass effect
     - SVG noise pattern for paper texture
     - Sticky header with scroll-based hide/show behavior
     - Lightbox image viewer
     - Metadata storage in JSON for photo titles
  
  3. Files and Code Sections:
  
     - `/var/www/rosy.shitchell.com/srv/web/photography/index.html`
       - Main photography gallery, completely rewritten to book-style with page flip animation
       - Contains 3 pages: Cover, Nature (Chapter One), City (Chapter Two)
       - Key structure: `.book` container with `.page` elements, each having `.page-front` and `.page-back`
       - Navigation arrows and indicator dots at bottom
       - Full lightbox and edit modal functionality preserved
  
     - `/var/www/rosy.shitchell.com/srv/web/photography/upload.html`
       - Photo upload form with password, category (Nature/City), title fields
       - Drag & drop upload zone
       - Categories updated from "Landscapes/Historic Sites" to "Nature/City"
  
     - `/var/www/rosy.shitchell.com/srv/upload-api/server.js`
       - Node.js HTTP server handling:
         - `GET /photos` - lists all photos with metadata
         - `POST /upload` - handles file upload with title
         - `POST /edit` - edits photo title
         - `POST /delete` - deletes photo
       - Password: `Rr16234160!`
  
     - `/var/www/rosy.shitchell.com/srv/upload-api/docker-compose.yml`
       - Docker container config, port 8083, volume mounts uploads directory
       - Environment variable for password
  
     - `/etc/nginx/sites-available/rosy.shitchell.com`
       - Added `/upload-api/` location block proxying to port 8083
  
  4. Errors and fixes:
     - **403 Forbidden Error**: Files had permissions `-rw-------` instead of `-rw-r--r--`
       - Fixed with `chmod 644` on HTML files
     - **Photos not auto-displaying**: Uploaded photos went to folder but didn't appear on gallery
       - Fixed by adding `/photos` API endpoint and JavaScript to fetch/render dynamically
     - **No "Add more" link after upload**: Link only showed when gallery was empty
       - Fixed by always showing the link in page footer after photos
  
  5. Problem Solving:
     - Iterative color adjustments (too bright → too dark → balanced warm taupe)
     - Header size reduction through multiple iterations
     - Font matching between title elements
     - Book page-flip animation with proper z-index stacking and 3D transforms
  
  6. All user messages:
     - "can you make a website that I can display my photograph? i have photographs of landscape and history sites. please make the style more modern but cozy"
     - "Can you make this less bright? and yes side pane is a good idea. I do have a photo where can i upload? Can i upload thru the web?"
     - "drag"
     - "where can i put?"
     - "i can't drag to this window"
     - "i'm fine i will add later"
     - "can you put the color lighter"
     - "can you make the user can upload the pic directly to the web?"
     - "also can you make the website look more like a Photobook?"
     - "the link shows 403"
     - "what is the password?"
     - "can you set the password to Rr16234160!"
     - "i upload a photo but i don't see it on the https://rosy.shitchell.com/photography/#landscapes"
     - "yes please you're awesome :))"
     - "please allow me to change the photo title. Umm seems like the photos is a bit too big, can make it smaller and when you click on it, it will have a floating screen to show a bit bigger? Thanks :))"
     - "can you edit the photo or the title of the photo afterwards. also, there is no link to upload photos on landscape after I uploaded the first photo"
     - "Top section where you say Rosy is too big make it much smaller thanks :)))"
     - "for the hearder, make space smaller and shorter"
     - "I would love to see 'Rosy' and 'photography' have the same font which match the scene and cozy and warm"
     - "Hey can you remove the 'return home' link on bottom of the page?"
     - "make the bottom space 1/2 smaller"
     - "Can you change the title landscape to Nature. historic sites to city?"
     - "do you have any dynamic header and background design recommendations?"
     - "Paper texture background"
     - "dynamic header?"
     - "glass effect"
     - "can you make a first page like a book and nature second page and third page is city. make a 'flipping pages' effect?"
  
  7. Pending Tasks:
     - None explicitly pending - the book with page-flip effect was just completed
  
  8. Current Work:
     Just completed implementing a book-style layout with page-flipping animation. The entire `index.html` was rewritten with:
     - 3D CSS page-flip animation
     - Cover page with "Rosy Photography" title
     - Nature page (Chapter One) with photo grid
     - City page (Chapter Two) with photo grid
     - Navigation arrows and page indicator dots
     - All previous functionality preserved (lightbox, edit/delete, auto-load photos)
  
  9. Optional Next Step:
     The book page-flip implementation was just completed. User should test the new book interface at https://rosy.shitchell.com/photography. No explicit next step was requested - awaiting user feedback on the new book design..
  Please continue the conversation from where we left it off without asking the user any further questions. Continue with the last task that you were asked to work on.
ASSISTANT
  I was working on implementing the book-style layout with page-flipping animation. Let me check the current state of the index.html file to see where we left off:
  Tokens: in=2 out=1 cache=17760
ASSISTANT
Tool: Read
  (toolu_01YB2tfY32jtBnQGdcCMuwXj)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
  Tokens: in=2 out=113 cache=17760
Result
  (toolu_01YB2tfY32jtBnQGdcCMuwXj)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #d8d3cc;
        13→            --paper: #eae6e0;
        14→            --paper-dark: #ddd8d0;
        15→            --ink: #2c2825;
        16→            --ink-light: #5a534d;
        17→            --ink-faint: #8a847d;
        18→            --accent: #7a6348;
        19→            --shadow: rgba(44, 40, 37, 0.12);
        20→            --shadow-deep: rgba(44, 40, 37, 0.25);
    ... (977 lines total)
ASSISTANT
  The book-style layout with page-flipping animation is fully implemented. Let me update the todo list and verify the site is working:
  Tokens: in=0 out=1 cache=39295
ASSISTANT
Tool: TodoWrite
  (toolu_01GKERqkhizPFoBfCN9HTAk2)
    todos: [{'content': 'Create book structure with cover, nature, and city pages', 'status': 'completed', 'activeForm': 'Creating book structure with pages'}, {'content': 'Add CSS page flip animation', 'status'...
  Tokens: in=0 out=240 cache=39295
ASSISTANT
Tool: Bash
  (toolu_01VGoraMjcijWRF2FzgRq8tV)
    command: curl -s -o /dev/null -w "%{http_code}" https://rosy.shitchell.com/photography/
    description: Check photography page status
  Tokens: in=0 out=240 cache=39295
Result
  (toolu_01GKERqkhizPFoBfCN9HTAk2)
    Todos have been modified successfully. Ensure that you continue to use the todo list to track your progress. Please proceed with the current tasks if applicable
Result
  (toolu_01VGoraMjcijWRF2FzgRq8tV)
    200
ASSISTANT
  The photography page is live. The book-style layout with page-flipping animation has been fully implemented. Here's what's now in place:
  
  **Book Structure:**
  - **Cover page** - "Rosy · Photography" with an elegant title design and "Click to open →" hint
  - **Page 1 back** - A quote: "A collection of moments captured through my lens"
  - **Nature page** - Chapter One with your nature photos
  - **Page 2 back** - John Muir quote about nature
  - **City page** - Chapter Two with your city/urban photos  
  - **Page 3 back** - "Thank you for viewing" with upload link
  
  **Page Flip Features:**
  - Smooth 3D CSS rotation animation (0.8s cubic-bezier easing)
  - Click anywhere on a page to flip it
  - Navigation arrows at bottom (← →)
  - Page indicator dots to jump to any page
  - Keyboard support (arrow keys to flip)
  - Paper texture and edge shadow effects for realism
  - Book spine shadow on left side
  
  **All existing features preserved:**
  - Photo lightbox viewer
  - Edit/delete functionality with password
  - Auto-loading photos from the API
  
  You can test it at: https://rosy.shitchell.com/photography/
  Tokens: in=0 out=293 cache=51425
File History Snapshot (2025-12-08T00:49:16.459Z)
USER
  Can you move Pages count and  Add more from middle to left bottom on the book? becuase it was blocked by the arrow button? We also need to change the photobook cover to be a bit more cozy and nature 
ASSISTANT
  I'll make those two changes - moving the page count/add more link to the left bottom, and making the cover more cozy and nature-themed.
  Tokens: in=2 out=1 cache=51774
ASSISTANT
Tool: Edit
  (toolu_01LxqXyohrTXJu8fXFX3N2Q5)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Page footer */
            .page-footer {
                text-align: center;
                padding-top: 15px;
                flex-shrink: 0;
                border-top: 1px solid rgba(0,0,0,0.05);
            ...
    new_string:         /* Page footer */
            .page-footer {
                text-align: left;
                padding-top: 15px;
                flex-shrink: 0;
                border-top: 1px solid rgba(0,0,0,0.05);
              ...
  Tokens: in=2 out=359 cache=51774
Result
  (toolu_01LxqXyohrTXJu8fXFX3N2Q5)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       309→        .photo-frame:hover .edit-btn {
       310→            opacity: 1;
       311→        }
       312→
       313→        /* Page footer */
       314→        .page-footer {
       315→            text-align: left;
       316→            padding-top: 15px;
       317→            flex-shrink: 0;
       318→            border-top: 1px solid rgba(0,0,0,0.05);
       319→            margin-top: auto;
       320→        }
       321→
       322→        .page-number {
       323→            font-size: 0.75rem;
       324→            color: var(--ink-faint);
       325→        }
       326→
       327→        .page-number a {
    ... (22 lines total)
ASSISTANT
  Now let me update the cover to be more cozy and nature-themed:
  Tokens: in=0 out=1 cache=52116
ASSISTANT
Tool: Edit
  (toolu_01BmjaGpyaUqtigsUyGJMRno)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=0 out=1303 cache=52116
Result
  (toolu_01BmjaGpyaUqtigsUyGJMRno)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       134→            border-radius: 5px 0 0 5px;
       135→            z-index: 10;
       136→        }
       137→
       138→        /* Cover Page Styles */
       139→        .cover-content {
       140→            height: 100%;
       141→            display: flex;
       142→            flex-direction: column;
       143→            align-items: center;
       144→            justify-content: center;
       145→            padding: 40px;
       146→            text-align: center;
       147→            position: relative;
       148→            background: linear-gradient(180deg,
       149→                #e8e4dd 0%,
       150→                #d4cfc6 30%,
       151→                #c9c4b8 60%,
       152→                #beb8aa 100%);
    ... (99 lines total)
ASSISTANT
  Now let me update the HTML for the cover page to include the botanical decorations:
  Tokens: in=0 out=1 cache=52759
ASSISTANT
Tool: Edit
  (toolu_011BVUn3u9KARfWaURvAoFEX)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <h1 class="cover-title">Rosy<...
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <div class="cover-decoration"...
  Tokens: in=0 out=433 cache=52759
Result
  (toolu_011BVUn3u9KARfWaURvAoFEX)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       625→</head>
       626→<body>
       627→    <!-- The Book -->
       628→    <div class="book" id="book">
       629→        <!-- Page 1: Cover -->
       630→        <div class="page" id="page-1">
       631→            <div class="page-front">
       632→                <div class="cover-content">
       633→                    <div class="cover-decoration">🌿</div>
       634→                    <h1 class="cover-title">Rosy</h1>
       635→                    <p class="cover-subtitle">Photography</p>
       636→                    <div class="cover-line"></div>
       637→                    <div class="cover-botanical">
       638→                        <span>🍃</span>
       639→                        <span>🌸</span>
       640→                        <span>🍃</span>
       641→                    </div>
       642→                    <p class="cover-hint">click to open</p>
       643→                </div>
    ... (25 lines total)
ASSISTANT
  Done! Here's what I changed:
  
  **Page count/Add more link:**
  - Moved from center to left bottom of the book pages so it won't be blocked by the navigation arrows
  
  **Cover redesign - more cozy and nature-themed:**
  - Added a warm gradient background (cream to soft beige tones)
  - Double border in sage green color with rounded corners
  - Added a decorative fern emoji (🌿) at the top
  - Added botanical elements (🍃🌸🍃) below the title
  - Changed the divider line to a sage green gradient
  - Made the "click to open" hint more subtle and italic
  - Overall softer, warmer, more natural feel
  
  You can view the changes at: https://rosy.shitchell.com/photography/
  Tokens: in=0 out=180 cache=55321
File History Snapshot (2025-12-08T00:51:46.296Z)
USER
  cover is not what I wanted LOL
ASSISTANT
  Haha, fair enough! Let me know what kind of vibe you're going for - here are a few directions I could take:
  
  1. **Minimalist nature** - Simple leaf/branch illustration, muted earth tones, clean and quiet
  2. **Vintage botanical** - Like an old pressed flower journal, aged paper look, delicate botanical drawings
  3. **Warm & woodsy** - Dark wood or leather texture, gold accents, like a classic photo album
  4. **Soft & dreamy** - Blurred nature photo background, soft focus, ethereal feel
  5. **Handwritten/artsy** - Script fonts, watercolor-style accents, artistic and personal
  
  Or describe what you have in mind - colors, textures, mood? I can adjust from there!
  Tokens: in=2 out=178 cache=56193
File History Snapshot (2025-12-08T00:52:11.093Z)
USER
  artsy?
ASSISTANT
Tool: Edit
  (toolu_016K6rdqU7p7tYZtGr8pgKvy)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles - Artsy/Handwritten */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
     ...
  Tokens: in=2 out=1792 cache=56485
Result
  (toolu_016K6rdqU7p7tYZtGr8pgKvy)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       134→            border-radius: 5px 0 0 5px;
       135→            z-index: 10;
       136→        }
       137→
       138→        /* Cover Page Styles - Artsy/Handwritten */
       139→        .cover-content {
       140→            height: 100%;
       141→            display: flex;
       142→            flex-direction: column;
       143→            align-items: center;
       144→            justify-content: center;
       145→            padding: 40px;
       146→            text-align: center;
       147→            position: relative;
       148→            background:
       149→                radial-gradient(ellipse at 20% 80%, rgba(199, 165, 137, 0.4) 0%, transparent 50%),
       150→                radial-gradient(ellipse at 80% 20%, rgba(169, 140, 160, 0.3) 0%, transparent 50%),
       151→                radial-gradient(ellipse at 60% 60%, rgba(139, 154, 125, 0.25) 0%, transparent 40%),
       152→                linear-gradient(180deg, #f5f1eb 0%, #ebe5db 100%);
    ... (101 lines total)
ASSISTANT
  Now let me update the HTML to match the new artsy style:
  Tokens: in=0 out=1 cache=56669
Queue: enqueue
  make the book fit to entire screen
Queue: remove
ASSISTANT
Tool: Edit
  (toolu_01QE75MvbcM5wosTWdAXpDcG)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <div class="cover-decoration"...
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <h1 class="cover-title">Rosy<...
  Tokens: in=0 out=457 cache=56669
Result
  (toolu_01QE75MvbcM5wosTWdAXpDcG)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       627→</head>
       628→<body>
       629→    <!-- The Book -->
       630→    <div class="book" id="book">
       631→        <!-- Page 1: Cover -->
       632→        <div class="page" id="page-1">
       633→            <div class="page-front">
       634→                <div class="cover-content">
       635→                    <h1 class="cover-title">Rosy</h1>
       636→                    <p class="cover-subtitle">Photography</p>
       637→                    <div class="cover-brushstroke"></div>
       638→                    <div class="cover-doodle">✿ ✦ ✿</div>
       639→                    <p class="cover-hint">click to open</p>
       640→                </div>
       641→            </div>
       642→            <div class="page-back">
       643→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       644→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
       645→                        A collection of moments<br>captured through my lens
ASSISTANT
  Let me also make the book fit the entire screen:
  Tokens: in=0 out=3 cache=59822
ASSISTANT
Tool: Edit
  (toolu_01Xk95jMovsR19NprpBrkHAN)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         body {
                font-family: 'Montserrat', sans-serif;
                background: linear-gradient(135deg, #8b7355 0%, #5a4a3a 100%);
                min-height: 100vh;
                display: flex;
     ...
    new_string:         body {
                font-family: 'Montserrat', sans-serif;
                background: linear-gradient(135deg, #8b7355 0%, #5a4a3a 100%);
                min-height: 100vh;
                display: flex;
     ...
  Tokens: in=0 out=477 cache=59822
Result
  (toolu_01Xk95jMovsR19NprpBrkHAN)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        25→            padding: 0;
        26→            box-sizing: border-box;
        27→        }
        28→
        29→        body {
        30→            font-family: 'Montserrat', sans-serif;
        31→            background: linear-gradient(135deg, #8b7355 0%, #5a4a3a 100%);
        32→            min-height: 100vh;
        33→            display: flex;
        34→            align-items: center;
        35→            justify-content: center;
        36→            padding: 10px;
        37→            perspective: 2000px;
        38→            overflow: hidden;
        39→        }
        40→
        41→        /* Book Container */
        42→        .book {
        43→            width: calc(100vw - 20px);
    ... (30 lines total)
ASSISTANT
  Also update the responsive styles for smaller screens:
  Tokens: in=0 out=1 cache=60803
ASSISTANT
Tool: Edit
  (toolu_01P9bqLyBaVLtGUTQbPDjYUS)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Responsive */
            @media (max-width: 600px) {
                body {
                    padding: 10px;
                }
    
                .book {
                    width: 95vw;
                    height: 8...
    new_string:         /* Responsive */
            @media (max-width: 600px) {
                body {
                    padding: 5px;
                }
    
                .book {
                    width: calc(100vw - 10px);
                ...
  Tokens: in=0 out=464 cache=60803
Result
  (toolu_01P9bqLyBaVLtGUTQbPDjYUS)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       598→            margin-top: 10px;
       599→            width: 100%;
       600→        }
       601→
       602→        /* Responsive */
       603→        @media (max-width: 600px) {
       604→            body {
       605→                padding: 5px;
       606→            }
       607→
       608→            .book {
       609→                width: calc(100vw - 10px);
       610→                height: calc(100vh - 10px);
       611→            }
       612→
       613→            .chapter-content {
       614→                padding: 15px;
       615→            }
       616→
    ... (42 lines total)
ASSISTANT
  Done! Here's what changed:
  
  **Artsy cover:**
  - Soft watercolor-style background with overlapping color splashes (warm terracotta, soft mauve, sage green)
  - Large italic "Rosy" title - feels more handwritten/personal
  - "PHOTOGRAPHY" in small caps with wide letter spacing
  - Brushstroke-style divider line (slightly tilted for that hand-painted feel)
  - Delicate doodle symbols (✿ ✦ ✿)
  - Softer "~ click to open ~" hint
  
  **Full screen book:**
  - Book now fills the entire screen (minus 20px padding)
  - No max-width or max-height limits
  - Adjusted for mobile too
  
  Check it out at: https://rosy.shitchell.com/photography/
  Tokens: in=0 out=190 cache=61650
File History Snapshot (2025-12-08T00:58:33.417Z)
USER
  can you take off the Rosy Photography and keep the cover blank?
ASSISTANT
Tool: Edit
  (toolu_01U3N984a6wKMCPFXYFdYhdi)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <h1 class="cover-title">Rosy<...
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <p class="cover-hint">click t...
  Tokens: in=2 out=324 cache=12598
Result
  (toolu_01U3N984a6wKMCPFXYFdYhdi)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       636→</head>
       637→<body>
       638→    <!-- The Book -->
       639→    <div class="book" id="book">
       640→        <!-- Page 1: Cover -->
       641→        <div class="page" id="page-1">
       642→            <div class="page-front">
       643→                <div class="cover-content">
       644→                    <p class="cover-hint">click to open</p>
       645→                </div>
       646→            </div>
       647→            <div class="page-back">
       648→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       649→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
       650→                        A collection of moments<br>captured through my lens
ASSISTANT
  Done! The cover is now blank with just the watercolor background and a subtle "~ click to open ~" hint at the center. Check it out at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=49 cache=62848
File History Snapshot (2025-12-08T00:59:33.060Z)
USER
  don't show "click to open"
ASSISTANT
Tool: Edit
  (toolu_01YV9zEbuZ2XMFfmmHvPEDwW)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <p class="cover-hint">click t...
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content"></div>
                </div>
  Tokens: in=2 out=228 cache=63469
Result
  (toolu_01YV9zEbuZ2XMFfmmHvPEDwW)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       636→</head>
       637→<body>
       638→    <!-- The Book -->
       639→    <div class="book" id="book">
       640→        <!-- Page 1: Cover -->
       641→        <div class="page" id="page-1">
       642→            <div class="page-front">
       643→                <div class="cover-content"></div>
       644→            </div>
       645→            <div class="page-back">
       646→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       647→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
       648→                        A collection of moments<br>captured through my lens
ASSISTANT
  Done! The cover is now completely blank - just the soft watercolor background.
  Tokens: in=0 out=19 cache=63630
File History Snapshot (2025-12-08T01:00:28.095Z)
USER
  I have a photo I want to put to fit to cover page. Can you send a link so I can upload thru it?
ASSISTANT
  You can upload the cover photo here: https://rosy.shitchell.com/photography/upload.html
  
  Once you upload it, let me know and I'll set it as the cover background!
  Tokens: in=2 out=47 cache=64129
File History Snapshot (2025-12-08T01:01:29.704Z)
USER
  yep i just uploaded it!
ASSISTANT
  Let me find the photo you just uploaded:
  Tokens: in=2 out=1 cache=64176
ASSISTANT
Tool: Bash
  (toolu_01G49bRs7jBG7PniRub4aptp)
    command: ls -lt /var/www/rosy.shitchell.com/srv/web/photography/uploads/*/ | head -20
    description: List recently uploaded photos
  Tokens: in=2 out=112 cache=64176
Result
  (toolu_01G49bRs7jBG7PniRub4aptp)
    /var/www/rosy.shitchell.com/srv/web/photography/uploads/landscapes/:
    total 5316
    -rw-rw-r--+ 1 root rosy-web  233279 Dec  8 01:01 img_5296.jpg_1765155678042_37e365a5.jpg
    -rw-rw-r--+ 1 root rosy-web 1984888 Dec  7 18:24 img_5507.jpg_1765131867270_ae5af9c4.jpg
    -rw-rw-r--+ 1 root rosy-web 2921732 Dec  7 18:21 ncyg5748.png_1765131669664_c50f1298.png
    -rw-rw-r--+ 1 root rosy-web  298882 Dec  7 05:01 whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg
    
    /var/www/rosy.shitchell.com/srv/web/photography/uploads/historic/:
    total 6324
    -rw-rw-r--+ 1 root rosy-web  777681 Dec  7 18:47 whatsapp_image_2025-12-07_at_13.45.20_ad896dfd_1765133224971_89ce7ba0.jpg
    -rw-rw-r--+ 1 root rosy-web 3032601 Dec  7 18:35 img_3465_1765132533652_c2217959.jpg
    -rw-rw-r--+ 1 root rosy-web  130430 Dec  7 18:27 whatsapp_image_2025-12-07_at_13.26.06_bcd73529_1765132027308_198d5c57.jpg
    -rw-rw-r--+ 1 root rosy-web 2529592 Dec  7 18:00 img_4751_1765130409547_475edc7c.jpg
ASSISTANT
  I see the most recent one is `img_5296.jpg_1765155678042_37e365a5.jpg` in landscapes. Let me set that as the cover:
  Tokens: in=0 out=1 cache=64336
ASSISTANT
Tool: Edit
  (toolu_01CHkPV3TviTuxPhTZUWS1Be)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles - Artsy/Handwritten */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
     ...
    new_string:         /* Cover Page Styles - Artsy/Handwritten */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
     ...
  Tokens: in=0 out=510 cache=64336
Result
  (toolu_01CHkPV3TviTuxPhTZUWS1Be)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles - Artsy/Handwritten */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 40px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
       150→        }
       151→
       152→        /* Watercolor splash effect */
       153→        .cover-content::before {
    ... (21 lines total)
ASSISTANT
  Let me also remove the watercolor overlay effect so your photo shows clearly:
  Tokens: in=0 out=1 cache=64989
ASSISTANT
Tool: Edit
  (toolu_019J7p8vwTnjPVXtc38anU5e)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Watercolor splash effect */
            .cover-content::before {
                content: '';
                position: absolute;
                top: 10%;
                left: 5%;
                width: 90%;
       ...
    new_string: 
  Tokens: in=0 out=276 cache=64989
Result
  (toolu_019J7p8vwTnjPVXtc38anU5e)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       148→            position: relative;
       149→            background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
       150→        }
       151→
       152→
       153→        .cover-title {
       154→            font-family: 'Cormorant Garamond', Georgia, serif;
       155→            font-size: clamp(3.5rem, 10vw, 6rem);
       156→            font-weight: 300;
ASSISTANT
  Done! Your photo is now the cover of the book. Check it out at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=33 cache=65903
File History Snapshot (2025-12-08T01:04:14.796Z)
USER
  on the bottom add a small line saying  "Photo by my Dear friend, Chien :)" on the top have big and straight words saying "THRU LENS"
ASSISTANT
Tool: Edit
  (toolu_01SptBVZKYusKWG1i7WVuf4a)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content"></div>
                </div>
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <h1 class="cover-title">THRU ...
  Tokens: in=2 out=257 cache=66378
Result
  (toolu_01SptBVZKYusKWG1i7WVuf4a)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       619→</head>
       620→<body>
       621→    <!-- The Book -->
       622→    <div class="book" id="book">
       623→        <!-- Page 1: Cover -->
       624→        <div class="page" id="page-1">
       625→            <div class="page-front">
       626→                <div class="cover-content">
       627→                    <h1 class="cover-title">THRU LENS</h1>
       628→                    <p class="cover-credit">Photo by my Dear friend, Chien :)</p>
       629→                </div>
       630→            </div>
       631→            <div class="page-back">
       632→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       633→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
       634→                        A collection of moments<br>captured through my lens
ASSISTANT
  Now let me update the CSS to position the title at top and credit at bottom:
  Tokens: in=0 out=1 cache=66552
ASSISTANT
Tool: Edit
  (toolu_01Ts164tx6uRQR7CMwm6FgPg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles - Artsy/Handwritten */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
     ...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=0 out=1166 cache=66552
Result
  (toolu_01Ts164tx6uRQR7CMwm6FgPg)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: space-between;
       146→            padding: 40px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
       150→        }
       151→
       152→        .cover-title {
       153→            font-family: 'Montserrat', sans-serif;
    ... (40 lines total)
ASSISTANT
  Done! The cover now has:
  - **"THRU LENS"** - big, straight text at the top in white with a subtle shadow
  - **"Photo by my Dear friend, Chien :)"** - small italic text at the bottom
  
  Check it out at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=77 cache=67138
File History Snapshot (2025-12-08T01:05:16.902Z)
USER
  photo too bit make it smaller thanks
ASSISTANT
Tool: Edit
  (toolu_01VsfDzLd3ZSeA5Di6uSELzp)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
    new_string:             background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / 60% auto no-repeat;
                background-color: #1a1a1a;
  Tokens: in=2 out=207 cache=68996
Result
  (toolu_01VsfDzLd3ZSeA5Di6uSELzp)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       145→            justify-content: space-between;
       146→            padding: 40px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / 60% auto no-repeat;
       150→            background-color: #1a1a1a;
       151→        }
       152→
       153→        .cover-title {
       154→            font-family: 'Montserrat', sans-serif;
ASSISTANT
  Done! The photo is now smaller (60% of the cover width) with a dark background around it. Check it at https://rosy.shitchell.com/photography/
  
  If you want it even smaller or a different size, just let me know!
  Tokens: in=0 out=59 cache=69081
File History Snapshot (2025-12-08T01:10:12.046Z)
USER
  cover photo font- Garamond Premier
ASSISTANT
Tool: Edit
  (toolu_01SuWabnWAL7kxXrSuoFndJn)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string: <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
    new_string: <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=EB+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500&display=swap" rel...
  Tokens: in=2 out=281 cache=69499
Result
  (toolu_01SuWabnWAL7kxXrSuoFndJn)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=EB+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #d8d3cc;
        13→            --paper: #eae6e0;
ASSISTANT
Tool: Edit
  (toolu_01M4TdDNJsQuibR9xdd1oTys)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-title {
                font-family: 'Montserrat', sans-serif;
                font-size: clamp(2rem, 6vw, 4rem);
                font-weight: 500;
                letter-spacing: 0.15em;
                c...
    new_string:         .cover-title {
                font-family: 'EB Garamond', 'Garamond', Georgia, serif;
                font-size: clamp(2rem, 6vw, 4rem);
                font-weight: 500;
                letter-spacing: 0.15...
  Tokens: in=0 out=347 cache=69671
Result
  (toolu_01M4TdDNJsQuibR9xdd1oTys)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       149→            background: url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / 60% auto no-repeat;
       150→            background-color: #1a1a1a;
       151→        }
       152→
       153→        .cover-title {
       154→            font-family: 'EB Garamond', 'Garamond', Georgia, serif;
       155→            font-size: clamp(2rem, 6vw, 4rem);
       156→            font-weight: 500;
       157→            letter-spacing: 0.15em;
       158→            color: white;
       159→            text-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
       160→            margin-top: 20px;
       161→        }
       162→
       163→        .cover-credit {
       164→            font-family: 'Cormorant Garamond', Georgia, serif;
       165→            font-size: clamp(0.8rem, 1.5vw, 1rem);
ASSISTANT
  Done! The "THRU LENS" title now uses EB Garamond (the closest Google Fonts equivalent to Garamond Premier). Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=53 cache=70258
File History Snapshot (2025-12-08T01:11:39.269Z)
USER
  make the "thru lens" to fit whole page and color is the cover photo color and you can take offf cover photo after doing the color
ASSISTANT
Tool: Edit
  (toolu_01Wo5ne51FqsKpo8bvPX3cWJ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=775 cache=70956
Result
  (toolu_01Wo5ne51FqsKpo8bvPX3cWJ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→        }
       151→
       152→        .cover-title {
       153→            font-family: 'EB Garamond', 'Garamond', Georgia, serif;
    ... (39 lines total)
ASSISTANT
  Done! The cover now has:
  - **"THRU LENS"** in huge text filling the page
  - Sage green color (#8b9a7d) inspired by the nature photo
  - Soft cream background (#f5f0eb)
  - Credit text at the bottom in a matching green
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=88 cache=71143
File History Snapshot (2025-12-08T01:13:09.973Z)
USER
  keep the cover photo but make it lighter
ASSISTANT
Tool: Edit
  (toolu_018S636fxYDMpk9mopDoXh3w)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=355 cache=72434
Result
  (toolu_018S636fxYDMpk9mopDoXh3w)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background:
       150→                linear-gradient(rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)),
       151→                url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
       152→        }
       153→
    ... (23 lines total)
ASSISTANT
  Done! The cover photo is back with a 50% white overlay to lighten it, and the big "THRU LENS" text is on top. Check it at https://rosy.shitchell.com/photography/
  
  Want it lighter or darker? I can adjust the overlay opacity.
  Tokens: in=0 out=68 cache=72531
File History Snapshot (2025-12-08T01:13:59.689Z)
USER
  text color dark
ASSISTANT
Tool: Edit
  (toolu_01A1mELXCe2m7HXU6FFv1A67)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-title {
                font-family: 'EB Garamond', 'Garamond', Georgia, serif;
                font-size: clamp(15vw, 20vw, 25vw);
                font-weight: 400;
                letter-spacing: 0.0...
    new_string:         .cover-title {
                font-family: 'EB Garamond', 'Garamond', Georgia, serif;
                font-size: clamp(15vw, 20vw, 25vw);
                font-weight: 400;
                letter-spacing: 0.0...
  Tokens: in=2 out=496 cache=73361
Result
  (toolu_01A1mELXCe2m7HXU6FFv1A67)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       150→                linear-gradient(rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)),
       151→                url('/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg') center center / cover no-repeat;
       152→        }
       153→
       154→        .cover-title {
       155→            font-family: 'EB Garamond', 'Garamond', Georgia, serif;
       156→            font-size: clamp(15vw, 20vw, 25vw);
       157→            font-weight: 400;
       158→            letter-spacing: 0.05em;
       159→            color: #2c2825;
       160→            line-height: 0.9;
       161→        }
       162→
       163→        .cover-credit {
       164→            font-family: 'Cormorant Garamond', Georgia, serif;
       165→            font-size: clamp(0.7rem, 1.2vw, 0.9rem);
       166→            font-style: italic;
       167→            color: #3d3530;
       168→            position: absolute;
    ... (26 lines total)
ASSISTANT
  Done! Text is now dark brown (#2c2825). Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=33 cache=73433
File History Snapshot (2025-12-08T01:16:36.607Z)
USER
  make an animation of photos keep scrolling on cover photo? and take off the thru lens 
ASSISTANT
Tool: Edit
  (toolu_01Mb4udVsjLXgBYmc6n7iCn2)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=865 cache=74362
Result
  (toolu_01Mb4udVsjLXgBYmc6n7iCn2)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        .cover-slideshow {
    ... (65 lines total)
ASSISTANT
  Now let me update the HTML to remove the title and add the slideshow container:
  Tokens: in=0 out=1 cache=74519
ASSISTANT
Tool: Edit
  (toolu_013HgkHtsf8Qcygr3KqEHiz9)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <h1 class="cover-title">THRU ...
    new_string:         <!-- Page 1: Cover -->
            <div class="page" id="page-1">
                <div class="page-front">
                    <div class="cover-content">
                        <div class="cover-slideshow" ...
  Tokens: in=0 out=336 cache=74519
Result
  (toolu_013HgkHtsf8Qcygr3KqEHiz9)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       600→</head>
       601→<body>
       602→    <!-- The Book -->
       603→    <div class="book" id="book">
       604→        <!-- Page 1: Cover -->
       605→        <div class="page" id="page-1">
       606→            <div class="page-front">
       607→                <div class="cover-content">
       608→                    <div class="cover-slideshow" id="coverSlideshow"></div>
       609→                    <div class="cover-overlay"></div>
       610→                    <p class="cover-credit">Photo by my Dear friend, Chien :)</p>
       611→                </div>
       612→            </div>
       613→            <div class="page-back">
       614→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       615→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
       616→                        A collection of moments<br>captured through my lens
ASSISTANT
  Now let me add the JavaScript for the slideshow animation:
  Tokens: in=0 out=4 cache=76104
ASSISTANT
Tool: Edit
  (toolu_01433SJG14g3UMoiwKfdAjPE)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         loadPhotos();
        </script>
    new_string:         loadPhotos();
    
            // Cover slideshow
            let slideshowImages = [];
            let currentSlide = 0;
            let slideshowInterval;
    
            function setupSlideshow(photos) {
                ...
  Tokens: in=0 out=1018 cache=76104
Result
  (toolu_01433SJG14g3UMoiwKfdAjPE)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       975→                console.error('Failed to load photos:', err);
       976→            }
       977→        }
       978→
       979→        loadPhotos();
       980→
       981→        // Cover slideshow
       982→        let slideshowImages = [];
       983→        let currentSlide = 0;
       984→        let slideshowInterval;
       985→
       986→        function setupSlideshow(photos) {
       987→            const slideshow = document.getElementById('coverSlideshow');
       988→            slideshowImages = [];
       989→
       990→            // Collect all photos
       991→            if (photos.landscapes) {
       992→                photos.landscapes.forEach(p => slideshowImages.push(p.path));
       993→            }
    ... (94 lines total)
ASSISTANT
  I need to remove the duplicate `loadPhotos()` call at the end and also remove the old loadPhotos function since we're replacing it:
  Tokens: in=0 out=1 cache=76884
ASSISTANT
Tool: Edit
  (toolu_01GycAmW15sU7FBGDr4dvRnk)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Load photos
            async function loadPhotos() {
                try {
                    const response = await fetch('/upload-api/photos');
                    const photos = await response.json();...
    new_string:         // Cover slideshow
  Tokens: in=0 out=645 cache=76884
Result
  (toolu_01GycAmW15sU7FBGDr4dvRnk)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       936→
       937→            return frame;
       938→        }
       939→
       940→        // Cover slideshow
       941→        let slideshowImages = [];
       942→        let currentSlide = 0;
       943→        let slideshowInterval;
       944→
ASSISTANT
  Now I need to fix the loadPhotos function reference:
  Tokens: in=0 out=2 cache=79237
ASSISTANT
Tool: Edit
  (toolu_01A8kzFbMn5H1mYGdR9aUa3N)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Modify loadPhotos to also setup slideshow
            const originalLoadPhotos = loadPhotos;
            loadPhotos = async function() {
    new_string:         // Load photos and setup slideshow
            async function loadPhotos() {
  Tokens: in=0 out=176 cache=79237
Result
  (toolu_01A8kzFbMn5H1mYGdR9aUa3N)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       975→                }, 4000);
       976→            }
       977→        }
       978→
       979→        // Load photos and setup slideshow
       980→        async function loadPhotos() {
       981→            try {
       982→                const response = await fetch('/upload-api/photos');
       983→                const photos = await response.json();
       984→                images = [];
ASSISTANT
Tool: Edit
  (toolu_01KNwi1c1FnxNGNBwS32a7LL)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             } catch (err) {
                    console.error('Failed to load photos:', err);
                }
            };
    
            loadPhotos();
        </script>
    new_string:             } catch (err) {
                    console.error('Failed to load photos:', err);
                }
            }
    
            loadPhotos();
        </script>
  Tokens: in=0 out=184 cache=80117
Result
  (toolu_01KNwi1c1FnxNGNBwS32a7LL)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
      1012→                } else {
      1013→                    cityGallery.innerHTML = '<p class="empty-message">No photos yet. <a href="/photography/upload.html?category=historic">Upload first photo</a></p>';
      1014→                }
      1015→
      1016→            } catch (err) {
      1017→                console.error('Failed to load photos:', err);
      1018→            }
      1019→        }
      1020→
      1021→        loadPhotos();
      1022→    </script>
      1023→</body>
      1024→</html>
      1025→
ASSISTANT
  Done! The cover now has:
  - A slideshow of all your photos that automatically scrolls every 4 seconds
  - Smooth fade transition between photos (1.5s)
  - Light white overlay to keep it soft
  - No "THRU LENS" text - just the photos and the credit line at the bottom
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=91 cache=80449
File History Snapshot (2025-12-08T01:19:24.338Z)
USER
  make the cover photo color original? add the floating fancy nevagate bar on center?
ASSISTANT
Tool: Edit
  (toolu_016qUGArGn67cVvsNHxadBKS)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-overlay {
                position: absolute;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                background: rgba(255, 255, 255, 0.4);
     ...
    new_string:         .cover-nav {
                position: absolute;
                bottom: 60px;
                left: 50%;
                transform: translateX(-50%);
                display: flex;
                gap: 8px;
            ...
  Tokens: in=2 out=484 cache=80954
Result
  (toolu_016qUGArGn67cVvsNHxadBKS)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       172→        .cover-slideshow img.active {
       173→            opacity: 1;
       174→        }
       175→
       176→        .cover-nav {
       177→            position: absolute;
       178→            bottom: 60px;
       179→            left: 50%;
       180→            transform: translateX(-50%);
       181→            display: flex;
       182→            gap: 8px;
       183→            padding: 12px 20px;
       184→            background: rgba(255, 255, 255, 0.85);
       185→            backdrop-filter: blur(10px);
       186→            border-radius: 30px;
       187→            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
       188→            z-index: 3;
       189→        }
       190→
    ... (43 lines total)
ASSISTANT
  Now update the HTML to add the nav and remove the overlay:
  Tokens: in=0 out=1 cache=81064
ASSISTANT
Tool: Edit
  (toolu_019S66YKnuDurkWyLGLYCDcn)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                        <div class="cover-slideshow" id="coverSlideshow"></div>
                        <div class="cover-overlay"></div>
                        <p cla...
    new_string:                 <div class="cover-content">
                        <div class="cover-slideshow" id="coverSlideshow"></div>
                        <div class="cover-nav" id="coverNav"></div>
                    ...
  Tokens: in=0 out=273 cache=81064
Result
  (toolu_019S66YKnuDurkWyLGLYCDcn)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       628→    <div class="book" id="book">
       629→        <!-- Page 1: Cover -->
       630→        <div class="page" id="page-1">
       631→            <div class="page-front">
       632→                <div class="cover-content">
       633→                    <div class="cover-slideshow" id="coverSlideshow"></div>
       634→                    <div class="cover-nav" id="coverNav"></div>
       635→                    <p class="cover-credit">Photo by my Dear friend, Chien :)</p>
       636→                </div>
       637→            </div>
       638→            <div class="page-back">
       639→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       640→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
ASSISTANT
  Now update the JavaScript to create the nav dots and make them clickable:
  Tokens: in=0 out=1 cache=82122
ASSISTANT
Tool: Edit
  (toolu_01Ma85HstGT1dZnEqgPh1nbn)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         function setupSlideshow(photos) {
                const slideshow = document.getElementById('coverSlideshow');
                slideshowImages = [];
    
                // Collect all photos
                if (...
    new_string:         function setupSlideshow(photos) {
                const slideshow = document.getElementById('coverSlideshow');
                const nav = document.getElementById('coverNav');
                slideshowIma...
  Tokens: in=0 out=1055 cache=82122
Result
  (toolu_01Ma85HstGT1dZnEqgPh1nbn)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       966→        let slideshowImages = [];
       967→        let currentSlide = 0;
       968→        let slideshowInterval;
       969→
       970→        function setupSlideshow(photos) {
       971→            const slideshow = document.getElementById('coverSlideshow');
       972→            const nav = document.getElementById('coverNav');
       973→            slideshowImages = [];
       974→
       975→            // Collect all photos
       976→            if (photos.landscapes) {
       977→                photos.landscapes.forEach(p => slideshowImages.push(p.path));
       978→            }
       979→            if (photos.historic) {
       980→                photos.historic.forEach(p => slideshowImages.push(p.path));
       981→            }
       982→
       983→            if (slideshowImages.length === 0) {
       984→                nav.style.display = 'none';
    ... (76 lines total)
ASSISTANT
  Done! The cover now has:
  - **Original photo colors** - no white overlay
  - **Fancy floating navigation bar** in the center with frosted glass effect
  - Clickable dots that expand when active
  - Click any dot to jump to that photo
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=1 cache=82804
File History Snapshot (2025-12-08T01:20:48.854Z)
USER
  make the cover page blank
ASSISTANT
Tool: Edit
  (toolu_01Lzn2zAo3bSHCuV3hggDRXU)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                        <div class="cover-slideshow" id="coverSlideshow"></div>
                        <div class="cover-nav" id="coverNav"></div>
                    ...
    new_string:                 <div class="cover-content">
                    </div>
  Tokens: in=2 out=202 cache=84863
Result
  (toolu_01Lzn2zAo3bSHCuV3hggDRXU)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       628→    <div class="book" id="book">
       629→        <!-- Page 1: Cover -->
       630→        <div class="page" id="page-1">
       631→            <div class="page-front">
       632→                <div class="cover-content">
       633→                </div>
       634→            </div>
       635→            <div class="page-back">
       636→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       637→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
ASSISTANT
  Done! The cover page is now blank. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=29 cache=85048
File History Snapshot (2025-12-08T01:22:38.189Z)
USER
  spinning wheel on cover page and have each chapter on it.
ASSISTANT
Tool: Edit
  (toolu_01Xw6YtfKVVHaCVG1P1mT2G3)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=1835 cache=85485
Result
  (toolu_01Xw6YtfKVVHaCVG1P1mT2G3)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        /* Spinning Wheel */
    ... (140 lines total)
ASSISTANT
  Now let me add the HTML for the spinning wheel:
  Tokens: in=0 out=1 cache=85527
ASSISTANT
Tool: Edit
  (toolu_014s5qWRMVNtVtGasE9iVHQY)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                    </div>
    new_string:                 <div class="cover-content">
                        <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner...
  Tokens: in=0 out=432 cache=85527
Result
  (toolu_014s5qWRMVNtVtGasE9iVHQY)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       678→    <div class="book" id="book">
       679→        <!-- Page 1: Cover -->
       680→        <div class="page" id="page-1">
       681→            <div class="page-front">
       682→                <div class="cover-content">
       683→                    <div class="spinning-wheel">
       684→                        <div class="wheel-ring"></div>
       685→                        <div class="wheel-ring-inner"></div>
       686→                        <div class="wheel-line"></div>
       687→                        <div class="wheel-line"></div>
       688→
       689→                        <div class="wheel-segment">
       690→                            <div class="wheel-chapter" onclick="event.stopPropagation(); flipTo(2);">
       691→                                <div class="wheel-chapter-title">Nature</div>
       692→                                <div class="wheel-chapter-sub">Chapter One</div>
       693→                            </div>
       694→                        </div>
       695→
       696→                        <div class="wheel-segment">
    ... (35 lines total)
ASSISTANT
  Done! The cover now has a spinning wheel with:
  - **Nature** (Chapter One) at the top
  - **City** (Chapter Two) at the bottom
  - The wheel slowly spins (20 seconds per rotation)
  - The text counter-rotates so it stays readable
  - Click on either chapter to flip directly to that page
  - Decorative rings and lines for a fancy look
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=106 cache=89100
File History Snapshot (2025-12-08T01:24:07.915Z)
USER
  oops all chapters needs to be seperate! LOL I love this haha
ASSISTANT
  Haha glad you love it! Let me fix the chapters so they're on opposite sides of the wheel instead of stacked:
  Tokens: in=2 out=4 cache=90104
ASSISTANT
Tool: Edit
  (toolu_01VfoN66txWQQregJiCyC231)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .wheel-segment {
                position: absolute;
                width: 100%;
                height: 100%;
                display: flex;
                align-items: flex-start;
                justify-content:...
    new_string:         .wheel-segment {
                position: absolute;
                width: 50%;
                height: 100%;
                display: flex;
                align-items: center;
                justify-content: cent...
  Tokens: in=2 out=365 cache=90104
Result
  (toolu_01VfoN66txWQQregJiCyC231)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       162→            from { transform: rotate(0deg); }
       163→            to { transform: rotate(360deg); }
       164→        }
       165→
       166→        .wheel-segment {
       167→            position: absolute;
       168→            width: 50%;
       169→            height: 100%;
       170→            display: flex;
       171→            align-items: center;
       172→            justify-content: center;
       173→        }
       174→
       175→        .wheel-segment:nth-child(1) {
       176→            left: 0;
       177→            padding-right: 20%;
       178→        }
       179→        .wheel-segment:nth-child(2) {
       180→            right: 0;
    ... (26 lines total)
ASSISTANT
  Now update the HTML - need to move the segments after the decorative elements for proper z-indexing:
  Tokens: in=0 out=1 cache=90331
ASSISTANT
Tool: Edit
  (toolu_01AtX3bMT9GYZuDz2JxwjHFD)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                     <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner"></div>
                            <div class=...
    new_string:                     <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner"></div>
    
                            <div class...
  Tokens: in=0 out=651 cache=90331
Result
  (toolu_01AtX3bMT9GYZuDz2JxwjHFD)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       684→        <!-- Page 1: Cover -->
       685→        <div class="page" id="page-1">
       686→            <div class="page-front">
       687→                <div class="cover-content">
       688→                    <div class="spinning-wheel">
       689→                        <div class="wheel-ring"></div>
       690→                        <div class="wheel-ring-inner"></div>
       691→
       692→                        <div class="wheel-segment">
       693→                            <div class="wheel-chapter" onclick="event.stopPropagation(); flipTo(2);">
       694→                                <div class="wheel-chapter-title">Nature</div>
       695→                                <div class="wheel-chapter-sub">Chapter One</div>
       696→                            </div>
       697→                        </div>
       698→
       699→                        <div class="wheel-segment">
       700→                            <div class="wheel-chapter" onclick="event.stopPropagation(); flipTo(3);">
       701→                                <div class="wheel-chapter-title">City</div>
       702→                                <div class="wheel-chapter-sub">Chapter Two</div>
    ... (31 lines total)
ASSISTANT
  Done! Now **Nature** is on the left side and **City** is on the right side of the spinning wheel - they're separate! 
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=1 cache=91000
File History Snapshot (2025-12-08T01:25:29.227Z)
USER
  i don't see them seperated?
ASSISTANT
  Let me check and fix the CSS - the segments need proper positioning:
  Tokens: in=2 out=1 cache=92246
ASSISTANT
Tool: Edit
  (toolu_01B2LD6YXrsy1imWRPWJNSLJ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .wheel-segment {
                position: absolute;
                width: 50%;
                height: 100%;
                display: flex;
                align-items: center;
                justify-content: cent...
    new_string:         .wheel-segment {
                position: absolute;
                top: 50%;
                left: 50%;
                transform-origin: center center;
            }
    
            .wheel-segment:nth-child(3) {
        ...
  Tokens: in=2 out=360 cache=92246
Result
  (toolu_01B2LD6YXrsy1imWRPWJNSLJ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       162→            from { transform: rotate(0deg); }
       163→            to { transform: rotate(360deg); }
       164→        }
       165→
       166→        .wheel-segment {
       167→            position: absolute;
       168→            top: 50%;
       169→            left: 50%;
       170→            transform-origin: center center;
       171→        }
       172→
       173→        .wheel-segment:nth-child(3) {
       174→            transform: translate(-50%, -50%) rotate(0deg) translateY(-35%);
       175→        }
       176→        .wheel-segment:nth-child(4) {
       177→            transform: translate(-50%, -50%) rotate(180deg) translateY(-35%);
       178→        }
       179→
       180→        .wheel-chapter {
    ... (22 lines total)
ASSISTANT
  Also need to fix the counter-spin for the second segment:
  Tokens: in=0 out=1 cache=92306
ASSISTANT
Tool: Edit
  (toolu_01HJkZWE3WA6irXpJ2zmmZMq)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .wheel-chapter {
                text-align: center;
                cursor: pointer;
                transition: transform 0.3s;
                animation: counter-spin 20s linear infinite;
            }
    
          ...
    new_string:         .wheel-chapter {
                text-align: center;
                cursor: pointer;
                transition: transform 0.3s;
            }
    
            .wheel-segment:nth-child(3) .wheel-chapter {
              ...
  Tokens: in=0 out=433 cache=92306
Result
  (toolu_01HJkZWE3WA6irXpJ2zmmZMq)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       176→        .wheel-segment:nth-child(4) {
       177→            transform: translate(-50%, -50%) rotate(180deg) translateY(-35%);
       178→        }
       179→
       180→        .wheel-chapter {
       181→            text-align: center;
       182→            cursor: pointer;
       183→            transition: transform 0.3s;
       184→        }
       185→
       186→        .wheel-segment:nth-child(3) .wheel-chapter {
       187→            animation: counter-spin 20s linear infinite;
       188→        }
       189→
       190→        .wheel-segment:nth-child(4) .wheel-chapter {
       191→            animation: counter-spin-flipped 20s linear infinite;
       192→        }
       193→
       194→        @keyframes counter-spin {
    ... (36 lines total)
ASSISTANT
  Now they should be separated - **Nature** at the top and **City** at the bottom, spinning around opposite sides of the wheel. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=48 cache=93063
File History Snapshot (2025-12-08T01:25:58.362Z)
USER
  I don't see the photos inside the book?
ASSISTANT
  Let me check the JavaScript - the photo loading might have broken. Let me look at the current state:
  Tokens: in=2 out=1 cache=93969
ASSISTANT
Tool: Bash
  (toolu_012ZKmbgvwJ4mBbitsWeVRZF)
    command: curl -s https://rosy.shitchell.com/upload-api/photos | head -100
    description: Check if photos API is working
  Tokens: in=2 out=119 cache=93969
Result
  (toolu_012ZKmbgvwJ4mBbitsWeVRZF)
    {"landscapes":[{"filename":"img_5296.jpg_1765155678042_37e365a5.jpg","title":"","path":"/photography/uploads/landscapes/img_5296.jpg_1765155678042_37e365a5.jpg","category":"landscapes","uploaded":"2025-12-08T01:01:18.061Z"},{"filename":"img_5507.jpg_1765131867270_ae5af9c4.jpg","title":"Tamsui Fisherman's Wharf | Taipei","path":"/photography/uploads/landscapes/img_5507.jpg_1765131867270_ae5af9c4.jpg","category":"landscapes","uploaded":"2025-12-07T18:24:27.272Z"},{"filename":"ncyg5748.png_1765131669664_c50f1298.png","title":"Yung Min Mt. | Taipei","path":"/photography/uploads/landscapes/ncyg5748.png_1765131669664_c50f1298.png","category":"landscapes","uploaded":"2025-12-07T18:21:09.667Z"},{"filename":"whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg","title":"Golden Season | Park nearby DJM","path":"/photography/uploads/landscapes/whatsapp_image_2025-11-09_at_20.11.09_dfbb0e45_1765083671882_4c1227ea.jpg","category":"landscapes","uploaded":"2025-12-07T05:23:09.550Z"}],"historic":[{"filename":"whatsapp_image_2025-12-07_at_13.45.20_ad896dfd_1765133224971_89ce7ba0.jpg","title":"Florence | Italy","path":"/photography/uploads/historic/whatsapp_image_2025-12-07_at_13.45.20_ad896dfd_1765133224971_89ce7ba0.jpg","category":"historic","uploaded":"2025-12-07T18:47:04.973Z"},{"filename":"img_3465_1765132533652_c2217959.jpg","title":"Cinque Terra | Italy","path":"/photography/uploads/historic/img_3465_1765132533652_c2217959.jpg","category":"historic","uploaded":"2025-12-07T18:35:33.655Z"},{"filename":"whatsapp_image_2025-12-07_at_13.26.06_bcd73529_1765132027308_198d5c57.jpg","title":"Taipei 101","path":"/photography/uploads/historic/whatsapp_image_2025-12-07_at_13.26.06_bcd73529_1765132027308_198d5c57.jpg","category":"historic","uploaded":"2025-12-07T18:27:07.309Z"},{"filename":"img_4751_1765130409547_475edc7c.jpg","title":"National Taiwan Theatre | Taipei","path":"/photography/uploads/historic/img_4751_1765130409547_475edc7c.jpg","category":"historic","uploaded":"2025-12-07T18:00:09.550Z"}]}
ASSISTANT
  The API is working. Let me check the JavaScript in the file - I think when I removed the slideshow code earlier, I might have broken the loadPhotos function:
  Tokens: in=0 out=2 cache=94131
ASSISTANT
Tool: Read
  (toolu_015xGCEuD81TA4X3tL9TiFBe)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 1000
    limit: 150
  Tokens: in=0 out=147 cache=94131
Result
  (toolu_015xGCEuD81TA4X3tL9TiFBe)
      1000→        }
      1001→
      1002→        // Format filename to title
      1003→        function formatTitle(filename) {
      1004→            let name = filename.replace(/\.[^.]+$/, '');
      1005→            name = name.replace(/_\d{13}_[a-f0-9]+$/, '');
      1006→            name = name.replace(/_/g, ' ');
      1007→            return name.split(' ').map(w => w.charAt(0).toUpperCase() + w.slice(1)).join(' ');
      1008→        }
      1009→
      1010→        // Create photo frame
      1011→        function createPhotoFrame(photo, index) {
      1012→            const frame = document.createElement('div');
      1013→            frame.className = 'photo-frame';
      1014→
      1015→            const title = photo.title || formatTitle(photo.filename);
      1016→
      1017→            const img = document.createElement('img');
      1018→            img.src = photo.path;
      1019→            img.alt = title;
    ... (155 lines total)
ASSISTANT
  I see the issue - the setupSlideshow function is looking for elements that no longer exist (coverSlideshow, coverNav) since we replaced them with the spinning wheel. This is causing an error that stops the rest of the code. Let me fix it:
  Tokens: in=0 out=6 cache=95066
ASSISTANT
Tool: Edit
  (toolu_01KL9GXhKW87vu5Rhtyr8fy9)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         // Cover slideshow
            let slideshowImages = [];
            let currentSlide = 0;
            let slideshowInterval;
    
            function setupSlideshow(photos) {
                const slideshow = docum...
    new_string:         // Load photos
            async function loadPhotos() {
                try {
                    const response = await fetch('/upload-api/photos');
                    const photos = await response.json();...
  Tokens: in=0 out=949 cache=95066
Result
  (toolu_01KL9GXhKW87vu5Rhtyr8fy9)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
      1043→
      1044→            return frame;
      1045→        }
      1046→
      1047→        // Load photos
      1048→        async function loadPhotos() {
      1049→            try {
      1050→                const response = await fetch('/upload-api/photos');
      1051→                const photos = await response.json();
      1052→                images = [];
      1053→                let globalIndex = 0;
      1054→
      1055→                // Nature gallery
      1056→                const natureGallery = document.getElementById('nature-gallery');
      1057→                natureGallery.innerHTML = '';
ASSISTANT
  Now the photos should load! The slideshow code was erroring because those elements don't exist anymore. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=41 cache=97461
File History Snapshot (2025-12-08T01:27:13.837Z)
USER
  take off the test on cover page?
ASSISTANT
Tool: Edit
  (toolu_013A8oiyg29Z4UfeEcvN5ruq)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                     <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner"></div>
    
                            <div class...
    new_string:                     <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner"></div>
    
                            <div class...
  Tokens: in=2 out=524 cache=98629
Result
  (toolu_013A8oiyg29Z4UfeEcvN5ruq)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       692→        <!-- Page 1: Cover -->
       693→        <div class="page" id="page-1">
       694→            <div class="page-front">
       695→                <div class="cover-content">
       696→                    <div class="spinning-wheel">
       697→                        <div class="wheel-ring"></div>
       698→                        <div class="wheel-ring-inner"></div>
       699→
       700→                        <div class="wheel-segment">
       701→                            <div class="wheel-chapter" onclick="event.stopPropagation(); flipTo(2);"></div>
       702→                        </div>
       703→
       704→                        <div class="wheel-segment">
       705→                            <div class="wheel-chapter" onclick="event.stopPropagation(); flipTo(3);"></div>
       706→                        </div>
       707→
       708→                        <div class="wheel-center">
       709→                            <div class="wheel-center-dot"></div>
       710→                        </div>
    ... (25 lines total)
ASSISTANT
  Done! The text is removed from the spinning wheel - now it's just the decorative rings spinning. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=41 cache=98782
File History Snapshot (2025-12-08T01:28:07.250Z)
USER
  make the spinning wheel colorful like winter season!
ASSISTANT
Tool: Edit
  (toolu_01C4WPY5o15cZMFiLDdox2zq)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=3202 cache=99705
Result
  (toolu_01C4WPY5o15cZMFiLDdox2zq)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: linear-gradient(135deg, #e8f4f8 0%, #d0e8f0 50%, #c5dce8 100%);
       150→            overflow: hidden;
       151→        }
       152→
       153→        /* Snowflakes background */
    ... (196 lines total)
ASSISTANT
  Done! The spinning wheel now has winter colors:
  
  - **Icy blue background** with subtle snowflake dots
  - **Colorful gradient rings** with pastel winter colors (icy blue, soft lavender, blush pink, mint green, soft gold)
  - **Glowing icy center** with a frosty blue dot
  - **Two colorful spinning rings** - outer and inner with different pastel gradients
  
  Check it out at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=116 cache=99757
File History Snapshot (2025-12-08T01:30:47.610Z)
USER
  go back to previos version and make lines thicker
ASSISTANT
Tool: Edit
  (toolu_018Qi18Vegkjmrx2bhN4Xadk)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=3201 cache=105680
Result
  (toolu_018Qi18Vegkjmrx2bhN4Xadk)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        /* Spinning Wheel */
    ... (153 lines total)
ASSISTANT
  Done! Back to the original simple style with thicker lines:
  - Outer ring: 4px solid
  - Inner ring: 3px dashed
  - Center border: 4px solid
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=63 cache=105808
File History Snapshot (2025-12-08T01:34:12.338Z)
USER
  remove the spinning wheel. add a camera on cover page
ASSISTANT
Tool: Edit
  (toolu_01YVY8SZkMPe1DDCUNiAZQnh)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                        <div class="spinning-wheel">
                            <div class="wheel-ring"></div>
                            <div class="wheel-ring-inner...
    new_string:                 <div class="cover-content">
                        <div class="cover-camera">📷</div>
                    </div>
  Tokens: in=2 out=324 cache=110793
Result
  (toolu_01YVY8SZkMPe1DDCUNiAZQnh)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       691→    <div class="book" id="book">
       692→        <!-- Page 1: Cover -->
       693→        <div class="page" id="page-1">
       694→            <div class="page-front">
       695→                <div class="cover-content">
       696→                    <div class="cover-camera">📷</div>
       697→                </div>
       698→            </div>
       699→            <div class="page-back">
       700→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       701→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
ASSISTANT
  Now let me update the CSS to style the camera nicely and remove the spinning wheel styles:
  Tokens: in=0 out=1 cache=110971
ASSISTANT
Tool: Edit
  (toolu_01R9WVmiNBzCb9YJihKvSCiz)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=0 out=1468 cache=110971
Result
  (toolu_01R9WVmiNBzCb9YJihKvSCiz)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        .cover-camera {
    ... (28 lines total)
ASSISTANT
  Done! The cover now has a big camera emoji (📷) in the center with a slightly muted look. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=1 cache=111549
File History Snapshot (2025-12-08T01:37:21.895Z)
USER
  make cover page white big  grids 
ASSISTANT
Tool: Edit
  (toolu_01PupAvZoyrdsKtEmVH2ECQY)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=463 cache=113461
Result
  (toolu_01PupAvZoyrdsKtEmVH2ECQY)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background:
       150→                linear-gradient(to right, #e0e0e0 1px, transparent 1px),
       151→                linear-gradient(to bottom, #e0e0e0 1px, transparent 1px),
       152→                #ffffff;
       153→            background-size: 60px 60px;
    ... (32 lines total)
Queue: enqueue
  and remove camera
  
Queue: dequeue
File History Snapshot (2025-12-08T01:37:36.089Z)
ASSISTANT
  Done! The cover now has a white background with big grid lines (60px squares) and the camera in the center. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=45 cache=113515
USER
  and remove camera
  
ASSISTANT
Tool: Edit
  (toolu_01Mnu5vJuAn795NZNNHM42bZ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                        <div class="cover-camera">📷</div>
                    </div>
    new_string:                 <div class="cover-content">
                    </div>
  Tokens: in=1 out=154 cache=114393
Result
  (toolu_01Mnu5vJuAn795NZNNHM42bZ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       570→    <div class="book" id="book">
       571→        <!-- Page 1: Cover -->
       572→        <div class="page" id="page-1">
       573→            <div class="page-front">
       574→                <div class="cover-content">
       575→                </div>
       576→            </div>
       577→            <div class="page-back">
       578→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       579→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
ASSISTANT
  Done! Cover is now just white with big grids - clean and minimal. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=36 cache=114443
File History Snapshot (2025-12-08T01:40:12.560Z)
USER
  take off grid. and only have cozy words of "Thru My Lens" in the center and middle size
ASSISTANT
Tool: Edit
  (toolu_01TZyUPY58TocAFd55ynC4gB)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
    new_string:         /* Cover Page Styles */
            .cover-content {
                height: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-c...
  Tokens: in=2 out=503 cache=114936
Result
  (toolu_01TZyUPY58TocAFd55ynC4gB)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       135→            border-radius: 5px 0 0 5px;
       136→            z-index: 10;
       137→        }
       138→
       139→        /* Cover Page Styles */
       140→        .cover-content {
       141→            height: 100%;
       142→            display: flex;
       143→            flex-direction: column;
       144→            align-items: center;
       145→            justify-content: center;
       146→            padding: 20px;
       147→            text-align: center;
       148→            position: relative;
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        .cover-title {
    ... (31 lines total)
ASSISTANT
Tool: Edit
  (toolu_01CDqqiPN4Y9ozsvNe6UqpMF)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:                 <div class="cover-content">
                    </div>
    new_string:                 <div class="cover-content">
                        <h1 class="cover-title">Thru My Lens</h1>
                    </div>
  Tokens: in=0 out=161 cache=114998
Result
  (toolu_01CDqqiPN4Y9ozsvNe6UqpMF)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       569→    <div class="book" id="book">
       570→        <!-- Page 1: Cover -->
       571→        <div class="page" id="page-1">
       572→            <div class="page-front">
       573→                <div class="cover-content">
       574→                    <h1 class="cover-title">Thru My Lens</h1>
       575→                </div>
       576→            </div>
       577→            <div class="page-back">
       578→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       579→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">
ASSISTANT
  Done! The cover now has a warm cream background with "Thru My Lens" in the center - cozy italic font, medium size. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=51 cache=115896
File History Snapshot (2025-12-08T01:41:05.729Z)
USER
  make text bigger
ASSISTANT
Tool: Edit
  (toolu_01Sgjr6djybR5dofCjshZ6z1)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(1.8rem, 5vw, 3rem);
                font-weight: 300;
                font-style: italic;
       ...
    new_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3rem, 8vw, 5rem);
                font-weight: 300;
                font-style: italic;
         ...
  Tokens: in=2 out=294 cache=116420
Result
  (toolu_01Sgjr6djybR5dofCjshZ6z1)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        .cover-title {
       154→            font-family: 'Cormorant Garamond', Georgia, serif;
       155→            font-size: clamp(3rem, 8vw, 5rem);
       156→            font-weight: 300;
       157→            font-style: italic;
       158→            color: #5c524a;
       159→            letter-spacing: 0.05em;
       160→        }
       161→
       162→        /* Chapter Page Styles */
       163→        .chapter-content {
       164→            height: 100%;
ASSISTANT
  Done! Text is bigger now. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=27 cache=116475
File History Snapshot (2025-12-08T01:41:36.060Z)
USER
  Can  you make an animatoin on writing the text ?
ASSISTANT
Tool: Edit
  (toolu_01259rRnvcKukijoVaN6cNpM)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3rem, 8vw, 5rem);
                font-weight: 300;
                font-style: italic;
         ...
    new_string:         .cover-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3rem, 8vw, 5rem);
                font-weight: 300;
                font-style: italic;
         ...
  Tokens: in=2 out=417 cache=117016
Result
  (toolu_01259rRnvcKukijoVaN6cNpM)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       149→            background: #f5f0eb;
       150→            overflow: hidden;
       151→        }
       152→
       153→        .cover-title {
       154→            font-family: 'Cormorant Garamond', Georgia, serif;
       155→            font-size: clamp(3rem, 8vw, 5rem);
       156→            font-weight: 300;
       157→            font-style: italic;
       158→            color: #5c524a;
       159→            letter-spacing: 0.05em;
       160→            overflow: hidden;
       161→            border-right: 2px solid #5c524a;
       162→            white-space: nowrap;
       163→            width: 0;
       164→            animation: typing 2.5s steps(12) 0.5s forwards, blink 0.7s step-end infinite;
       165→        }
       166→
       167→        @keyframes typing {
    ... (31 lines total)
ASSISTANT
  Done! Now "Thru My Lens" has a typewriter animation - the text types out letter by letter with a blinking cursor. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=3 cache=117160
File History Snapshot (2025-12-08T01:43:49.385Z)
USER
  add :) to thru my lens
ASSISTANT
Tool: Edit
  (toolu_017H4sEkLHjU5sVqu54oNbAf)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string: <h1 class="cover-title">Thru My Lens</h1>
    new_string: <h1 class="cover-title">Thru My Lens :)</h1>
  Tokens: in=2 out=149 cache=117991
Result
  (toolu_017H4sEkLHjU5sVqu54oNbAf)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       584→        <!-- Page 1: Cover -->
       585→        <div class="page" id="page-1">
       586→            <div class="page-front">
       587→                <div class="cover-content">
       588→                    <h1 class="cover-title">Thru My Lens :)</h1>
       589→                </div>
       590→            </div>
       591→            <div class="page-back">
       592→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
ASSISTANT
  Also need to update the animation steps for the extra characters:
  Tokens: in=0 out=1 cache=118050
ASSISTANT
Tool: Edit
  (toolu_01EpCzdYwGti8JVztnwbBKBT)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             animation: typing 2.5s steps(12) 0.5s forwards, blink 0.7s step-end infinite;
    new_string:             animation: typing 3s steps(16) 0.5s forwards, blink 0.7s step-end infinite;
  Tokens: in=0 out=185 cache=118050
Result
  (toolu_01EpCzdYwGti8JVztnwbBKBT)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       160→            overflow: hidden;
       161→            border-right: 2px solid #5c524a;
       162→            white-space: nowrap;
       163→            width: 0;
       164→            animation: typing 3s steps(16) 0.5s forwards, blink 0.7s step-end infinite;
       165→        }
       166→
       167→        @keyframes typing {
       168→            from { width: 0; }
ASSISTANT
  Done! Now it says "Thru My Lens :)" with the typing animation. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=39 cache=118508
File History Snapshot (2025-12-08T01:44:58.206Z)
USER
  keep "about"  on the last page
ASSISTANT
Tool: Read
  (toolu_01GPKHpjFyiCtVxiTrsAvfbF)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    offset: 600
    limit: 80
  Tokens: in=2 out=110 cache=118871
Result
  (toolu_01GPKHpjFyiCtVxiTrsAvfbF)
       600→        <!-- Page 2: Nature -->
       601→        <div class="page" id="page-2">
       602→            <div class="page-front">
       603→                <div class="chapter-content">
       604→                    <div class="chapter-header">
       605→                        <span class="chapter-number">Chapter One</span>
       606→                        <h2 class="chapter-title">Nature</h2>
       607→                        <p class="chapter-description">Moments of stillness found in nature</p>
       608→                    </div>
       609→                    <div id="nature-gallery" class="photo-grid">
       610→                        <div class="empty-message">Loading...</div>
       611→                    </div>
       612→                    <div class="page-footer">
       613→                        <p class="page-number" id="nature-count"></p>
       614→                    </div>
       615→                </div>
       616→            </div>
       617→            <div class="page-back">
       618→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       619→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light); text-align: center;">
    ... (85 lines total)
ASSISTANT
Tool: Edit
  (toolu_01Wb1sRQywVXamB4C51uMaLW)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             <div class="page-back">
                    <div class="chapter-content" style="display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px;">
                  ...
    new_string:             <div class="page-back">
                    <div class="chapter-content" style="display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px;">
                  ...
  Tokens: in=0 out=600 cache=119023
Result
  (toolu_01Wb1sRQywVXamB4C51uMaLW)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       639→                        <p class="page-number" id="city-count"></p>
       640→                    </div>
       641→                </div>
       642→            </div>
       643→            <div class="page-back">
       644→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px;">
       645→                    <p style="font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: var(--ink);">About</p>
       646→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light); text-align: center; max-width: 80%; line-height: 1.6;">
       647→                        A collection of moments captured through my lens.<br>
       648→                        Thank you for viewing.
       649→                    </p>
       650→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">— Rosy</p>
       651→                    <a href="/photography/upload.html" style="color: var(--accent); font-size: 0.85rem;">Upload Photos</a>
       652→                </div>
       653→            </div>
       654→        </div>
       655→    </div>
       656→
       657→    <!-- Navigation -->
    ... (22 lines total)
ASSISTANT
  Done! The last page (back of City page) now has "About" as a header with your description underneath. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=44 cache=120556
File History Snapshot (2025-12-08T01:46:24.499Z)
USER
  i don't see about?
ASSISTANT
  Let me check - you need to flip to the last page to see it. The "About" is on the back of the City page (page 3). Let me verify it's there:
  Tokens: in=2 out=1 cache=121638
ASSISTANT
Tool: Bash
  (toolu_01Hn7vw9B6Cf8EXWTXJpRxH5)
    command: curl -s https://rosy.shitchell.com/photography/ | grep -A5 "About"
    description: Check if About is in the page
  Tokens: in=2 out=141 cache=121638
Result
  (toolu_01Hn7vw9B6Cf8EXWTXJpRxH5)
                        <p style="font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: var(--ink);">About</p>
                        <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light); text-align: center; max-width: 80%; line-height: 1.6;">
                            A collection of moments captured through my lens.<br>
                            Thank you for viewing.
                        </p>
                        <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light);">— Rosy</p>
ASSISTANT
  The "About" is there - it's on the **back** of the City page. To see it, you need to:
  1. Go to the City page (click arrow or flip twice from cover)
  2. Click on the City page again to flip it over - that's where "About" appears
  
  Would you like me to move "About" to a different location, like make it a separate page that's easier to see?
  Tokens: in=0 out=95 cache=121792
File History Snapshot (2025-12-08T01:46:57.979Z)
USER
  also book is too wide make it not too wide
ASSISTANT
Tool: Edit
  (toolu_01HV2sNT8C39U3x8X8c9rtPg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Container */
            .book {
                width: calc(100vw - 20px);
                max-width: none;
                height: calc(100vh - 20px);
                max-height: none;
                posit...
    new_string:         /* Book Container */
            .book {
                width: calc(100vh - 40px);
                max-width: 700px;
                height: calc(100vh - 40px);
                max-height: 900px;
                pos...
  Tokens: in=2 out=261 cache=122127
Result
  (toolu_01HV2sNT8C39U3x8X8c9rtPg)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        37→            perspective: 2000px;
        38→            overflow: hidden;
        39→        }
        40→
        41→        /* Book Container */
        42→        .book {
        43→            width: calc(100vh - 40px);
        44→            max-width: 700px;
        45→            height: calc(100vh - 40px);
        46→            max-height: 900px;
        47→            position: relative;
        48→            transform-style: preserve-3d;
        49→        }
        50→
        51→        /* Individual Pages */
        52→        .page {
        53→            position: absolute;
ASSISTANT
  Done! The book is now narrower (max 700px wide) and more portrait-shaped like a real book. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=45 cache=122336
File History Snapshot (2025-12-08T01:47:12.446Z)
USER
  a seperate page is fine
ASSISTANT
Tool: Edit
  (toolu_01W7zUoEa3ukHrJeRb8B8SaT)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             <div class="page-back">
                    <div class="chapter-content" style="display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px;">
                  ...
    new_string:             <div class="page-back">
                    <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
                        <p style="font-family: 'Cormo...
  Tokens: in=2 out=986 cache=122825
Result
  (toolu_01W7zUoEa3ukHrJeRb8B8SaT)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       639→                        <p class="page-number" id="city-count"></p>
       640→                    </div>
       641→                </div>
       642→            </div>
       643→            <div class="page-back">
       644→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center;">
       645→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light); text-align: center;">
       646→                        "A city is not gauged by its length and width,<br>but by the broadness of its vision."<br><span style="font-size: 0.8em;">— Herb Caen</span>
       647→                    </p>
       648→                </div>
       649→            </div>
       650→        </div>
       651→
       652→        <!-- Page 4: About -->
       653→        <div class="page" id="page-4">
       654→            <div class="page-front">
       655→                <div class="chapter-content" style="display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 25px;">
       656→                    <p style="font-family: 'Cormorant Garamond', serif; font-size: 2rem; color: var(--ink);">About</p>
       657→                    <p style="font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ink-light); text-align: center; max-width: 80%; line-height: 1.8; font-size: 1.1rem;">
    ... (38 lines total)
ASSISTANT
  Now I need to add an indicator dot for the new page:
  Tokens: in=0 out=1 cache=122877
ASSISTANT
Tool: Edit
  (toolu_01B5SufVmDJJvz13oLXE52EG)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <!-- Navigation -->
        <div class="page-indicator">
            <div class="indicator-dot active" data-page="0"></div>
            <div class="indicator-dot" data-page="1"></div>
            <div class="indi...
    new_string:     <!-- Navigation -->
        <div class="page-indicator">
            <div class="indicator-dot active" data-page="0"></div>
            <div class="indicator-dot" data-page="1"></div>
            <div class="indi...
  Tokens: in=0 out=326 cache=122877
Result
  (toolu_01B5SufVmDJJvz13oLXE52EG)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       669→            </div>
       670→        </div>
       671→    </div>
       672→
       673→    <!-- Navigation -->
       674→    <div class="page-indicator">
       675→        <div class="indicator-dot active" data-page="0"></div>
       676→        <div class="indicator-dot" data-page="1"></div>
       677→        <div class="indicator-dot" data-page="2"></div>
       678→        <div class="indicator-dot" data-page="3"></div>
       679→        <div class="indicator-dot" data-page="4"></div>
       680→    </div>
       681→
       682→    <div class="nav-arrows">
       683→        <button class="nav-btn" id="prevBtn" disabled>←</button>
       684→        <button class="nav-btn" id="nextBtn">→</button>
ASSISTANT
  Also need to update the CSS for 4 pages z-index stacking:
  Tokens: in=0 out=1 cache=124801
ASSISTANT
Tool: Edit
  (toolu_01L1vkukcWhwvbHmHK9LDx1z)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Page stacking */
            .page:nth-child(1) { z-index: 4; }
            .page:nth-child(2) { z-index: 3; }
            .page:nth-child(3) { z-index: 2; }
            .page:nth-child(4) { z-index: 1; }
    ...
    new_string:         /* Page stacking */
            .page:nth-child(1) { z-index: 5; }
            .page:nth-child(2) { z-index: 4; }
            .page:nth-child(3) { z-index: 3; }
            .page:nth-child(4) { z-index: 2; }
    ...
  Tokens: in=0 out=486 cache=124801
Result
  (toolu_01L1vkukcWhwvbHmHK9LDx1z)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        88→        .page.flipped {
        89→            transform: rotateY(-180deg);
        90→        }
        91→
        92→        /* Page stacking */
        93→        .page:nth-child(1) { z-index: 5; }
        94→        .page:nth-child(2) { z-index: 4; }
        95→        .page:nth-child(3) { z-index: 3; }
        96→        .page:nth-child(4) { z-index: 2; }
        97→
        98→        .page.flipped:nth-child(1) { z-index: 1; }
        99→        .page.flipped:nth-child(2) { z-index: 2; }
       100→        .page.flipped:nth-child(3) { z-index: 3; }
       101→        .page.flipped:nth-child(4) { z-index: 4; }
       102→
       103→        /* Page edge effect */
       104→        .page-front::after {
       105→            content: '';
ASSISTANT
  Done! Now there's a separate "About" page after the City page. The book now has:
  1. Cover - "Thru My Lens :)"
  2. Nature - photos
  3. City - photos
  4. About - with your description and upload link
  
  Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=79 cache=125413
File History Snapshot (2025-12-08T01:48:08.452Z)
USER
  a bit wider
ASSISTANT
Tool: Edit
  (toolu_0112vqBzTKEE1JDDuUoCiRm5)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Container */
            .book {
                width: calc(100vh - 40px);
                max-width: 700px;
                height: calc(100vh - 40px);
                max-height: 900px;
                pos...
    new_string:         /* Book Container */
            .book {
                width: calc(100vh - 40px);
                max-width: 850px;
                height: calc(100vh - 40px);
                max-height: 900px;
                pos...
  Tokens: in=2 out=265 cache=126342
Result
  (toolu_0112vqBzTKEE1JDDuUoCiRm5)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        37→            perspective: 2000px;
        38→            overflow: hidden;
        39→        }
        40→
        41→        /* Book Container */
        42→        .book {
        43→            width: calc(100vh - 40px);
        44→            max-width: 850px;
        45→            height: calc(100vh - 40px);
        46→            max-height: 900px;
        47→            position: relative;
        48→            transform-style: preserve-3d;
        49→        }
        50→
        51→        /* Individual Pages */
        52→        .page {
        53→            position: absolute;
ASSISTANT
  Done! Made the book a bit wider (850px max). Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=33 cache=126425
File History Snapshot (2025-12-08T01:48:44.001Z)
USER
  1200 px
ASSISTANT
Tool: Edit
  (toolu_01KEUENRabQJSeio43zCB3VL)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:             max-width: 850px;
    new_string:             max-width: 1200px;
  Tokens: in=2 out=130 cache=126917
Result
  (toolu_01KEUENRabQJSeio43zCB3VL)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        40→
        41→        /* Book Container */
        42→        .book {
        43→            width: calc(100vh - 40px);
        44→            max-width: 1200px;
        45→            height: calc(100vh - 40px);
        46→            max-height: 900px;
        47→            position: relative;
        48→            transform-style: preserve-3d;
ASSISTANT
  Done! Book is now 1200px max width. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=32 cache=127058
File History Snapshot (2025-12-08T01:49:25.062Z)
USER
  make the book much wider
ASSISTANT
Tool: Edit
  (toolu_014KNWzSCELXRERVyrsKceU1)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Book Container */
            .book {
                width: calc(100vh - 40px);
                max-width: 1200px;
                height: calc(100vh - 40px);
                max-height: 900px;
                po...
    new_string:         /* Book Container */
            .book {
                width: calc(100vw - 40px);
                max-width: none;
                height: calc(100vh - 40px);
                max-height: none;
                posit...
  Tokens: in=2 out=263 cache=127353
Result
  (toolu_014KNWzSCELXRERVyrsKceU1)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        37→            perspective: 2000px;
        38→            overflow: hidden;
        39→        }
        40→
        41→        /* Book Container */
        42→        .book {
        43→            width: calc(100vw - 40px);
        44→            max-width: none;
        45→            height: calc(100vh - 40px);
        46→            max-height: none;
        47→            position: relative;
        48→            transform-style: preserve-3d;
        49→        }
        50→
        51→        /* Individual Pages */
        52→        .page {
        53→            position: absolute;
ASSISTANT
  Done! The book now fills the entire screen width. Check it at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=31 cache=127391
File History Snapshot (2025-12-08T01:51:25.306Z)
USER
  don't do the book design. make it more like a web
ASSISTANT
Tool: Read
  (toolu_01H83fstLPjBYWubYfpLkCkW)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
  Tokens: in=2 out=76 cache=127982
Result
  (toolu_01H83fstLPjBYWubYfpLkCkW)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=EB+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --page-bg: #d8d3cc;
        13→            --paper: #eae6e0;
        14→            --paper-dark: #ddd8d0;
        15→            --ink: #2c2825;
        16→            --ink-light: #5a534d;
        17→            --ink-faint: #8a847d;
        18→            --accent: #7a6348;
        19→            --shadow: rgba(44, 40, 37, 0.12);
        20→            --shadow-deep: rgba(44, 40, 37, 0.25);
    ... (987 lines total)
ASSISTANT
  Let me rewrite this as a standard scrolling website instead of a book:
  Tokens: in=0 out=1 cache=128027
ASSISTANT
Tool: Write
  (toolu_01Y4yQDF18CkxMLoQFo6oDpp)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    content: <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Thru My Lens :) - Rosy's Photography</title>
      ...
  Tokens: in=0 out=6005 cache=128027
Result
  (toolu_01Y4yQDF18CkxMLoQFo6oDpp)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Thru My Lens :) - Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --bg: #f5f0eb;
        13→            --ink: #2c2825;
        14→            --ink-light: #5a534d;
        15→            --ink-faint: #8a847d;
        16→            --accent: #7a6348;
        17→        }
        18→
        19→        * {
    ... (689 lines total)
ASSISTANT
  Done! I completely redesigned it as a normal scrolling website:
  
  - **Header** with "Thru My Lens :)" title
  - **Sticky navigation** - Nature, City, About links that stick to top when scrolling
  - **Nature section** - photo grid with hover effects
  - **City section** - photo grid with hover effects
  - **About section** - your description
  - **Footer** - upload link
  
  All the same features work:
  - Click photos to open lightbox
  - Edit/delete photos with password
  - Responsive design for mobile
  
  Check it out at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=144 cache=140462
File History Snapshot (2025-12-08T01:54:32.967Z)
USER
  header space to 1/2
ASSISTANT
Tool: Edit
  (toolu_01HrEAtAprtr1g2BnAMxqaEY)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 80px 20px 60px;
            }
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
            }
  Tokens: in=2 out=179 cache=154685
Result
  (toolu_01HrEAtAprtr1g2BnAMxqaEY)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 40px 20px 30px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(2.5rem, 8vw, 4rem);
Queue: enqueue
  add copyright
SYSTEM (compact_boundary)
  Conversation compacted (155018 tokens before compaction)
USER
  This session is being continued from a previous conversation that ran out of context. The conversation is summarized below:
  Analysis:
  Let me chronologically analyze this conversation:
  
  1. **Initial context**: The conversation was continued from a previous session about a photography portfolio website. The previous session had implemented a book-style layout with page-flipping animation.
  
  2. **Page count/Add more link position**: User asked to move the page count and "Add more" link from middle to left bottom because it was blocked by arrow buttons. I changed `.page-footer` text-align from center to left.
  
  3. **Cover page redesign - cozy and nature theme**: User wanted a more cozy, nature-themed cover. I tried adding botanical decorations with emojis (🌿, 🍃, 🌸), green borders, and warm gradients. User said "cover is not what I wanted LOL".
  
  4. **Artsy style request**: User asked for artsy style. I redesigned with watercolor-style gradients, italic handwritten-feel title, brushstroke divider, and doodle symbols.
  
  5. **Full screen book**: User asked to make book fit entire screen. Changed book dimensions to `calc(100vw - 20px)` and removed max-width/max-height limits.
  
  6. **Blank cover**: User asked to remove title text, then "click to open" hint. Cover became completely blank.
  
  7. **Cover photo upload**: User wanted to upload a cover photo. I provided the upload link and then set the uploaded photo (`img_5296.jpg_1765155678042_37e365a5.jpg`) as background.
  
  8. **Cover with text overlay**: Added "THRU LENS" at top and "Photo by my Dear friend, Chien :)" at bottom of cover photo.
  
  9. **Photo size adjustment**: User said photo too big, I made it 60% size with dark background.
  
  10. **Font change**: Changed cover title font to EB Garamond (closest to Garamond Premier on Google Fonts).
  
  11. **Large title with photo colors**: User wanted "THRU LENS" to fit whole page with cover photo colors, then remove photo. Made huge italic title in sage green color.
  
  12. **Keep cover photo but lighter**: Added white overlay (50% opacity) over cover photo.
  
  13. **Dark text**: Changed text color to dark brown (#2c2825).
  
  14. **Photo slideshow animation**: User wanted scrolling photos animation on cover. I added slideshow functionality that auto-scrolls through all uploaded photos every 4 seconds with fade transitions. Added floating navigation dots.
  
  15. **Blank cover again**: User asked to make cover blank.
  
  16. **Spinning wheel**: User wanted spinning wheel with chapters. I created a CSS-animated spinning wheel with Nature and City chapters.
  
  17. **Separate chapters**: User said chapters need to be separate. I adjusted positioning so they appear on opposite sides.
  
  18. **Photos not showing**: The slideshow code was causing errors because elements didn't exist anymore. I removed the broken slideshow code and fixed loadPhotos function.
  
  19. **Remove text from spinning wheel**: Made chapter labels empty.
  
  20. **Colorful winter wheel**: Added winter colors with conic gradients, icy blue theme, snowflakes.
  
  21. **Revert to simple wheel with thicker lines**: User wanted previous version. I reverted and made borders thicker (4px outer ring, 3px dashed inner, 4px center).
  
  22. **Remove spinning wheel, add camera**: Replaced with camera emoji (📷).
  
  23. **White grid cover**: Changed to white background with 60px grid lines.
  
  24. **Remove camera, add "Thru My Lens" text**: Created cozy italic title in center.
  
  25. **Bigger text**: Increased font size from clamp(1.8rem, 5vw, 3rem) to clamp(3rem, 8vw, 5rem).
  
  26. **Typing animation**: Added typewriter animation with cursor blink.
  
  27. **Add :) to title**: Changed to "Thru My Lens :)" and adjusted animation steps.
  
  28. **About page**: User wanted About on last page. I added a separate Page 4 with About section.
  
  29. **Book width adjustments**: Made book narrower (700px), then 850px, then 1200px, then full width again.
  
  30. **Switch from book to web design**: User said "don't do the book design, make it more like a web". I completely rewrote the page as a standard scrolling website with header, sticky nav, sections for Nature/City/About, footer.
  
  31. **Header space to 1/2**: Reduced header padding from 80px/60px to 40px/30px.
  
  Key files:
  - `/var/www/rosy.shitchell.com/srv/web/photography/index.html` - Main photography page
  - `/var/www/rosy.shitchell.com/srv/web/photography/upload.html` - Upload page
  - `/var/www/rosy.shitchell.com/srv/upload-api/server.js` - Node.js upload server
  
  Current state: Standard scrolling website with:
  - Header "Thru My Lens :)"
  - Sticky navigation (Nature, City, About)
  - Photo grids for each category
  - About section
  - Footer with upload link
  - Lightbox and edit functionality preserved
  
  Summary:
  1. Primary Request and Intent:
     User requested a photography portfolio website that evolved through many iterations:
     - Started with a book-style page-flipping design
     - Various cover designs were tried: nature/botanical, artsy/watercolor, photo background, spinning wheel with chapters, camera emoji, grid background, typing animation text
     - User eventually requested to abandon the book design entirely and switch to a standard scrolling web layout
     - Final design is a simple, cozy website with "Thru My Lens :)" header, sticky navigation, Nature/City photo sections, About section, and preserved photo management features (upload, edit, delete, lightbox)
  
  2. Key Technical Concepts:
     - CSS 3D transforms for page-flip animation (now removed)
     - CSS animations: typing/typewriter effect, spinning wheel rotation
     - CSS Grid for photo layouts
     - Sticky navigation with `position: sticky`
     - Lightbox image viewer
     - Password-protected photo editing/deletion via API
     - Node.js HTTP server for file uploads
     - Docker containerization for upload API
     - Google Fonts integration (Cormorant Garamond, EB Garamond, Montserrat)
  
  3. Files and Code Sections:
     - `/var/www/rosy.shitchell.com/srv/web/photography/index.html`
       - Main photography page - completely rewritten from book layout to standard scrolling web page
       - Final structure: Header → Sticky Nav → Nature Section → City Section → About Section → Footer
       - Key CSS variables: `--bg: #f5f0eb`, `--ink: #2c2825`, `--ink-light: #5a534d`, `--accent: #7a6348`
       - Header styling (most recent edit - reduced padding):
       ```css
       header {
           text-align: center;
           padding: 40px 20px 30px;
       }
       ```
       - Photo grid with hover effects, lightbox functionality, edit buttons preserved
  
     - `/var/www/rosy.shitchell.com/srv/web/photography/upload.html`
       - Upload form with password protection, drag & drop
       - Categories: Nature (landscapes) and City (historic)
  
     - `/var/www/rosy.shitchell.com/srv/upload-api/server.js`
       - Node.js server handling `/photos`, `/upload`, `/edit`, `/delete` endpoints
       - Password: `Rr16234160!`
  
  4. Errors and fixes:
     - **Photos not displaying after adding spinning wheel**: The slideshow JavaScript code was trying to access elements (`coverSlideshow`, `coverNav`) that no longer existed after replacing with spinning wheel, causing errors that stopped photo loading.
       - Fix: Removed the broken slideshow code and kept only the loadPhotos function
     - **Chapters overlapping on spinning wheel**: Initial implementation had both chapters stacked
       - Fix: Changed CSS positioning to place them on opposite sides using `translateY(-35%)` with different rotations
     - **Cover design iterations**: Multiple cover designs were rejected by user
       - User feedback: "cover is not what I wanted LOL" - tried artsy instead
       - Continued iterating through various styles until user requested complete redesign to standard web layout
  
  5. Problem Solving:
     - Transitioned from complex book-style design to simple scrolling website based on user preference
     - Preserved all photo management functionality (upload, edit, delete, lightbox) through redesign
     - Maintained cozy aesthetic with warm colors and elegant typography
  
  6. All user messages:
     - "Can you move Pages count and Add more from middle to left bottom on the book? becuase it was blocked by the arrow button? We also need to change the photobook cover to be a bit more cozy and nature"
     - "cover is not what I wanted LOL"
     - "artsy?"
     - "make the book fit to entire screen"
     - "can you take off the Rosy Photography and keep the cover blank?"
     - "don't show 'click to open'"
     - "I have a photo I want to put to fit to cover page. Can you send a link so I can upload thru it?"
     - "yep i just uploaded it!"
     - "on the bottom add a small line saying 'Photo by my Dear friend, Chien :)' on the top have big and straight words saying 'THRU LENS'"
     - "photo too bit make it smaller thanks"
     - "cover photo font- Garamond Premier"
     - "make the 'thru lens' to fit whole page and color is the cover photo color and you can take offf cover photo after doing the color"
     - "keep the cover photo but make it lighter"
     - "text color dark"
     - "make an animation of photos keep scrolling on cover photo? and take off the thru lens"
     - "make the cover photo color original? add the floating fancy nevagate bar on center?"
     - "make the cover page blank"
     - "spinning wheel on cover page and have each chapter on it."
     - "oops all chapters needs to be seperate! LOL I love this haha"
     - "I don't see the photos inside the book?"
     - "take off the test on cover page?"
     - "make the spinning wheel colorful like winter season!"
     - "go back to previos version and make lines thicker"
     - "remove the spinning wheel. add a camera on cover page"
     - "make cover page white big grids"
     - "and remove camera"
     - "take off grid. and only have cozy words of 'Thru My Lens' in the center and middle size"
     - "make text bigger"
     - "Can you make an animatoin on writing the text?"
     - "add :) to thru my lens"
     - "keep 'about' on the last page"
     - "i don't see about?"
     - "also book is too wide make it not too wide"
     - "a seperate page is fine"
     - "a bit wider"
     - "1200 px"
     - "make the book much wider"
     - "don't do the book design. make it more like a web"
     - "header space to 1/2"
  
  7. Pending Tasks:
     - None explicitly pending - last request (header space to 1/2) was completed
  
  8. Current Work:
     Just completed reducing the header spacing to half. Changed header padding from `80px 20px 60px` to `40px 20px 30px`.
  
     The website is now a standard scrolling design at https://rosy.shitchell.com/photography/ with:
     - "Thru My Lens :)" title header
     - Sticky navigation (Nature, City, About)
     - Photo grid sections
     - About section
     - Upload link in footer
  
  9. Optional Next Step:
     No explicit next step - the last task (header space to 1/2) was completed. The user may want to continue refining the web design, but should wait for their next request to confirm direction..
  Please continue the conversation from where we left it off without asking the user any further questions. Continue with the last task that you were asked to work on.
Queue: dequeue
File History Snapshot (2025-12-08T01:56:03.452Z)
ASSISTANT
  I just reduced the header spacing to half as you requested. The header padding is now `40px 20px 30px` (down from `80px 20px 60px`).
  
  Your photography page at https://rosy.shitchell.com/photography/ now has:
  - Compact header with "Thru My Lens :)"
  - Sticky navigation bar (Nature, City, About)
  - Photo grid sections for each category
  - About section at the bottom
  - Footer with upload link
  
  Let me know if you'd like any other adjustments to the layout!
  Tokens: in=2 out=131 cache=17760
USER
  add copyright
ASSISTANT
Tool: Read
  (toolu_01Lw7drPcZMfdNEAe5rnhPri)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
  Tokens: in=2 out=76 cache=39637
Result
  (toolu_01Lw7drPcZMfdNEAe5rnhPri)
         1→<!DOCTYPE html>
         2→<html lang="en">
         3→<head>
         4→    <meta charset="UTF-8">
         5→    <meta name="viewport" content="width=device-width, initial-scale=1.0">
         6→    <title>Thru My Lens :) - Rosy's Photography</title>
         7→    <link rel="preconnect" href="https://fonts.googleapis.com">
         8→    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
         9→    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap" rel="stylesheet">
        10→    <style>
        11→        :root {
        12→            --bg: #f5f0eb;
        13→            --ink: #2c2825;
        14→            --ink-light: #5a534d;
        15→            --ink-faint: #8a847d;
        16→            --accent: #7a6348;
        17→        }
        18→
        19→        * {
        20→            margin: 0;
    ... (693 lines total)
ASSISTANT
  I'll add a copyright notice to the footer:
  Tokens: in=0 out=2 cache=39773
ASSISTANT
Tool: Edit
  (toolu_01YPL9C6RqtaTUfj8x3tmDoE)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <footer>
            <a href="/photography/upload.html">Upload Photos</a>
        </footer>
    new_string:     <footer>
            <p>&copy; 2025 Rosy. All rights reserved.</p>
            <a href="/photography/upload.html">Upload Photos</a>
        </footer>
  Tokens: in=0 out=194 cache=39773
Result
  (toolu_01YPL9C6RqtaTUfj8x3tmDoE)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       453→        <p>Thank you for viewing.</p>
       454→        <p class="signature">— Rosy</p>
       455→    </section>
       456→
       457→    <footer>
       458→        <p>&copy; 2025 Rosy. All rights reserved.</p>
       459→        <a href="/photography/upload.html">Upload Photos</a>
       460→    </footer>
       461→
       462→    <!-- Lightbox -->
       463→    <div class="lightbox" id="lightbox">
       464→        <span class="lightbox-close" onclick="closeLightbox()">&times;</span>
ASSISTANT
  Done! Added a copyright line to the footer: "© 2025 Rosy. All rights reserved."
  
  You can see it at the bottom of your page at https://rosy.shitchell.com/photography/
  Tokens: in=0 out=53 cache=47997
File History Snapshot (2025-12-08T01:56:47.311Z)
USER
  can you the first version about?
ASSISTANT
  I'm not sure I understand - could you clarify what you mean by "the first version about"? 
  
  Are you asking me to:
  1. **Change the About section text** to something different?
  2. **Show you what the About section looked like** in an earlier version?
  3. Something else?
  
  Let me know what you'd like!
  Tokens: in=2 out=1 cache=48414
File History Snapshot (2025-12-08T01:57:35.486Z)
USER
  2.
ASSISTANT
  From the conversation history, the About section was first added when you requested to switch from the book design to a standard web layout. The original About section I created looked like this:
  
  ```html
  <section id="about">
      <div class="section-header">
          <h2 class="section-title">About</h2>
      </div>
      <p>A collection of moments captured through my lens.</p>
      <p>Thank you for viewing.</p>
      <p class="signature">— Rosy</p>
  </section>
  ```
  
  That's actually the same as what's currently on the page - it hasn't been changed since it was first added. The About section has always had:
  - "About" as the title
  - "A collection of moments captured through my lens."
  - "Thank you for viewing."
  - "— Rosy" as the signature
  
  Would you like me to change it to something different?
  Tokens: in=2 out=213 cache=48578
File History Snapshot (2025-12-08T01:58:48.857Z)
USER
  no it was before the book design
ASSISTANT
  Ah, I don't have access to what the About section looked like before the book design - that was in a previous conversation that got summarized, and the summary didn't include the original About text.
  
  Do you remember what it said, or would you like me to write something new for it?
  Tokens: in=2 out=65 cache=48664
File History Snapshot (2025-12-08T02:01:26.534Z)
USER
  I can you check the git history to see?
ASSISTANT
  Good idea! Let me check the git history for the photography page.
  Tokens: in=2 out=1 cache=48887
ASSISTANT
Tool: Bash
  (toolu_019xPdzpRXEPJgNffELLQf9v)
    command: cd ~/code/git/rosy-web && git log --oneline public/photography/index.html | head -20
    description: Check git history for photography page
  Tokens: in=2 out=115 cache=48887
Result
  (toolu_019xPdzpRXEPJgNffELLQf9v)
    fatal: ambiguous argument 'public/photography/index.html': unknown revision or path not in the working tree.
    Use '--' to separate paths from revisions, like this:
    'git <command> [<revision>...] -- [<file>...]'
ASSISTANT
Tool: Bash
  (toolu_01Uk1yLj8W8Pq483hK3LGVTP)
    command: cd ~/code/git/rosy-web && git log --oneline -- public/photography/index.html | head -20
    description: Check git history for photography page
  Tokens: in=0 out=101 cache=49068
Result
  (toolu_01Uk1yLj8W8Pq483hK3LGVTP)
ASSISTANT
Tool: Bash
  (toolu_016x7uhducS9hjcTccscFZdx)
    command: cd ~/code/git/rosy-web && git log --oneline | head -20
    description: Check git commit history
  Tokens: in=0 out=91 cache=49255
Result
  (toolu_016x7uhducS9hjcTccscFZdx)
    ab9f5ea Update password hint to ask Rosy instead of Guy
    8d4bf38 feat: Update landing page with OLTP/OLAP schema documentation
    041b8b5 Initial setup: Landing page with SQL practice info and GitHub Actions deploy
ASSISTANT
Tool: Bash
  (toolu_0145iLQqwhguapjdjRcCwkVc)
    command: cd ~/code/git/rosy-web && ls -la public/
    description: List public directory contents
  Tokens: in=0 out=87 cache=49469
Result
  (toolu_0145iLQqwhguapjdjRcCwkVc)
    total 20
    drwxrwxr-x 2 rosy rosy  4096 Dec  5 07:18 .
    drwxrwxr-x 5 rosy rosy  4096 Dec  5 07:18 ..
    -rw-rw-r-- 1 rosy rosy 11476 Dec  5 08:39 index.html
ASSISTANT
  It looks like the photography folder hasn't been committed to the git repo yet - the changes have only been made directly in `/var/www/rosy.shitchell.com/srv/web/photography/` but not pushed to the repo.
  
  Let me check the deployed web directory's git history if there is one, or look for any backup:
  Tokens: in=0 out=1 cache=49630
ASSISTANT
Tool: Bash
  (toolu_01TEDQAKTeC8GD5sgrgJTHJh)
    command: cd /var/www/rosy.shitchell.com/srv/web && git log --oneline -- photography/index.html 2>/dev/null | head -20 || echo "Not a git repo or no history"
    description: Check deployed directory git history
  Tokens: in=0 out=201 cache=49630
Result
  (toolu_01TEDQAKTeC8GD5sgrgJTHJh)
    Shell cwd was reset to /home/rosy
ASSISTANT
  Unfortunately, the photography page changes haven't been committed to git - they've only been edited directly on the server. So there's no version history available to look back at the original About section text.
  
  Would you like to tell me what you remember it saying, or would you like me to write a new version?
  Tokens: in=0 out=67 cache=49824
File History Snapshot (2025-12-08T02:02:21.905Z)
USER
   a new version more poetry
ASSISTANT
Tool: Edit
  (toolu_01HH4bpfHL5baDy8oS1dpcaB)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:     <section id="about">
            <div class="section-header">
                <h2 class="section-title">About</h2>
            </div>
            <p>A collection of moments captured through my lens.</p>
            <...
    new_string:     <section id="about">
            <div class="section-header">
                <h2 class="section-title">About</h2>
            </div>
            <p>Light falls softly on quiet corners,</p>
            <p>and I try t...
  Tokens: in=2 out=319 cache=50151
Result
  (toolu_01HH4bpfHL5baDy8oS1dpcaB)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       444→        </div>
       445→        <div class="section-footer" id="city-footer"></div>
       446→    </section>
       447→
       448→    <section id="about">
       449→        <div class="section-header">
       450→            <h2 class="section-title">About</h2>
       451→        </div>
       452→        <p>Light falls softly on quiet corners,</p>
       453→        <p>and I try to hold it still.</p>
       454→        <p>These are the moments that whispered to me—</p>
       455→        <p>now they whisper to you.</p>
       456→        <p class="signature">— Rosy</p>
       457→    </section>
       458→
       459→    <footer>
       460→        <p>&copy; 2025 Rosy. All rights reserved.</p>
       461→        <a href="/photography/upload.html">Upload Photos</a>
ASSISTANT
  Done! The About section now reads:
  
  > *Light falls softly on quiet corners,*
  > *and I try to hold it still.*
  > *These are the moments that whispered to me—*
  > *now they whisper to you.*
  > 
  > *— Rosy*
  
  Check it out at https://rosy.shitchell.com/photography/#about
  
  Let me know if you'd like it tweaked!
  Tokens: in=0 out=101 cache=50224
File History Snapshot (2025-12-08T02:07:27.631Z)
USER
  i like it thanks!
ASSISTANT
  You're welcome! Glad you like it! 
  
  Let me know if you want any other changes to your photography site.
  Tokens: in=2 out=29 cache=50856
File History Snapshot (2025-12-08T02:08:35.762Z)
USER
  make the header floating ?
ASSISTANT
Tool: Edit
  (toolu_01FYREvLx3DLKAQjvGzkhA1J)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
            }
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
                position: sticky;
                top: 0;
                background: var(--bg);
            ...
  Tokens: in=2 out=209 cache=51066
Result
  (toolu_01FYREvLx3DLKAQjvGzkhA1J)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 40px 20px 30px;
        36→            position: sticky;
        37→            top: 0;
        38→            background: var(--bg);
        39→            z-index: 101;
        40→        }
        41→
        42→        .site-title {
        43→            font-family: 'Cormorant Garamond', Georgia, serif;
        44→            font-size: clamp(2.5rem, 8vw, 4rem);
ASSISTANT
  Done! The header with "Thru My Lens :)" is now sticky/floating - it stays at the top of the screen as you scroll down.
  
  Check it out at https://rosy.shitchell.com/photography/
  
  Would you like the navigation bar to stick below it, or just have the header float alone?
  Tokens: in=0 out=75 cache=51103
File History Snapshot (2025-12-08T02:09:15.731Z)
USER
  navigation too and add glass effect
ASSISTANT
Tool: Edit
  (toolu_01BYivaDrqiyv74aVamjc3dz)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
                position: sticky;
                top: 0;
                background: var(--bg);
            ...
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
                position: sticky;
                top: 0;
                background: rgba(245, 240, 235,...
  Tokens: in=2 out=275 cache=51568
Result
  (toolu_01BYivaDrqiyv74aVamjc3dz)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 40px 20px 30px;
        36→            position: sticky;
        37→            top: 0;
        38→            background: rgba(245, 240, 235, 0.8);
        39→            backdrop-filter: blur(12px);
        40→            -webkit-backdrop-filter: blur(12px);
        41→            z-index: 101;
        42→        }
        43→
        44→        .site-title {
        45→            font-family: 'Cormorant Garamond', Georgia, serif;
        46→            font-size: clamp(2.5rem, 8vw, 4rem);
ASSISTANT
Tool: Edit
  (toolu_01JNYJmHBFgbgvgFsHsc4DEZ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                border-top: 1px solid rgba(0,0,0,0....
    new_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                border-top: 1px solid rgba(0,0,0,0....
  Tokens: in=0 out=380 cache=51753
Result
  (toolu_01JNYJmHBFgbgvgFsHsc4DEZ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        49→            color: var(--ink-light);
        50→            letter-spacing: 0.05em;
        51→        }
        52→
        53→        /* Navigation */
        54→        nav {
        55→            display: flex;
        56→            justify-content: center;
        57→            gap: 40px;
        58→            padding: 20px;
        59→            border-top: 1px solid rgba(0,0,0,0.08);
        60→            border-bottom: 1px solid rgba(0,0,0,0.08);
        61→            background: rgba(245, 240, 235, 0.8);
        62→            backdrop-filter: blur(12px);
        63→            -webkit-backdrop-filter: blur(12px);
        64→            position: sticky;
        65→            top: 117px;
        66→            z-index: 100;
        67→        }
    ... (24 lines total)
ASSISTANT
  Done! Both the header and navigation now have a frosted glass effect - they're semi-transparent with a blur that makes content underneath look blurry when scrolling.
  
  Check it out at https://rosy.shitchell.com/photography/ - scroll down to see the glass effect in action!
  Tokens: in=0 out=68 cache=52325
File History Snapshot (2025-12-08T02:11:01.468Z)
USER
  sorry i don't like this. can you make hearder not floating but make navigation a frosted glass effect ?
ASSISTANT
Tool: Edit
  (toolu_01QRFPaY5pQ2U6oG5mo2YiXh)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
                position: sticky;
                top: 0;
                background: rgba(245, 240, 235,...
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
            }
  Tokens: in=2 out=244 cache=53053
Result
  (toolu_01QRFPaY5pQ2U6oG5mo2YiXh)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 40px 20px 30px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(2.5rem, 8vw, 4rem);
ASSISTANT
Tool: Edit
  (toolu_01AUL1GKnF7jiGRm2aBa7Q56)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                border-top: 1px solid rgba(0,0,0,0....
    new_string:         /* Navigation */
            nav {
                display: flex;
                justify-content: center;
                gap: 40px;
                padding: 20px;
                border-top: 1px solid rgba(0,0,0,0....
  Tokens: in=0 out=415 cache=53248
Result
  (toolu_01AUL1GKnF7jiGRm2aBa7Q56)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        43→            color: var(--ink-light);
        44→            letter-spacing: 0.05em;
        45→        }
        46→
        47→        /* Navigation */
        48→        nav {
        49→            display: flex;
        50→            justify-content: center;
        51→            gap: 40px;
        52→            padding: 20px;
        53→            border-top: 1px solid rgba(0,0,0,0.08);
        54→            border-bottom: 1px solid rgba(0,0,0,0.08);
        55→            background: rgba(245, 240, 235, 0.7);
        56→            backdrop-filter: blur(12px);
        57→            -webkit-backdrop-filter: blur(12px);
        58→            position: sticky;
        59→            top: 0;
        60→            z-index: 100;
        61→        }
    ... (24 lines total)
ASSISTANT
  Done! Now:
  - Header scrolls away normally (not floating)
  - Navigation bar sticks to the top with a frosted glass effect
  
  Check it out at https://rosy.shitchell.com/photography/ - when you scroll past the title, the nav bar will stick with that nice blurry glass look!
  Tokens: in=0 out=74 cache=53705
File History Snapshot (2025-12-08T02:13:27.680Z)
USER
  what is the space of header?
ASSISTANT
  The current header spacing is:
  
  ```css
  padding: 40px 20px 30px;
  ```
  
  This means:
  - **40px** on top
  - **20px** on left and right
  - **30px** on bottom
  
  Would you like me to change it?
  Tokens: in=2 out=66 cache=54467
File History Snapshot (2025-12-08T02:13:54.933Z)
USER
  make it 30 on top and 20px on bottom
ASSISTANT
Tool: Edit
  (toolu_01GArii7C2YPuqb1jZS7frZg)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 40px 20px 30px;
            }
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 30px 20px 20px;
            }
  Tokens: in=2 out=178 cache=54652
Result
  (toolu_01GArii7C2YPuqb1jZS7frZg)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 30px 20px 20px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(2.5rem, 8vw, 4rem);
ASSISTANT
  Done! Header is now 30px top, 20px sides, 20px bottom.
  Tokens: in=0 out=23 cache=54734
File History Snapshot (2025-12-08T02:14:37.631Z)
USER
  20px top and 10px bottom. navigation text bold
ASSISTANT
Tool: Edit
  (toolu_01EkZeef1f32dCYhCHUgfqGJ)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         /* Header */
            header {
                text-align: center;
                padding: 30px 20px 20px;
            }
    new_string:         /* Header */
            header {
                text-align: center;
                padding: 20px 20px 10px;
            }
  Tokens: in=2 out=178 cache=55125
Result
  (toolu_01EkZeef1f32dCYhCHUgfqGJ)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        28→            color: var(--ink);
        29→            line-height: 1.6;
        30→        }
        31→
        32→        /* Header */
        33→        header {
        34→            text-align: center;
        35→            padding: 20px 20px 10px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(2.5rem, 8vw, 4rem);
ASSISTANT
Tool: Edit
  (toolu_01Cwn9uSTEUm67zS3HCF98XR)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         nav a {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.1rem;
                color: var(--ink-light);
                text-decoration: none;
                transi...
    new_string:         nav a {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.1rem;
                font-weight: 600;
                color: var(--ink-light);
                text-decora...
  Tokens: in=0 out=261 cache=55264
Result
  (toolu_01Cwn9uSTEUm67zS3HCF98XR)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        59→            top: 0;
        60→            z-index: 100;
        61→        }
        62→
        63→        nav a {
        64→            font-family: 'Cormorant Garamond', Georgia, serif;
        65→            font-size: 1.1rem;
        66→            font-weight: 600;
        67→            color: var(--ink-light);
        68→            text-decoration: none;
        69→            transition: color 0.3s;
        70→        }
        71→
        72→        nav a:hover {
        73→            color: var(--accent);
        74→        }
ASSISTANT
  Done! Header is now 20px top, 10px bottom, and navigation links are bold.
  Tokens: in=0 out=3 cache=55655
File History Snapshot (2025-12-08T02:15:37.820Z)
USER
  sorry i don't like it bold. undo that 
ASSISTANT
Tool: Edit
  (toolu_014WTkhWz3pWX5dt93rE2tte)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         nav a {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.1rem;
                font-weight: 600;
                color: var(--ink-light);
                text-decora...
    new_string:         nav a {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: 1.1rem;
                color: var(--ink-light);
                text-decoration: none;
                transi...
  Tokens: in=2 out=261 cache=56145
Result
  (toolu_014WTkhWz3pWX5dt93rE2tte)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        59→            top: 0;
        60→            z-index: 100;
        61→        }
        62→
        63→        nav a {
        64→            font-family: 'Cormorant Garamond', Georgia, serif;
        65→            font-size: 1.1rem;
        66→            color: var(--ink-light);
        67→            text-decoration: none;
        68→            transition: color 0.3s;
        69→        }
        70→
        71→        nav a:hover {
        72→            color: var(--accent);
        73→        }
ASSISTANT
  Done! Navigation is back to normal weight.
  Tokens: in=0 out=12 cache=56285
File History Snapshot (2025-12-08T02:18:40.077Z)
USER
  header text to "Thru Lens"
ASSISTANT
Tool: Edit
  (toolu_011HDcQKCW7zkeqLL9YNPYg1)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string: <h1 class="site-title">Thru My Lens :)</h1>
    new_string: <h1 class="site-title">Thru Lens</h1>
  Tokens: in=2 out=148 cache=56766
Result
  (toolu_011HDcQKCW7zkeqLL9YNPYg1)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
       415→    </style>
       416→</head>
       417→<body>
       418→    <header>
       419→        <h1 class="site-title">Thru Lens</h1>
       420→    </header>
       421→
       422→    <nav>
       423→        <a href="#nature">Nature</a>
ASSISTANT
  Done! Header now says "Thru Lens".
  Tokens: in=0 out=15 cache=56789
File History Snapshot (2025-12-08T02:19:32.130Z)
USER
  make text bigger
ASSISTANT
Tool: Edit
  (toolu_01LemASDaWz5AZebdLBtzwXT)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(2.5rem, 8vw, 4rem);
    new_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3.5rem, 10vw, 6rem);
  Tokens: in=2 out=213 cache=57193
Result
  (toolu_01LemASDaWz5AZebdLBtzwXT)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        34→            text-align: center;
        35→            padding: 20px 20px 10px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(3.5rem, 10vw, 6rem);
        41→            font-weight: 300;
        42→            font-style: italic;
        43→            color: var(--ink-light);
        44→            letter-spacing: 0.05em;
ASSISTANT
  Done! Title is now bigger.
  Tokens: in=0 out=10 cache=57212
File History Snapshot (2025-12-08T02:20:06.087Z)
USER
  slightly smaller
ASSISTANT
Tool: Edit
  (toolu_017JrbS2PDG3SfbWGD7i4pui)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3.5rem, 10vw, 6rem);
    new_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3rem, 9vw, 5rem);
  Tokens: in=2 out=210 cache=57637
Result
  (toolu_017JrbS2PDG3SfbWGD7i4pui)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        34→            text-align: center;
        35→            padding: 20px 20px 10px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(3rem, 9vw, 5rem);
        41→            font-weight: 300;
        42→            font-style: italic;
        43→            color: var(--ink-light);
        44→            letter-spacing: 0.05em;
ASSISTANT
  Done! Title is now slightly smaller.
  Tokens: in=0 out=6 cache=57753
File History Snapshot (2025-12-08T02:20:33.186Z)
USER
  smaller a bit only a little
ASSISTANT
Tool: Edit
  (toolu_01X2JPrY9dMFAvLVqoxnShRr)
    file_path: /var/www/rosy.shitchell.com/srv/web/photography/index.html
    old_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(3rem, 9vw, 5rem);
    new_string:         .site-title {
                font-family: 'Cormorant Garamond', Georgia, serif;
                font-size: clamp(2.8rem, 8.5vw, 4.5rem);
  Tokens: in=2 out=214 cache=58174
Result
  (toolu_01X2JPrY9dMFAvLVqoxnShRr)
    The file /var/www/rosy.shitchell.com/srv/web/photography/index.html has been updated. Here's the result of running `cat -n` on a snippet of the edited file:
        34→            text-align: center;
        35→            padding: 20px 20px 10px;
        36→        }
        37→
        38→        .site-title {
        39→            font-family: 'Cormorant Garamond', Georgia, serif;
        40→            font-size: clamp(2.8rem, 8.5vw, 4.5rem);
        41→            font-weight: 300;
        42→            font-style: italic;
        43→            color: var(--ink-light);
        44→            letter-spacing: 0.05em;
ASSISTANT
  Done! Just a little bit smaller now.
  Tokens: in=0 out=3 cache=58192
File History Snapshot (2025-12-08T02:25:33.509Z)
