:root {
            /* Garden palette mapped to app tokens so this page feels part
               of the same visual language as the chat page. */
            --garden-earth: var(--earth, #8B7355);
            --garden-leaf:  var(--air,   #87A889);
            --garden-bloom: var(--ether, #9B8AA8);
            --garden-sky:   var(--water, #5B8FA8);
            --garden-sun:   var(--accent, #C4A77D);
            --garden-water: var(--water-light, #7BA7BD);
        }
        body.growth-garden-page {
            overflow-y: auto !important;
            overflow-x: hidden;
            height: auto;
            min-height: 100vh;
            background: var(--bg-dark, #0a0a0f);
            color: var(--text-primary, #E8E6E3);
            font-family: var(--font-body, 'Inter', sans-serif);
        }
        body.growth-garden-page #app { height: auto; min-height: 100vh; }
        .container {
            max-width: 1000px;
            margin: 0 auto;
            padding: 20px;
            padding-top: 24px;
            min-height: 100vh;
            color: var(--text-primary, #E8E6E3);
        }

        .weather-banner {
            background: var(--bg-card, #12121a);
            border: 1px solid var(--border-color, #3a3a42);
            border-radius: 12px;
            padding: 24px;
            margin-bottom: 25px;
            display: flex;
            align-items: center;
            gap: 20px;
            position: relative;
            overflow: hidden;
        }
        .weather-icon { animation: float 3s ease-in-out infinite; color: var(--accent, #C4A77D); }
        @keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
        .weather-info h3 {
            margin: 0 0 5px 0;
            font-size: 1.2rem;
            font-family: var(--font-display, 'Crimson Pro', serif);
            font-weight: 400;
            color: var(--text-primary, #E8E6E3);
        }
        .weather-desc { color: var(--text-secondary, #A09A92); font-size: 0.9rem; }
        .weather-stats { margin-left: auto; display: flex; gap: 24px; }
        .weather-stat { text-align: center; }
        .weather-stat-value {
            display: block;
            font-size: 1.8rem;
            font-weight: 600;
            color: var(--accent, #C4A77D);
            font-family: var(--font-display, 'Crimson Pro', serif);
        }
        .weather-stat-label { font-size: 0.7rem; color: var(--text-muted, #6B665E); text-transform: uppercase; letter-spacing: 0.05em; }

        .garden-view {
            position: relative;
            height: 420px;
            background: linear-gradient(180deg,
                rgba(40, 50, 60, 0.6) 0%,
                rgba(60, 70, 60, 0.5) 30%,
                rgba(139, 115, 85, 0.25) 70%,
                rgba(50, 40, 30, 0.5) 100%);
            border-radius: 14px;
            margin-bottom: 25px;
            overflow: hidden;
            border: 1px solid var(--border-color, #3a3a42);
            box-shadow: 0 20px 60px rgba(0,0,0,0.4);
        }
        .garden-particles { position: absolute; top: 0; left: 0; right: 0; bottom: 0; pointer-events: none; overflow: hidden; }
        .particle { position: absolute; font-size: 1rem; opacity: 0.6; animation: particleFloat 10s linear infinite; }
        @keyframes particleFloat { 0% { transform: translateY(420px) rotate(0deg); opacity: 0; } 10% { opacity: 0.6; } 90% { opacity: 0.6; } 100% { transform: translateY(-50px) rotate(360deg); opacity: 0; } }
        .sky-layer { position: absolute; top: 0; left: 0; right: 0; height: 80px; display: flex; justify-content: flex-end; padding: 15px 25px; }
        .sky-element { font-size: 2rem; opacity: 0.8; animation: twinkle 2s ease-in-out infinite; }
        @keyframes twinkle { 0%, 100% { opacity: 0.6; transform: scale(1); } 50% { opacity: 1; transform: scale(1.1); } }
        .canopy-layer { position: absolute; top: 50px; left: 0; right: 0; height: 90px; display: flex; justify-content: center; align-items: flex-end; gap: 15px; padding: 10px; }
        .canopy-fruit { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.7rem; animation: sway 3s ease-in-out infinite; cursor: pointer; transition: all 0.3s; box-shadow: 0 5px 15px rgba(0,0,0,0.3); }
        .canopy-fruit:hover { transform: scale(1.3) translateY(-10px); box-shadow: 0 15px 30px rgba(0,0,0,0.4); }
        .canopy-fruit:nth-child(2) { animation-delay: -0.5s; }
        .canopy-fruit:nth-child(3) { animation-delay: -1s; }
        .canopy-fruit:nth-child(4) { animation-delay: -1.5s; }
        .canopy-fruit:nth-child(5) { animation-delay: -2s; }
        @keyframes sway { 0%, 100% { transform: rotate(-5deg) translateY(0); } 50% { transform: rotate(5deg) translateY(-5px); } }
        .beds-layer { position: absolute; top: 130px; left: 0; right: 0; height: 140px; display: flex; justify-content: space-around; align-items: center; padding: 20px 30px; }
        .garden-bed { background: linear-gradient(180deg, rgba(139,115,85,0.4) 0%, rgba(139,115,85,0.2) 100%); border-radius: 18px; padding: 18px; text-align: center; cursor: pointer; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); min-width: 120px; border: 1px solid rgba(139,115,85,0.3); }
        .garden-bed:hover { background: linear-gradient(180deg, rgba(139,115,85,0.6) 0%, rgba(139,115,85,0.4) 100%); transform: translateY(-10px) scale(1.05); box-shadow: 0 20px 40px rgba(0,0,0,0.4); }
        .bed-plants { font-size: 2.2rem; margin-bottom: 8px; }
        .bed-name { font-size: 0.85rem; color: var(--text-primary, #E8E6E3); font-weight: 500; }
        .bed-progress { height: 5px; background: var(--border-subtle, rgba(255,255,255,0.06)); border-radius: 3px; margin-top: 10px; overflow: hidden; }
        .bed-progress-fill { height: 100%; background: linear-gradient(90deg, var(--garden-leaf), var(--garden-sun)); border-radius: 3px; transition: width 0.8s ease; }
        .pathways-layer { position: absolute; top: 280px; left: 0; right: 0; height: 50px; display: flex; justify-content: center; gap: 15px; align-items: center; }
        .pathway { display: flex; align-items: center; gap: 8px; padding: 10px 16px; background: rgba(139,115,85,0.3); border-radius: 25px; font-size: 0.85rem; cursor: pointer; transition: all 0.3s; border: 1px solid rgba(139,115,85,0.3); }
        .pathway:hover { background: rgba(139,115,85,0.5); transform: scale(1.05); }
        .roots-layer { position: absolute; bottom: 0; left: 0; right: 0; height: 80px; background: linear-gradient(0deg, rgba(50,30,20,0.9) 0%, rgba(50,30,20,0.6) 50%, transparent 100%); display: flex; justify-content: center; align-items: center; gap: 20px; padding: 15px; }
        .root-stat { text-align: center; padding: 10px 18px; background: rgba(0,0,0,0.4); border-radius: 8px; }
        .root-value { font-size: 1.2rem; font-weight: 600; color: var(--accent, #C4A77D); display: block; font-family: var(--font-display, 'Crimson Pro', serif); }
        .root-label { font-size: 0.7rem; color: var(--text-muted, #6B665E); text-transform: uppercase; letter-spacing: 0.05em; }

        .growth-modes { display: flex; gap: 10px; margin-bottom: 25px; justify-content: center; flex-wrap: wrap; }
        .mode-btn {
            padding: 10px 18px;
            border-radius: 8px;
            cursor: pointer;
            font-size: 0.9rem;
            display: flex;
            align-items: center;
            gap: 8px;
            transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.2s;
            background: var(--bg-card, #12121a);
            color: var(--text-secondary, #A09A92);
            border: 1px solid var(--border-color, #3a3a42);
            font-weight: 500;
            font-family: var(--font-body, 'Inter', sans-serif);
        }
        .mode-btn:hover { background: var(--bg-elevated, #1a1a24); color: var(--text-primary, #E8E6E3); border-color: var(--accent, #C4A77D); transform: translateY(-2px); }
        .mode-btn.active {
            background: var(--accent, #C4A77D);
            color: var(--bg-dark, #0a0a0f);
            border-color: var(--accent, #C4A77D);
        }
        /* Keep the subtle per-mode tint on active state */
        .mode-btn.seed.active { background: var(--garden-earth); border-color: var(--garden-earth); }
        .mode-btn.nurture.active { background: var(--garden-water); border-color: var(--garden-water); }
        .mode-btn.bloom.active { background: var(--garden-bloom); border-color: var(--garden-bloom); }
        .mode-btn.harvest.active { background: var(--garden-sun); border-color: var(--garden-sun); }
        .mode-btn.renewal.active { background: var(--garden-leaf); border-color: var(--garden-leaf); }

        .habits-section, .reflections-section {
            margin-top: 30px;
            padding: 24px;
            background: var(--bg-card, #12121a);
            border-radius: 12px;
            border: 1px solid var(--border-color, #3a3a42);
        }
        .habits-section h2, .reflections-section h2 {
            margin: 0 0 20px 0;
            font-size: 1.25rem;
            font-family: var(--font-display, 'Crimson Pro', serif);
            font-weight: 400;
            color: var(--text-primary, #E8E6E3);
        }
        .section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
        .add-btn {
            background: var(--accent, #C4A77D);
            color: var(--bg-dark, #0a0a0f);
            border: none;
            padding: 9px 18px;
            border-radius: 8px;
            cursor: pointer;
            font-weight: 600;
            font-size: 0.9rem;
            transition: background 0.2s, transform 0.2s;
        }
        .add-btn:hover { background: var(--accent-gold, #D4B896); transform: translateY(-1px); }

        .habits-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
        .habit-card {
            background: var(--bg-elevated, #1a1a24);
            border-radius: 12px;
            padding: 20px;
            border: 1px solid var(--border-color, #3a3a42);
            transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
        }
        .habit-card:hover { border-color: var(--accent, #C4A77D); transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,0.4); }
        .habit-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
        .habit-icon { color: var(--accent, #C4A77D); }
        .habit-streak {
            background: rgba(196, 167, 125, 0.15);
            color: var(--accent, #C4A77D);
            padding: 3px 9px;
            border-radius: 999px;
            font-size: 0.75rem;
            font-weight: 600;
            border: 1px solid rgba(196, 167, 125, 0.3);
        }
        .habit-name { font-weight: 500; font-size: 1.05rem; margin-bottom: 6px; color: var(--text-primary, #E8E6E3); }
        .habit-trigger { font-size: 0.8rem; color: var(--text-muted, #6B665E); margin-bottom: 12px; }
        .habit-progress { height: 5px; background: var(--border-subtle, rgba(255,255,255,0.06)); border-radius: 3px; overflow: hidden; margin-bottom: 15px; }
        .habit-progress-fill { height: 100%; background: var(--accent, #C4A77D); border-radius: 3px; }
        .habit-actions { display: flex; gap: 8px; }
        .habit-action-btn { flex: 1; padding: 9px; border: 1px solid transparent; border-radius: 8px; cursor: pointer; font-weight: 500; font-size: 0.85rem; transition: background 0.2s, color 0.2s; }
        .complete-btn { background: rgba(196, 167, 125, 0.12); color: var(--accent, #C4A77D); border-color: rgba(196, 167, 125, 0.25); }
        .complete-btn:hover { background: rgba(196, 167, 125, 0.22); }
        .skip-btn { background: transparent; color: var(--text-muted, #6B665E); border-color: var(--border-color, #3a3a42); }
        .skip-btn:hover { background: var(--bg-card, #12121a); color: var(--text-secondary, #A09A92); }

        .reflection-input {
            width: 100%;
            padding: 14px;
            border-radius: 10px;
            border: 1px solid var(--border-color, #3a3a42);
            background: var(--bg-dark, #0a0a0f);
            color: var(--text-primary, #E8E6E3);
            font-size: 0.95rem;
            font-family: var(--font-body, 'Inter', sans-serif);
            min-height: 100px;
            resize: vertical;
            margin-bottom: 15px;
        }
        .reflection-input:focus { outline: none; border-color: var(--accent, #C4A77D); }
        .plant-btn {
            background: var(--accent, #C4A77D);
            color: var(--bg-dark, #0a0a0f);
            border: none;
            padding: 11px 22px;
            border-radius: 8px;
            cursor: pointer;
            font-weight: 600;
            font-size: 0.95rem;
            transition: background 0.2s, transform 0.2s;
        }
        .plant-btn:hover { background: var(--accent-gold, #D4B896); transform: translateY(-1px); }
        .recent-seeds { margin-top: 25px; }
        .recent-seeds h3 { margin-bottom: 15px; font-size: 0.9rem; color: var(--text-secondary, #A09A92); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; }
        .seed-card { display: flex; gap: 14px; padding: 14px; background: var(--bg-elevated, #1a1a24); border: 1px solid var(--border-color, #3a3a42); border-radius: 10px; margin-bottom: 10px; align-items: flex-start; }
        .seed-icon { color: var(--accent, #C4A77D); flex-shrink: 0; }
        .seed-content { flex: 1; }
        .seed-text { font-size: 0.95rem; line-height: 1.5; margin-bottom: 6px; color: var(--text-primary, #E8E6E3); }
        .seed-date { font-size: 0.75rem; color: var(--text-muted, #6B665E); }

        .empty-message { text-align: center; padding: 40px; color: var(--text-muted, #6B665E); }

        /* ═══════════════════════════════════════════════════════════════════
           GROWTH TREE VISUALIZATION
           ═══════════════════════════════════════════════════════════════════ */
        .growth-tree-section {
            margin-top: 30px;
            padding: 24px;
            background: var(--bg-card, #12121a);
            border-radius: 12px;
            border: 1px solid var(--border-color, #3a3a42);
        }
        .growth-tree-section h2 {
            margin: 0 0 8px 0;
            font-size: 1.3rem;
            color: var(--garden-leaf);
        }
        .growth-tree-section .tree-subtitle {
            color: rgba(255,255,255,0.5);
            font-size: 0.85rem;
            margin-bottom: 20px;
        }
        .growth-tree-container {
            display: flex;
            justify-content: center;
            align-items: center;
            background: linear-gradient(180deg, rgba(15,26,15,0.6) 0%, rgba(26,42,26,0.4) 100%);
            border-radius: 16px;
            border: 1px solid rgba(76,175,80,0.15);
            padding: 20px;
            min-height: 480px;
            position: relative;
            overflow: hidden;
        }
        .growth-tree-container svg {
            max-width: 100%;
            height: auto;
        }
        .growth-tree-container .tree-empty {
            text-align: center;
            color: rgba(255,255,255,0.4);
            font-size: 0.95rem;
        }
        .tree-legend {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-top: 16px;
            justify-content: center;
        }
        .tree-legend-item {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 0.75rem;
            color: rgba(255,255,255,0.6);
        }
        .tree-legend-swatch {
            width: 12px;
            height: 12px;
            border-radius: 3px;
        }
        /* Tooltip for tree elements */
        .tree-tooltip {
            position: absolute;
            background: rgba(0,0,0,0.85);
            color: #fff;
            padding: 8px 12px;
            border-radius: 8px;
            font-size: 0.8rem;
            pointer-events: none;
            opacity: 0;
            transition: opacity 0.2s;
            z-index: 10;
            white-space: nowrap;
            border: 1px solid rgba(200,180,140,0.3);
        }
        .tree-tooltip.visible {
            opacity: 1;
        }
        /* Pulse animation for leaves */
        @keyframes leafPulse {
            0%, 100% { opacity: 0.7; }
            50% { opacity: 1; }
        }
        .tree-leaf {
            animation: leafPulse 3s ease-in-out infinite;
        }
        .tree-leaf:nth-child(odd) { animation-delay: -1.5s; }
        /* Gentle sway for branches */
        @keyframes branchSway {
            0%, 100% { transform: rotate(0deg); }
            50% { transform: rotate(1deg); }
        }
        
        /* Modal styles */
        .modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.75); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; z-index: 1000; padding: 20px; }
        .modal-content {
            background: var(--bg-card, #12121a);
            border-radius: 14px;
            max-width: 500px;
            width: 100%;
            max-height: 90vh;
            overflow-y: auto;
            border: 1px solid var(--border-color, #3a3a42);
            box-shadow: 0 20px 60px rgba(0,0,0,0.5);
        }
        .modal-header {
            padding: 20px 24px;
            text-align: center;
            border-bottom: 1px solid var(--border-color, #3a3a42);
            font-family: var(--font-display, 'Crimson Pro', serif);
            color: var(--text-primary, #E8E6E3);
        }
        .modal-body { padding: 24px; }
        .modal-actions { display: flex; gap: 12px; padding: 18px 24px; border-top: 1px solid var(--border-color, #3a3a42); }
        .modal-actions button { flex: 1; padding: 10px; border-radius: 8px; border: 1px solid transparent; cursor: pointer; font-weight: 600; font-size: 0.9rem; transition: background 0.2s, border-color 0.2s; }
        .cancel-btn { background: transparent; color: var(--text-secondary, #A09A92); border-color: var(--border-color, #3a3a42); }
        .cancel-btn:hover { background: var(--bg-elevated, #1a1a24); color: var(--text-primary, #E8E6E3); }
        .save-btn { background: var(--accent, #C4A77D); color: var(--bg-dark, #0a0a0f); }
        .save-btn:hover { background: var(--accent-gold, #D4B896); }
        .form-group { margin-bottom: 18px; }
        .form-group label { display: block; margin-bottom: 8px; color: var(--text-secondary, #A09A92); font-size: 0.85rem; }
        .form-group input, .form-group select {
            width: 100%;
            padding: 10px 12px;
            border-radius: 8px;
            border: 1px solid var(--border-color, #3a3a42);
            background: var(--bg-dark, #0a0a0f);
            color: var(--text-primary, #E8E6E3);
            font-size: 0.95rem;
            font-family: var(--font-body, 'Inter', sans-serif);
        }
        .form-group input:focus, .form-group select:focus { outline: none; border-color: var(--accent, #C4A77D); }

        /* ===== Responsive breakpoints ===== */
        @media (max-width: 900px) {
            .container { padding: 16px; padding-top: 24px; }
            .page-title-section { padding: 16px 12px 12px; }
            .weather-banner {
                flex-direction: column;
                text-align: center;
                gap: 14px;
                padding: 20px 16px;
            }
            .weather-stats {
                margin-left: 0;
                justify-content: center;
                gap: 18px;
            }
            .weather-stat-value { font-size: 1.4rem; }
            .garden-view {
                height: auto;
                min-height: 360px;
            }
            .habits-grid {
                grid-template-columns: 1fr;
                gap: 14px;
            }
            .growth-modes {
                gap: 8px;
            }
            .mode-btn {
                padding: 10px 16px;
                font-size: 0.85rem;
            }
        }

        @media (max-width: 600px) {
            .container { padding: 12px; padding-top: 16px; }
            .page-title-section h1.page-title { font-size: 1.4rem; }
            .weather-banner { padding: 16px 12px; border-radius: 14px; }
            .weather-icon { margin: 0 auto; }
            .weather-stats { gap: 12px; }
            .weather-stat-value { font-size: 1.2rem; }
            .weather-stat-label { font-size: 0.7rem; }
            .canopy-fruit { width: 40px; height: 40px; font-size: 1.3rem; }
            .garden-bed { min-width: 90px; padding: 12px; }
            .habit-actions { flex-direction: column; gap: 8px; }
            .modal { padding: 10px; }
            .modal-body { padding: 16px; }
            .modal-actions { padding: 12px; gap: 10px; }
        }

        /* Growth-garden icon sizing: make SVG replacements match the visual
           weight the emojis had (avoid shrunken 18px defaults) */
        .weather-icon > svg { width: 48px; height: 48px; color: var(--garden-sun); }
        .sky-element > svg  { width: 36px; height: 36px; color: var(--garden-sun); }
        .canopy-fruit > svg { width: 28px; height: 28px; }
