:root{--color-primary:#2d5a3d;--color-primary-pale:#f4f9f4;--color-primary-dark:#1f3f2a;--color-background-light:#f8faf9;--color-background-dark:#f0f4f1;--color-border:#e1e8e3;--color-border-light:#f0f4f1;--color-text-primary:#1a1a1a;--color-text-secondary:#4a5a4f;--color-text-tertiary:#6b7c71;--color-success:#28a745;--color-success-light:#d4edda;--color-success-dark:#1e7e34;--color-error:#dc3545;--color-error-light:#f8d7da;--color-error-dark:#b02a37;--color-warning:#ffc107;--color-warning-light:#fff3cd;--color-warning-dark:#d39e00;--color-info:#17a2b8;--color-info-light:#d1ecf1;--color-info-dark:#138496;--color-urgent:#dc3545;--color-urgent-light:#f8d7da;--color-urgent-dark:#b02a37;--color-high:#fd7e14;--color-high-light:#ffe5d0;--color-high-dark:#d63384;--color-medium:#ffc107;--color-medium-light:#fff3cd;--color-medium-dark:#d39e00;--color-low:#28a745;--color-low-light:#d4edda;--color-low-dark:#1e7e34;--spacing-xxl:48px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a}.simple-investment-panel{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg)}.simple-investment-panel .panel-header{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.simple-investment-panel .header-controls{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.simple-investment-panel h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.2rem;font-weight:600;margin:0}.simple-investment-panel .item-count{background:#f8f9fa;background:var(--color-background-light);border-radius:12px;color:#7f8c8d;color:var(--color-text-tertiary);font-size:.9rem;padding:2px 8px}.investment-list{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.investment-item{background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:block;margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.investment-item:hover{background:#f8fff9;background:var(--color-primary-pale);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm)}.investment-item.selected,.investment-item:hover{border-color:#27ae60;border-color:var(--color-primary)}.investment-item.selected{background:#e8f5e8;background:var(--color-primary-light)}.investment-item .item-main{align-items:flex-start;display:flex;gap:16px;gap:var(--spacing-md)}.investment-item .item-icon{flex-shrink:0;font-size:1.3rem;margin-top:2px;text-align:center;width:32px}.investment-item .item-content{flex:1 1}.investment-item .item-name{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;line-height:1.3;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.investment-item .item-reason{color:#34495e;color:var(--color-text-secondary);font-size:.95rem;line-height:1.4;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.investment-item .item-price{align-self:flex-start;color:#229954;color:var(--color-primary-dark);flex-shrink:0;font-size:1.2rem;font-weight:700;margin-top:2px}.investment-item .selection-indicator{align-items:center;background:#fff;background:var(--color-background);border:2px solid #dee2e6;border:2px solid var(--color-border-dark);border-radius:50%;color:#27ae60;color:var(--color-primary);display:flex;font-size:.8rem;height:24px;justify-content:center;transition:all .2s ease;width:24px}.investment-item.selected .selection-indicator{background:#27ae60;background:var(--color-primary);border-color:#27ae60;border-color:var(--color-primary);color:#fff}.selection-summary{align-items:center;background:#e8f5e8;background:var(--color-primary-light);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;margin-top:16px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.selection-summary .selected-count{color:#34495e;color:var(--color-text-secondary);font-weight:500}.selection-summary .selected-total{color:#229954;color:var(--color-primary-dark);font-size:1.1rem;font-weight:600}.investment-item .item-actions{align-items:center;border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.investment-item .action-buttons{display:flex;gap:8px;gap:var(--spacing-sm);margin-left:auto}.add-btn,.owned-btn,.reject-btn{border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);text-align:center;transition:all .2s ease;white-space:nowrap}.add-btn{background:#f8fff9;border:1px solid #e8f5e8;color:#4a9e5a}.add-btn:hover{background:#e8f5e8;border-color:#4a9e5a;opacity:1}.owned-btn{background:#f8fbff;border:1px solid #e3f2fd;color:#4a7db2}.owned-btn:hover{background:#e3f2fd;border-color:#4a7db2;opacity:1}.reject-btn{border:1px solid #e0e0e0;color:#666}.reject-btn:hover{background:#f0f0f0;border-color:#999;opacity:1}.status-indicator{border-radius:var(--radius-md);font-size:.8rem;font-weight:500;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.status-indicator.shopping{background:#d5f4e6;color:#27ae60}.status-indicator.owned{background:#bbdefb;color:#1976d2}.status-indicator.rejected{background:#ffebee;color:#d32f2f}.investment-item.shopping{background:#f8fff9;border-color:#d5f4e6}.investment-item.owned{background:#f3f9ff;border-color:#bbdefb}.investment-item.rejected{background:#fafafa;border-color:#e0e0e0;opacity:.7}.shopping-list-panel{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;margin-bottom:var(--spacing-lg)}.shopping-list-panel .panel-header,.shopping-list-panel.empty{padding:16px;padding:var(--spacing-md)}.shopping-list-panel .panel-header{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);cursor:pointer;display:flex;justify-content:space-between}.shopping-list-panel.empty .panel-header{border-bottom:none;cursor:default}.shopping-list-panel h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;margin:0}.shopping-list-panel .header-info{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.shopping-list-panel .item-count{background:#f8f9fa;background:var(--color-background-light);border-radius:12px;color:#7f8c8d;color:var(--color-text-tertiary);font-size:.9rem;padding:2px 8px}.shopping-list-panel .total-cost{color:#229954;color:var(--color-primary-dark);font-weight:600}.shopping-list-panel .expand-icon{color:#7f8c8d;color:var(--color-text-tertiary);font-size:1.2rem;font-weight:600}.shopping-list-content{padding:16px;padding:var(--spacing-md)}.shopping-items{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.shopping-item{align-items:center;background:#f8f9fa;background:var(--color-background-light);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:8px;padding:var(--spacing-sm)}.shopping-item .item-info{flex:1 1}.shopping-item .item-name{color:#2c3e50;color:var(--color-text-primary);font-weight:500;margin-bottom:2px}.shopping-item .item-details{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.shopping-item .price{color:#2c3e50;color:var(--color-text-primary);font-weight:600}.shopping-item .urgency{background:#fafbfc;background:var(--color-background-subtle);border-radius:8px;color:#7f8c8d;color:var(--color-text-tertiary);font-size:.75rem;padding:2px 6px}.shopping-item .urgency.urgency-urgent{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark)}.shopping-item .urgency.urgency-high{background:#fdeaa7;background:var(--color-warning-light);color:#b7791f;color:var(--color-warning-dark)}.shopping-item.urgent-timing{background:#fdeaa7;background:var(--color-warning-light);border-left:3px solid #f39c12;border-left:3px solid var(--color-warning)}.planting-info{background:#f8fff9;background:var(--color-primary-pale);border-radius:4px;color:#229954;color:var(--color-primary-dark);font-size:.75rem;padding:2px 6px}.timing-reminder{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.75rem;font-style:italic;margin-top:.25rem}.shopping-item.urgent-timing .timing-reminder{color:#b7791f;color:var(--color-warning-dark);font-weight:500}.shopping-item .remove-btn{align-items:center;background:none;border:none;border-radius:50%;color:#7f8c8d;color:var(--color-text-tertiary);cursor:pointer;display:flex;font-size:1.2rem;height:24px;justify-content:center;line-height:1;padding:.25rem;transition:all .15s ease;width:24px}.shopping-item .remove-btn:hover{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark)}.shopping-actions{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding-top:16px;padding-top:var(--spacing-md)}.clear-btn{background:#0000;border:1px solid #dee2e6;border:1px solid var(--color-border-dark);border-radius:4px;border-radius:var(--radius-sm);color:#7f8c8d;color:var(--color-text-tertiary);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .15s ease}.clear-btn:hover{background:#f8f9fa;background:var(--color-background-light);border-color:#7f8c8d;border-color:var(--color-text-tertiary)}.empty-message{font-style:italic;margin:0}.empty-message,.timing-toggle{color:#7f8c8d;color:var(--color-text-tertiary)}.timing-toggle{background:#0000;border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;padding:.25rem .5rem;transition:all .15s ease}.timing-toggle:hover{color:#27ae60;color:var(--color-primary)}.timing-toggle.active,.timing-toggle:hover{border-color:#27ae60;border-color:var(--color-primary)}.timing-toggle.active{background:#e8f5e8;background:var(--color-primary-light);color:#229954;color:var(--color-primary-dark)}.investment-item.urgent-timing{border-left:3px solid #f39c12;border-left:3px solid var(--color-warning)}.investment-item .item-content .item-name{font-weight:500}.investment-item[data-category="Indoor Starting"] .item-name{color:#229954;color:var(--color-primary-dark);font-weight:600}.investment-item[data-category="Indoor Starting"]{background:#f8fff9;background:var(--color-primary-pale);border:2px solid #27ae60;border:2px solid var(--color-primary)}.investment-item[data-category="Indoor Starting"] .consequences{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark);font-weight:500}.timing-info{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);margin-top:8px;margin-top:var(--spacing-sm);overflow:hidden;padding-top:8px;padding-top:var(--spacing-sm);width:100%}.planting-timeline{align-items:center;display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs);margin-bottom:4px;margin-bottom:var(--spacing-xs);width:100%}.timeline-label{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.75rem;font-weight:500}.planting-date{background:#f8fff9;background:var(--color-primary-pale);border-radius:4px;color:#229954;color:var(--color-primary-dark);font-size:.8rem;font-weight:500;padding:2px 6px}.time-until{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.75rem;font-style:italic}.consequences{word-wrap:break-word;align-items:flex-start;background:#f8f9fa;background:var(--color-background-light);border-left:3px solid #f39c12;border-left:3px solid var(--color-warning);border-radius:4px;border-radius:var(--radius-sm);color:#a93226;color:var(--color-error-dark);display:flex;font-size:.75rem;gap:4px;gap:var(--spacing-xs);line-height:1.3;margin-top:4px;margin-top:var(--spacing-xs);overflow-wrap:break-word;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.warning-icon{flex-shrink:0;font-size:.8rem;margin-top:1px}.garden-tasks-panel{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg)}.garden-tasks-panel .panel-header{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.garden-tasks-panel .header-controls{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.garden-tasks-panel h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.2rem;font-weight:600;margin:0}.task-list{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.task-item{align-items:center;background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:16px;padding:var(--spacing-md);transition:all .2s ease}.task-item:hover{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary)}.task-item.completed{background:#d5f4e6;background:var(--color-success-light);border-color:#27ae60;border-color:var(--color-success);opacity:.8}.task-item.urgent-timing{border-left:3px solid #e74c3c;border-left:3px solid var(--color-error)}.task-item[data-category="Indoor Starting"]{background:#d6eaf8;background:var(--color-info-light);border:2px solid #3498db;border:2px solid var(--color-info)}.task-item[data-category="Indoor Starting"] .consequences{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark);font-weight:500}.task-item .task-main{align-items:center;display:flex;flex:1 1;gap:16px;gap:var(--spacing-md)}.task-item .task-icon{font-size:1.2rem;text-align:center;width:32px}.task-item .task-content{flex:1 1}.task-item .task-name{color:#2c3e50;color:var(--color-text-primary);font-weight:500;margin-bottom:2px}.task-item .task-reason{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.9rem}.task-item .task-actions{align-items:center;display:flex}.complete-btn{border:1px solid #27ae60;border:1px solid var(--color-success);border-radius:4px;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .15s ease}.task-status.completed{color:#1e8449;color:var(--color-success-dark);font-size:.8rem;font-weight:500}.App{background:#f8f9fa;background:var(--color-background-light)}.main-navigation{background:#fff;background:var(--color-background);border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);flex-shrink:0;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.nav-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md)}.app-title{color:#229954;color:var(--color-primary-dark);font-size:1.4rem}.app-subtitle{font-size:.85rem}.nav-items{overflow-x:auto;padding-bottom:4px;padding-bottom:var(--spacing-xs)}.nav-item{border-radius:8px;border-radius:var(--radius-md);color:#2c3e50;color:var(--color-text-primary);min-width:-webkit-fit-content;min-width:fit-content;text-align:center;text-decoration:none}.nav-item:hover{background:#f8fff9;background:var(--color-primary-pale);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.nav-item.active{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md)}.nav-icon{flex-shrink:0;font-size:1.1rem}.nav-label{color:#2c3e50;color:var(--color-text-primary);font-size:.9rem;font-weight:500}.nav-badge{border-radius:12px;box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);font-weight:500;min-width:16px;padding:2px 6px;text-align:center}.nav-badge.new{background:#3498db;background:var(--color-info);color:#fff}.nav-badge.count{background:#27ae60;background:var(--color-primary);color:#fff}.main-content{background:#fff;background:var(--color-background);overflow-y:auto;padding:32px;padding:var(--spacing-xl)}.config-view,.dashboard-view,.results-view,.shopping-view,.tasks-view{margin:0 auto;max-width:1200px}.view-header{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);margin-bottom:48px;margin-bottom:var(--spacing-xxl);padding-bottom:24px;padding-bottom:var(--spacing-lg)}.view-header h2{color:#229954;color:var(--color-primary-dark);font-size:2.25rem}.view-subtitle{color:#7f8c8d;color:var(--color-text-tertiary);font-size:1.1rem;font-weight:400}.dashboard-header{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);margin-bottom:48px;margin-bottom:var(--spacing-xxl);padding-bottom:24px;padding-bottom:var(--spacing-lg)}.dashboard-header h2{color:#229954;color:var(--color-primary-dark);font-size:2.5rem;font-weight:600;margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.current-date{color:#7f8c8d;color:var(--color-text-tertiary);font-size:1.1rem;font-weight:400;margin:0}.priority-grid{grid-gap:32px;grid-gap:var(--spacing-xl);gap:32px;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:32px;margin-top:var(--spacing-xl)}.focus-card,.quick-actions-card,.status-summary,.urgent-section{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:32px;padding:var(--spacing-xl);transition:box-shadow .2s ease}.focus-card:hover,.quick-actions-card:hover,.status-summary:hover,.urgent-section:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md)}.focus-card h3,.quick-actions-card h3,.status-summary h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.2rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.focus-header{color:#229954;color:var(--color-primary-dark);margin:8px 0;margin:var(--spacing-sm) 0}.focus-bullet{margin:4px 0;margin:var(--spacing-xs) 0}.quick-actions-grid{grid-template-columns:1fr 1fr}.quick-action{background:#f8f9fa;background:var(--color-background-light);font-size:.9rem;transition:all .15s ease}.status-label{color:#7f8c8d;color:var(--color-text-tertiary)}.status-value{font-weight:500}.urgent-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.urgent-section h3{font-size:1.3rem}.section-description{font-style:italic}.no-shopping,.no-tasks,.section-description{color:#7f8c8d;color:var(--color-text-tertiary)}.shopping-help,.tasks-help{border:1px solid #f1f3f4;border:1px solid var(--color-border-light);margin-top:32px;margin-top:var(--spacing-xl)}.shopping-help li,.tasks-help li{margin-bottom:4px;margin-bottom:var(--spacing-xs)}@media (max-width:768px){.main-navigation{padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.nav-header{align-items:flex-start;flex-direction:column;gap:4px;gap:var(--spacing-xs);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.app-title{font-size:1.2rem}.app-subtitle{font-size:.8rem}.nav-items{gap:4px;gap:var(--spacing-xs);padding-bottom:4px;padding-bottom:var(--spacing-xs)}.nav-item{min-width:-webkit-fit-content;min-width:fit-content;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.nav-label{font-size:.8rem}.main-content{padding:16px;padding:var(--spacing-md)}.priority-grid,.quick-actions-grid{grid-template-columns:1fr}.investment-item{padding:16px;padding:var(--spacing-md)}.investment-item .item-main{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.investment-item .item-actions{flex-direction:column;gap:8px;gap:var(--spacing-sm)}.investment-item .action-buttons{justify-content:space-between;width:100%}.add-btn,.owned-btn,.reject-btn{flex:1 1}.status-indicator{align-self:flex-start}}.card{border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:16px;margin-bottom:var(--spacing-md);position:relative}.card:hover{border-color:#e9ecef;border-color:var(--color-border)}.card--pending{border-color:#f1f3f4;border-color:var(--color-border-light)}.card--committed{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary)}.card--completed{border-color:#e9ecef;border-color:var(--color-border);opacity:.8}.card--completed,.card--dismissed{background:#f8f9fa;background:var(--color-background-light)}.card--dismissed{border-color:#f1f3f4;border-color:var(--color-border-light);opacity:.6}.card--purchase{border-top:3px solid #27ae60;border-top:3px solid var(--color-success)}.card--task{border-top:3px solid #3498db;border-top:3px solid var(--color-info)}.card--planning{border-top:3px solid #f39c12;border-top:3px solid var(--color-warning)}.card--info{border-top:3px solid #7f8c8d;border-top:3px solid var(--color-text-tertiary)}.card--priority-urgent{animation:urgentPulse 2s infinite}.card--urgent{box-shadow:0 0 0 2px #e74c3c,0 2px 8px #0000001a;box-shadow:0 0 0 2px var(--color-error),var(--shadow-md)}.card--blocked{cursor:not-allowed;opacity:.5}@keyframes urgentPulse{0%,to{box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm)}50%{box-shadow:0 0 0 2px #e74c3c,0 4px 16px #0000001a;box-shadow:0 0 0 2px var(--color-error),var(--shadow-lg)}}.card__header{margin-bottom:16px;margin-bottom:var(--spacing-md)}.card__header-main{align-items:flex-start;display:flex;gap:16px;gap:var(--spacing-md);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.card__icon{flex-shrink:0;font-size:1.4rem;margin-top:2px;text-align:center;width:36px}.card__title-area{flex:1 1;min-width:0}.card__title{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 4px;margin:0 0 var(--spacing-xs) 0}.card__category{background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem;font-weight:500;padding:2px 8px}.card__indicators{align-items:center;display:flex;flex-shrink:0;gap:4px;gap:var(--spacing-xs)}.card__priority{border-radius:4px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.card__priority--urgent{background:#e74c3c;background:var(--color-error);color:#fff}.card__priority--high{background:#f39c12;background:var(--color-warning);color:#fff}.card__priority--medium{background:#3498db;background:var(--color-info);color:#fff}.card__priority--low{background:#7f8c8d;background:var(--color-text-tertiary);color:#fff}.card__state-icon{font-size:1rem;font-weight:700}.card__state-icon--committed{color:#27ae60;color:var(--color-primary)}.card__state-icon--completed{color:#27ae60;color:var(--color-success)}.card__state-icon--dismissed{color:#7f8c8d;color:var(--color-text-tertiary)}.card__urgent-indicator{animation:flash 1s infinite;background:#e74c3c;background:var(--color-error)}.card__blocked-indicator,.card__urgent-indicator{border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-size:.6rem;font-weight:700;padding:2px 4px}.card__blocked-indicator{background:#7f8c8d;background:var(--color-text-tertiary)}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.card__meta{align-items:center;border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:flex;font-size:.9rem;justify-content:space-between;padding:4px 0;padding:var(--spacing-xs) 0}.card__timeline{color:#34495e;color:var(--color-text-secondary);font-weight:500}.card__cost{color:#229954;color:var(--color-primary-dark);font-size:1rem;font-weight:700}.card__content{margin-bottom:16px;margin-bottom:var(--spacing-md)}.card__description{color:#34495e;color:var(--color-text-secondary);line-height:1.4;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.card__consequences,.card__dependencies{align-items:flex-start;border-radius:4px;border-radius:var(--radius-sm);display:flex;font-size:.85rem;gap:4px;gap:var(--spacing-xs);margin-bottom:4px;margin-bottom:var(--spacing-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.card__dependencies{border-left:3px solid #3498db;border-left:3px solid var(--color-info);color:#34495e;color:var(--color-text-secondary)}.card__consequences,.card__dependencies{background:#f8f9fa;background:var(--color-background-light)}.card__consequences{border-left:3px solid #f39c12;border-left:3px solid var(--color-warning);color:#a93226;color:var(--color-error-dark)}.card__consequences-icon,.card__dependencies-icon{flex-shrink:0;margin-top:1px}.card__expandable{margin-top:8px;margin-top:var(--spacing-sm)}.card__expanded-content{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);color:#34495e;color:var(--color-text-secondary);line-height:1.4;margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:8px 0;padding:var(--spacing-sm) 0}.card__expand-toggle{background:none;border:none;color:#27ae60;color:var(--color-primary);cursor:pointer;font-size:.85rem;font-weight:500;padding:0;text-decoration:underline}.card__expand-toggle:hover{color:#229954;color:var(--color-primary-dark)}.card__actions,.card__state-actions{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm);padding-top:16px;padding-top:var(--spacing-md)}.card__action{border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);text-align:center;transition:all .2s ease;white-space:nowrap}.card__action:disabled{cursor:not-allowed;opacity:.5}.card__action--primary{background:#27ae60;background:var(--color-primary);color:#fff;font-weight:600}.card__action--primary:hover:not(:disabled){background:#229954;background:var(--color-primary-dark);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.card__action--secondary{background:#f8f9fa;background:var(--color-background-light);border-color:#e9ecef;border-color:var(--color-border);color:#2c3e50;color:var(--color-text-primary)}.card__action--secondary:hover:not(:disabled){background:#f0f4f1;background:var(--color-background-dark);border-color:#27ae60;border-color:var(--color-primary)}.card__action--dismiss{background:#0000;color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem;margin-left:auto}.card__action--dismiss:hover{color:#34495e;color:var(--color-text-secondary);text-decoration:underline}.card__action--complete{background:#27ae60;background:var(--color-success);color:#fff}.card__action--complete:hover{background:#218838}.card__action--restore,.card__action--revert{background:#0000;color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem}.card__action--restore:hover,.card__action--revert:hover{color:#34495e;color:var(--color-text-secondary);text-decoration:underline}.card--purchase .card__action--primary{background:#27ae60;background:var(--color-success)}.card--purchase .card__action--primary:hover:not(:disabled){background:#218838}.card--task .card__action--primary{background:#3498db;background:var(--color-info)}.card--task .card__action--primary:hover:not(:disabled){background:#0056b3}.card--planning .card__action--primary{background:#f39c12;background:var(--color-warning);color:#2c3e50;color:var(--color-text-primary)}.card--planning .card__action--primary:hover:not(:disabled){background:#e0a800}@media (max-width:768px){.card{padding:16px;padding:var(--spacing-md)}.card__header-main{flex-direction:column;gap:8px;gap:var(--spacing-sm)}.card__indicators{align-self:flex-start}.card__actions,.card__state-actions{flex-direction:column}.card__action{width:100%}.card__action--dismiss{margin-left:0;order:999}}.planning-details,.purchase-details,.task-details{line-height:1.4;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.planning-details strong,.purchase-details strong,.task-details strong{color:#2c3e50;color:var(--color-text-primary);font-weight:600}.planning-options{margin:4px 0 0 16px;margin:var(--spacing-xs) 0 0 var(--spacing-md);padding:0}.planning-options li{list-style-type:none;margin-bottom:4px;margin-bottom:var(--spacing-xs);padding-left:8px;padding-left:var(--spacing-sm);position:relative}.planning-options li:before{color:#27ae60;color:var(--color-primary);content:"•";left:0;position:absolute}.planning-options-grid{grid-gap:8px;grid-gap:var(--spacing-sm);border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.planning-option-button{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;padding:16px;padding:var(--spacing-md);text-align:left;transition:all .2s ease}.planning-option-button:hover{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm)}.option-label{color:#2c3e50;color:var(--color-text-primary);font-weight:600;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.option-description{color:#34495e;color:var(--color-text-secondary);font-size:.85rem;line-height:1.3}.card-demo{margin:0 auto;max-width:1200px;padding:32px;padding:var(--spacing-xl)}.demo-header{margin-bottom:32px;margin-bottom:var(--spacing-xl);text-align:center}.demo-header h2{color:#229954;color:var(--color-primary-dark);margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.demo-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:32px;margin-bottom:var(--spacing-xl)}.demo-state-display{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.demo-state-display h3{color:#2c3e50;color:var(--color-text-primary);margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.demo-state-display pre{background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);font-size:.85rem;overflow-x:auto;padding:16px;padding:var(--spacing-md)}.shopping-card-list,.task-card-list{width:100%}.shopping-card-list__title,.task-card-list__title{color:#2c3e50;color:var(--color-text-primary);font-size:1.2rem;font-weight:600;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.shopping-card-list__cards,.task-card-list__cards{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}:root{--color-primary:#27ae60;--color-primary-dark:#229954;--color-primary-light:#e8f5e8;--color-primary-pale:#f8fff9;--color-text-primary:#2c3e50;--color-text-secondary:#34495e;--color-text-tertiary:#7f8c8d;--color-text-muted:#95a5a6;--color-background:#fff;--color-background-light:#f8f9fa;--color-background-subtle:#fafbfc;--color-border:#e9ecef;--color-border-light:#f1f3f4;--color-border-dark:#dee2e6;--color-success:#27ae60;--color-success-light:#d5f4e6;--color-success-dark:#1e8449;--color-warning:#f39c12;--color-warning-light:#fdeaa7;--color-warning-dark:#b7791f;--color-error:#e74c3c;--color-error-light:#fadbd8;--color-error-dark:#a93226;--color-info:#3498db;--color-info-light:#d6eaf8;--color-info-dark:#2471a3;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 2px 8px #0000001a;--shadow-lg:0 4px 16px #0000001a;--font-size-xs:12px;--font-size-sm:14px;--font-size-base:16px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:24px;--font-size-3xl:28px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.6}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--color-background-light);color:#2c3e50;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:16px;font-size:var(--font-size-base);line-height:1.5;line-height:var(--line-height-normal);margin:0;padding:0}.App{margin:0 auto;max-width:1200px;padding:24px;padding:var(--spacing-lg)}h1,h2,h3,h4,h5,h6{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2;line-height:var(--line-height-tight);margin:0 0 16px;margin:0 0 var(--spacing-md) 0}h1{font-size:28px;font-size:var(--font-size-3xl)}h2{font-size:24px;font-size:var(--font-size-2xl)}h3{font-size:20px;font-size:var(--font-size-xl)}h4{font-size:18px;font-size:var(--font-size-lg)}h5{font-size:16px;font-size:var(--font-size-base)}h6{font-size:14px;font-size:var(--font-size-sm)}p{color:#34495e;color:var(--color-text-secondary);margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.header{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:8px 0;padding:var(--spacing-sm) 0}.header-content{justify-content:space-between}.header-content,.header-main{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.app-title{font-size:18px;font-size:var(--font-size-lg);font-weight:700;font-weight:var(--font-weight-bold)}.app-subtitle{color:#7f8c8d;color:var(--color-text-tertiary);font-size:14px;font-size:var(--font-size-sm);margin:0}.location-info{align-items:center;display:flex;font-style:normal;gap:8px;gap:var(--spacing-sm)}.location-name{color:#34495e;color:var(--color-text-secondary)}.current-temp{background:#e8f5e8;background:var(--color-primary-light);border-radius:4px;border-radius:var(--radius-sm);color:#27ae60;color:var(--color-primary);font-weight:600;font-weight:var(--font-weight-semibold);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.current-temp,.header-quick-stats{font-size:14px;font-size:var(--font-size-sm)}.header-quick-stats{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.urgent-tasks{background:#f8d7da;background:var(--color-urgent-light);color:#b02a37;color:var(--color-urgent-dark)}.ready-harvest,.urgent-tasks{border-radius:4px;border-radius:var(--radius-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.ready-harvest{background:#d5f4e6;background:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.garden-management,.garden-quick-nav{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs)}.create-garden-btn,.quick-start-btn{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#2c3e50;color:var(--color-text-primary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.create-garden-btn:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary)}.quick-start-btn:hover{background:#fdeaa7;background:var(--color-warning-light);border-color:#f39c12;border-color:var(--color-warning)}.garden-content{padding:24px;padding:var(--spacing-lg)}.garden-info{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);justify-content:space-between;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.garden-info,.garden-status{align-items:center;display:flex}.garden-status{gap:16px;gap:var(--spacing-md)}.garden-id{background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);font-family:monospace;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.garden-id,.garden-readonly{font-size:14px;font-size:var(--font-size-sm)}.garden-readonly{color:#b7791f;color:var(--color-warning-dark)}.garden-owned{color:#1e8449;color:var(--color-success-dark);font-size:14px;font-size:var(--font-size-sm)}.garden-actions{display:flex;gap:8px;gap:var(--spacing-sm)}.fork-garden-btn,.share-garden-btn{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.fork-garden-btn:hover,.share-garden-btn:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary)}.location-saved-feedback{animation:fadeInOut 3s ease-in-out;background:#d5f4e6;background:var(--color-success-light);border:1px solid #27ae60;border:1px solid var(--color-success);border-radius:4px;border-radius:var(--radius-sm);color:#1e8449;color:var(--color-success-dark);font-size:14px;font-size:var(--font-size-sm);margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%,90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.settings-saved-feedback{animation:fadeInOut 2s ease-in-out;background:#d5f4e6;background:var(--color-success-light);border:1px solid #27ae60;border:1px solid var(--color-success);border-radius:4px;border-radius:var(--radius-sm);color:#1e8449;color:var(--color-success-dark);font-size:14px;font-size:var(--font-size-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-align:center}.card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:32px;margin-bottom:var(--spacing-xl);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.card:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md)}.card-header{border-bottom:2px solid #f1f3f4;border-bottom:2px solid var(--color-border-light);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding-bottom:16px;padding-bottom:var(--spacing-md)}.card-title{color:#2c3e50;color:var(--color-text-primary);font-size:20px;font-size:var(--font-size-xl);font-weight:600;font-weight:var(--font-weight-semibold);margin:0}.card-subtitle{color:#7f8c8d;color:var(--color-text-tertiary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:0;margin-top:4px;margin-top:var(--spacing-xs)}.investment-configurer{background:#fff;background:var(--color-background)}.investment-summary{background:#fafbfc;background:var(--color-background-subtle);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.investment-summary .summary-stats{display:flex;flex-wrap:wrap;gap:24px;gap:var(--spacing-lg)}.investment-summary .stat-item{background:none;border:none;color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);padding:0}.investment-summary .stat-item strong{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base)}.preset-section{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.preset-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:16px;margin-top:var(--spacing-md)}.preset-button{background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;padding:16px;padding:var(--spacing-md);text-align:left;transition:all .2s ease}.preset-button:hover{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm)}.preset-button strong{color:#2c3e50;color:var(--color-text-primary);display:block;font-size:16px;font-size:var(--font-size-base);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.preset-description{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.preset-total{color:#27ae60;color:var(--color-primary);font-weight:600;font-weight:var(--font-weight-semibold)}.advanced-toggle{margin:24px 0;margin:var(--spacing-lg) 0;text-align:center}.toggle-button{background:#e8f5e8;background:var(--color-primary-light);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);color:#27ae60;color:var(--color-primary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.toggle-button:hover{background:#27ae60;background:var(--color-primary);color:#fff;color:var(--color-background)}.advanced-config{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding-top:24px;padding-top:var(--spacing-lg)}.category-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:16px;margin-top:var(--spacing-md)}.category-item{background:#fafbfc;background:var(--color-background-subtle);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--spacing-md)}.category-item.essential{border-left:4px solid #27ae60;border-left:4px solid var(--color-success)}.category-item.optional{border-left:4px solid #3498db;border-left:4px solid var(--color-info)}.category-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.category-header h4{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);margin:0}.category-badge{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.category-badge.annual{background:#d5f4e6;background:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.category-badge.equipment{background:#d6eaf8;background:var(--color-info-light);color:#2471a3;color:var(--color-info-dark)}.category-description{color:#7f8c8d;color:var(--color-text-tertiary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.category-input{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.category-input label{align-items:center;display:flex;flex:1 1;gap:8px;gap:var(--spacing-sm)}.investment-slider{-webkit-appearance:none;appearance:none;background:#e9ecef;background:var(--color-border);border-radius:4px;border-radius:var(--radius-sm);flex:1 1;height:6px;outline:none}.investment-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#27ae60;background:var(--color-primary);border-radius:50%;cursor:pointer;height:18px;width:18px}.investment-slider::-moz-range-thumb{background:#27ae60;background:var(--color-primary);border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.investment-value{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold);min-width:50px;text-align:right}.investment-recommendations{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);margin-top:24px;margin-top:var(--spacing-lg);padding-top:24px;padding-top:var(--spacing-lg)}.recommendations-grid{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md);margin-top:16px;margin-top:var(--spacing-md)}.recommendation-item{border:1px solid}.recommendation-item.warning{background:#fdeaa7;background:var(--color-warning-light);border-color:#f39c12;border-color:var(--color-warning);color:#b7791f;color:var(--color-warning-dark)}.recommendation-item.info{background:#d6eaf8;background:var(--color-info-light);border-color:#3498db;border-color:var(--color-info);color:#2471a3;color:var(--color-info-dark)}.recommendation-item.success{background:#d5f4e6;background:var(--color-success-light);border-color:#27ae60;border-color:var(--color-success);color:#1e8449;color:var(--color-success-dark)}.recommendation-item strong{display:block;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.recommendation-item p{color:inherit;margin:0}.button{align-items:center;border:none;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:16px;font-size:var(--font-size-base);font-weight:500;font-weight:var(--font-weight-medium);gap:8px;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .2s ease}.button-primary{background:#27ae60;background:var(--color-primary);color:#fff;color:var(--color-background)}.button-primary:hover{background:#229954;background:var(--color-primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.button-secondary{background:#fff;background:var(--color-background);border:1px solid #dee2e6;border:1px solid var(--color-border-dark);color:#2c3e50;color:var(--color-text-primary)}.button-secondary:hover{background:#f8f9fa;background:var(--color-background-light);border-color:#27ae60;border-color:var(--color-primary)}.button:disabled{background:#95a5a6;background:var(--color-text-muted);box-shadow:none;color:#fff;color:var(--color-background);cursor:not-allowed;transform:none}.button-small{font-size:14px;font-size:var(--font-size-sm);min-height:36px;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.scenario-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.scenario-grid{grid-gap:32px;grid-gap:var(--spacing-xl);display:grid;gap:32px;gap:var(--spacing-xl);grid-template-columns:1fr 1fr;margin-top:24px;margin-top:var(--spacing-lg)}.scenario-column{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.scenario-column h3{color:#2c3e50;color:var(--color-text-primary);font-size:18px;font-size:var(--font-size-lg);margin-bottom:16px;margin-bottom:var(--spacing-md)}.scenario-button{background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;padding:24px;padding:var(--spacing-lg);text-align:left;transition:all .2s ease}.scenario-button:hover{transform:translateY(-2px)}.scenario-button.selected,.scenario-button:hover{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md)}.scenario-button.selected{background:#e8f5e8;background:var(--color-primary-light)}.scenario-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.scenario-header strong{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold)}.probability{color:#7f8c8d;color:var(--color-text-tertiary);font-weight:400;font-weight:var(--font-weight-normal)}.probability,.scenario-details{font-size:14px;font-size:var(--font-size-sm)}.scenario-details{color:#34495e;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.scenario-details .impact{color:#27ae60;color:var(--color-primary);font-weight:500;font-weight:var(--font-weight-medium)}.portfolio-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.portfolio-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:24px;margin-top:var(--spacing-lg)}.portfolio-button{background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;padding:32px;padding:var(--spacing-xl);text-align:left;transition:all .2s ease}.portfolio-button:hover{transform:translateY(-2px)}.portfolio-button.selected,.portfolio-button:hover{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md)}.portfolio-button.selected{background:#e8f5e8;background:var(--color-primary-light)}.portfolio-button strong{color:#2c3e50;color:var(--color-text-primary);display:block;font-size:18px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.portfolio-description{margin-bottom:16px;margin-bottom:var(--spacing-md)}.portfolio-allocations,.portfolio-description{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.portfolio-allocations{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.portfolio-allocations div{align-items:center;display:flex;justify-content:space-between}.portfolio-allocations .allocation-value{color:#27ae60;color:var(--color-primary);font-weight:500;font-weight:var(--font-weight-medium)}.results-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.results-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:24px;margin-top:var(--spacing-lg)}.result-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:24px;padding:var(--spacing-lg);text-align:center}.result-value{color:#27ae60;color:var(--color-primary);font-size:28px;font-size:var(--font-size-3xl);font-weight:700;font-weight:var(--font-weight-bold);line-height:1;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.result-label{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium)}.result-confidence{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs);font-style:italic;margin-top:4px;margin-top:var(--spacing-xs)}.garden-calendar{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.garden-calendar-dashboard{margin-bottom:0}.calendar-subtitle{color:#7f8c8d;color:var(--color-text-tertiary);font-style:italic;margin-bottom:8px;margin-bottom:var(--spacing-sm);text-align:center}.activity-legend{background:#f8f9fa;background:var(--color-background-light);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm);justify-content:center;margin-bottom:16px;margin-bottom:var(--spacing-md);padding:8px;padding:var(--spacing-sm)}.legend-item{font-size:12px;font-size:var(--font-size-xs);padding:2px 4px;padding:2px var(--spacing-xs);white-space:nowrap}.calendar-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.calendar-month{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.calendar-month.current{border-color:#27ae60;border-color:var(--color-primary);border-width:2px;box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:scale(1.02)}.calendar-month.peak{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary)}.month-header{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.month-header h5{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);margin:0}.month-emphasis,.month-header h5{font-weight:600;font-weight:var(--font-weight-semibold)}.month-emphasis{background:#27ae60;background:var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);color:#fff;color:var(--color-background);font-size:12px;font-size:var(--font-size-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.month-activities{list-style:none;margin:0;padding:0}.activity{background:#fafbfc;background:var(--color-background-subtle);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin:8px 0;margin:var(--spacing-sm) 0;overflow:hidden;padding:16px;padding:var(--spacing-md)}.activity,.activity-header{box-sizing:border-box;width:100%}.activity-header{flex-direction:column;gap:4px;gap:var(--spacing-xs);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.activity-header-row{width:100%}.activity-header-row,.activity-meta-row{align-items:center;display:flex;justify-content:space-between}.activity-meta-row{flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.activity-crop{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.activity-priority{background:#e74c3c;background:var(--color-error);border:1px solid #a93226;border:1px solid var(--color-error-dark);border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-size:12px;font-size:var(--font-size-xs);font-weight:600;font-weight:var(--font-weight-semibold);text-transform:uppercase}.activity-frequency,.activity-priority{padding:2px 8px;padding:2px var(--spacing-sm)}.activity-frequency{background:#d6eaf8;background:var(--color-info-light);border:1px solid #3498db;border:1px solid var(--color-info);color:#2471a3;color:var(--color-info-dark)}.next-due{font-size:12px;font-size:var(--font-size-xs)}.activity-action{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.activity-timing{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs);font-style:italic}.activity.activity-shopping{background:#fdeaa7;background:var(--color-warning-light);border-left-color:#f39c12;border-left-color:var(--color-warning)}.activity.activity-shopping .activity-action{font-weight:500;font-weight:var(--font-weight-medium)}.activity.activity-shopping .activity-crop{color:#b7791f;color:var(--color-warning-dark)}.activity.activity-succession{background:#d6eaf8;background:var(--color-info-light);border-left-color:#3498db;border-left-color:var(--color-info)}.activity.activity-succession .activity-crop{color:#2471a3;color:var(--color-info-dark)}.activity.activity-rotation{background:#e8f5e8;background:var(--color-primary-light);border-left-color:#27ae60;border-left-color:var(--color-primary)}.activity.activity-rotation .activity-crop{color:#229954;color:var(--color-primary-dark)}.activity.activity-indoor-starting{background:beige;border-left-color:#8b4513}.activity.activity-indoor-starting .activity-crop{color:#654321;font-weight:600;font-weight:var(--font-weight-semibold)}.activity.activity-indoor-starting .activity-action{color:#5d4037;font-weight:500;font-weight:var(--font-weight-medium)}.activity.activity-indoor-starting .activity-timing{color:#8d6e63;font-style:italic;font-weight:500;font-weight:var(--font-weight-medium)}.activity.activity-seed-starting{background:beige;border-left-color:#8b4513}.activity.activity-seed-starting .activity-crop{color:#654321;font-weight:600;font-weight:var(--font-weight-semibold)}.activity.activity-indoor-starting.priority-high{background:#fdf5e6;border-left-color:#d2691e;box-shadow:0 2px 4px #d2691e26}.activity.activity-indoor-starting.priority-critical{background:#fff8dc;border-left-color:#b22222;box-shadow:0 2px 4px #b2222233}@media (max-width:768px){.activity.activity-indoor-starting{margin:4px 0;margin:var(--spacing-xs) 0;padding:8px;padding:var(--spacing-sm)}.activity.activity-indoor-starting .activity-crop{font-size:14px;font-size:var(--font-size-sm)}.activity.activity-indoor-starting .activity-action{font-size:12px;font-size:var(--font-size-xs);line-height:1.4}.activity.activity-indoor-starting .activity-timing{font-size:12px;font-size:var(--font-size-xs);margin-top:4px;margin-top:var(--spacing-xs)}}.activity-header{align-items:flex-start}.activity-header-left{align-items:center;display:flex;flex:1 1;gap:8px;gap:var(--spacing-sm);min-width:0;overflow:hidden}.activity-controls{flex-shrink:0}.activity-controls,.activity-tags{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs)}.activity-tags{flex-wrap:wrap}.activity-btn{align-items:center;background:none;border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:14px;font-size:var(--font-size-sm);height:28px;justify-content:center;min-width:28px;padding:4px 8px;transition:all .2s ease}.activity-btn:hover{box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.complete-btn{background:#d5f4e6;background:var(--color-success-light);border-color:#27ae60;border-color:var(--color-success);color:#1e8449;color:var(--color-success-dark)}.complete-btn:hover{background:#27ae60;background:var(--color-success);color:#fff;color:var(--color-background)}.dismiss-btn{background:#fadbd8;background:var(--color-error-light);border-color:#e74c3c;border-color:var(--color-error);color:#a93226;color:var(--color-error-dark)}.dismiss-btn:hover{background:#e74c3c;background:var(--color-error);color:#fff;color:var(--color-background)}.undo-btn{background:#d6eaf8;background:var(--color-info-light);border-color:#3498db;border-color:var(--color-info);color:#2471a3;color:var(--color-info-dark);font-size:12px;font-size:var(--font-size-xs)}.undo-btn:hover{background:#3498db;background:var(--color-info);color:#fff;color:var(--color-background)}.activity-completed,.completed-indicator{font-size:12px;font-size:var(--font-size-xs)}.completed-indicator{background:#d5f4e6;background:var(--color-success-light);border-radius:4px;color:#1e8449;color:var(--color-success-dark);font-weight:600;font-weight:var(--font-weight-semibold);padding:2px 6px}.next-due{color:#7f8c8d;color:var(--color-text-tertiary);font-style:italic}.activity-frequency{background:#e8f5e8;background:var(--color-primary-light);color:#229954;color:var(--color-primary-dark);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 4px;padding:2px var(--spacing-xs);text-transform:capitalize}.activity-consequences,.activity-frequency{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs)}.activity-consequences{background:#fdeaa7;background:var(--color-warning-light);border-left:3px solid #f39c12;border-left:3px solid var(--color-warning);color:#b7791f;color:var(--color-warning-dark);margin-top:4px;margin-top:var(--spacing-xs);padding:4px;padding:var(--spacing-xs)}.activity.state-completed{background:#d5f4e6;background:var(--color-success-light);border-left-color:#27ae60;border-left-color:var(--color-success);border-left-width:4px;box-shadow:0 1px 3px #28a74533;opacity:1}.activity.state-completed .activity-action{color:#1e8449;color:var(--color-success-dark);font-weight:500;font-weight:var(--font-weight-medium);text-decoration:line-through}.activity.state-pending.priority-critical,.activity.state-pending.priority-urgent{border-left-width:6px;box-shadow:0 2px 8px #dc354526}.activity.activity-urgent-task{background:#f8d7da;background:var(--color-urgent-light);border-left-color:#dc3545;border-left-color:var(--color-urgent);border-left-width:6px;box-shadow:0 2px 8px #dc354533}.activity.activity-urgent-task .activity-crop{color:#b02a37;color:var(--color-urgent-dark);font-weight:600;font-weight:var(--font-weight-semibold)}.activity.activity-urgent-task .activity-action{color:#b02a37;color:var(--color-urgent-dark);font-weight:500;font-weight:var(--font-weight-medium)}.activity-completed{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs)}@media (max-width:768px){.activity-header-row{align-items:stretch;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.activity-controls{justify-content:flex-end}.activity-btn{font-size:16px;font-size:var(--font-size-base);height:32px;min-width:32px}.activity-completed{flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.next-due{flex:1 0 100%}.activity-legend{gap:4px;gap:var(--spacing-xs);padding:4px;padding:var(--spacing-xs)}.legend-item{font-size:.65rem;padding:1px 4px;padding:1px var(--spacing-xs)}}.forecast-widget{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.forecast-header{margin-bottom:16px;margin-bottom:var(--spacing-md);text-align:center}.forecast-location{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin:0}.forecast-warning{background:#fdeaa7;background:var(--color-warning-light);border:1px solid #f39c12;border:1px solid var(--color-warning);border-radius:4px;border-radius:var(--radius-sm);color:#b7791f;color:var(--color-warning-dark);font-size:12px;font-size:var(--font-size-xs);margin-top:4px;margin-top:var(--spacing-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.forecast-error,.forecast-loading{padding:32px;padding:var(--spacing-xl);text-align:center}.forecast-error h3,.forecast-loading h3{color:#2c3e50;color:var(--color-text-primary);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.forecast-retry-btn{background:#27ae60;background:var(--color-primary);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:500;font-weight:var(--font-weight-medium);padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:background .2s ease}.forecast-retry-btn:hover{background:#229954;background:var(--color-primary-dark)}.forecast-alerts{margin-bottom:16px;margin-bottom:var(--spacing-md)}.forecast-alert{align-items:flex-start;border-left:4px solid;border-radius:8px;border-radius:var(--radius-md);display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs);padding:8px;padding:var(--spacing-sm)}.forecast-alert.alert-high{background:#fadbd8;background:var(--color-error-light);border-left-color:#e74c3c;border-left-color:var(--color-error)}.forecast-alert.alert-medium{background:#fdeaa7;background:var(--color-warning-light);border-left-color:#f39c12;border-left-color:var(--color-warning)}.forecast-alert.alert-low{background:#d6eaf8;background:var(--color-info-light);border-left-color:#3498db;border-left-color:var(--color-info)}.alert-days{font-weight:400}.alert-days,.alert-recommendation{color:#34495e;color:var(--color-text-secondary)}.alert-recommendation{font-size:14px;font-size:var(--font-size-sm);margin-top:4px;margin-top:var(--spacing-xs)}.forecast-summary{background:#f8f9fa;background:var(--color-background-light);border-radius:8px;border-radius:var(--radius-md);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.summary-stats{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stat-item{background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);padding:8px;padding:var(--spacing-sm);text-align:center;transition:all .2s ease}.stat-item:hover{border-color:#e8f5e8;border-color:var(--color-primary-light);transform:translateY(-1px)}.stat-label{font-weight:600;line-height:1.2}.stat-value{color:#2c3e50;color:var(--color-text-primary);line-height:1.1}.stat-value .metric-primary{color:#27ae60;color:var(--color-primary)}.stat-value .imperial-secondary{color:#34495e;color:var(--color-text-secondary);display:block;font-size:14px;font-size:var(--font-size-sm);font-weight:500;margin-top:2px}.stat-value.potential-excellent{color:#1e8449;color:var(--color-success-dark)}.stat-value.potential-good{color:#2471a3;color:var(--color-info-dark)}.stat-value.potential-fair{color:#b7791f;color:var(--color-warning-dark)}.stat-value.potential-poor{color:#a93226;color:var(--color-error-dark)}.forecast-days{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px;margin-bottom:var(--spacing-md)}.forecast-day{background:#fafbfc;background:var(--color-background-subtle);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--spacing-md);transition:all .2s ease}.forecast-day.today{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary);border-width:2px}.forecast-day.projected{background:#f8f9fa;background:var(--color-background-light);opacity:.8}.forecast-day:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.forecast-day.compact{align-items:center;display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs);min-height:0;min-height:auto;padding:8px;padding:var(--spacing-sm);text-align:center}.forecast-day.compact .day-header{flex-direction:column;gap:2px;margin-bottom:0}.forecast-day.compact .day-name{font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium)}.forecast-day.compact .day-date{font-size:10px}.day-weather-icon{font-size:1.5rem;line-height:1}.forecast-day.compact .day-temps{gap:4px;justify-content:center;margin:0}.forecast-day.compact .high-temp{font-size:14px;font-size:var(--font-size-sm);font-weight:600;font-weight:var(--font-weight-semibold)}.forecast-day.compact .low-temp{font-size:12px;font-size:var(--font-size-xs)}.day-conditions-compact{align-items:center;display:flex;flex-wrap:wrap;font-size:10px;gap:4px;justify-content:center;min-height:14px}.gdd-compact,.precip-compact{align-items:center;color:#34495e;color:var(--color-text-secondary);display:inline-flex;font-size:10px;gap:1px}.risk-indicator{font-size:12px;line-height:1}.day-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.day-name{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold)}.day-date{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.day-temps{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs);justify-content:center;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.high-temp{color:#2c3e50;color:var(--color-text-primary);font-size:20px;font-size:var(--font-size-xl);font-weight:700;font-weight:var(--font-weight-bold)}.temp-separator{color:#7f8c8d;color:var(--color-text-tertiary)}.low-temp,.temp-separator{font-size:18px;font-size:var(--font-size-lg)}.low-temp{color:#34495e;color:var(--color-text-secondary)}.feels-like{color:var(--color-accent);display:block;font-size:12px;font-size:var(--font-size-xs);font-weight:500;margin-left:4px;margin-left:var(--spacing-xs);margin-top:2px}.day-conditions{margin-bottom:8px;margin-bottom:var(--spacing-sm);text-align:center}.day-weather{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.day-precip{color:#2471a3;color:var(--color-info-dark);font-size:12px;font-size:var(--font-size-xs)}.day-garden-info{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs);justify-content:center;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.garden-indicator{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 4px;padding:2px var(--spacing-xs)}.garden-indicator.frost{background:#d6eaf8;background:var(--color-info-light);color:#2471a3;color:var(--color-info-dark)}.garden-indicator.heat{background:#fdeaa7;background:var(--color-warning-light);color:#b7791f;color:var(--color-warning-dark)}.garden-indicator.gdd{background:#d5f4e6;background:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.day-recommendations{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding-top:8px;padding-top:var(--spacing-sm)}.recommendation{color:#34495e;color:var(--color-text-secondary);font-size:12px;font-size:var(--font-size-xs);line-height:1.3;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.recommendation:last-child{margin-bottom:0}.forecast-actions{align-items:center;border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.forecast-refresh-btn,.forecast-toggle-btn{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.forecast-refresh-btn:hover,.forecast-toggle-btn:hover{background:#f0f4f1;background:var(--color-background-dark);border-color:#27ae60;border-color:var(--color-primary)}.forecast-refresh-btn:disabled{cursor:not-allowed;opacity:.5}.simulation-impact{background:#f8f9fa;background:var(--color-background-light);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--spacing-md)}.simulation-impact h4{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.impact-grid{grid-gap:8px;grid-gap:var(--spacing-sm);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);margin-bottom:16px;margin-bottom:var(--spacing-md)}.impact-stat{background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);padding:8px;padding:var(--spacing-sm);text-align:center}.impact-stat .impact-value{color:#27ae60;color:var(--color-primary);font-size:18px;font-size:var(--font-size-lg);font-weight:700;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.impact-stat .impact-label{color:#34495e;color:var(--color-text-secondary);font-size:12px;font-size:var(--font-size-xs);font-weight:500;letter-spacing:.5px;text-transform:uppercase}.impact-factors{grid-gap:8px;grid-gap:var(--spacing-sm);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.impact-item{align-items:center;display:flex;justify-content:space-between}.impact-label{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.impact-value{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold)}.risk-factors{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding-top:8px;padding-top:var(--spacing-sm)}.risk-header{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-weight:600;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.risk-tags{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.risk-factors strong{font-size:14px;font-size:var(--font-size-sm);margin-right:8px;margin-right:var(--spacing-sm)}.risk-tag{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 4px;padding:2px var(--spacing-xs)}.risk-tag.frost{background:#d6eaf8;background:var(--color-info-light);color:#2471a3;color:var(--color-info-dark)}.risk-tag.heat{background:#fdeaa7;background:var(--color-warning-light);color:#b7791f;color:var(--color-warning-dark)}.risk-tag.drought{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark)}.risk-tag.moisture{background:#e8f5e8;background:var(--color-primary-light);color:#229954;color:var(--color-primary-dark)}@media (max-width:768px){.forecast-days{grid-template-columns:1fr}.summary-stats{gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr)}.stat-item{padding:4px;padding:var(--spacing-xs)}.stat-value{font-size:18px;font-size:var(--font-size-lg)}.impact-factors{grid-template-columns:1fr}.forecast-actions{flex-direction:column;gap:8px;gap:var(--spacing-sm)}.forecast-refresh-btn,.forecast-toggle-btn{width:100%}}.settings-toggle{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);font-size:14px;font-size:var(--font-size-sm);padding:16px;padding:var(--spacing-md);transition:all .2s ease}.settings-toggle:hover:not(:disabled){background:#f0f4f1;background:var(--color-background-dark);border-color:#27ae60;border-color:var(--color-primary)}.settings-toggle:disabled{cursor:not-allowed}.settings-toggle.expanded{border-bottom-color:#27ae60;border-bottom-color:var(--color-primary);border-bottom-left-radius:0;border-bottom-right-radius:0}.settings-icon{font-size:16px;font-size:var(--font-size-base)}.settings-summary{align-items:flex-start}.current-selection{line-height:1.2}.toggle-hint{color:#34495e;color:var(--color-text-secondary)}.expand-arrow{font-size:12px;font-size:var(--font-size-xs)}.expand-arrow.up{transform:rotate(180deg)}.settings-content{background:#fff;background:var(--color-background);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:0 0 8px 8px;border-radius:0 0 var(--radius-md) var(--radius-md);border-top:none}.setting-group:last-of-type{margin-bottom:16px;margin-bottom:var(--spacing-md)}.setting-title{font-size:14px;font-size:var(--font-size-sm);margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.setting-row{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.setting-item.full-width{grid-column:1/-1}.setting-label{font-size:12px;font-size:var(--font-size-xs);letter-spacing:.5px;text-transform:uppercase}.setting-select{border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;padding:8px;padding:var(--spacing-sm);transition:border-color .2s ease}.setting-select:focus{box-shadow:0 0 0 2px #f8fff9;box-shadow:0 0 0 2px var(--color-primary-pale)}.setting-select:disabled{background:#f8f9fa;background:var(--color-background-light);opacity:.7}.portfolio-summary{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding-top:8px;padding-top:var(--spacing-sm)}.allocation-chip{white-space:nowrap}.settings-actions{align-items:center;gap:8px;gap:var(--spacing-sm);justify-content:space-between;padding-top:16px;padding-top:var(--spacing-md)}.settings-action-btn{transition:background .2s ease}.settings-advanced-btn{background:#0000;border:1px solid #e9ecef;border:1px solid var(--color-border);color:#34495e;color:var(--color-text-secondary);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.settings-advanced-btn:hover{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}@media (max-width:768px){.settings-summary{align-items:flex-start;flex-direction:column}.current-selection{font-size:14px;font-size:var(--font-size-sm)}.setting-row{gap:8px;gap:var(--spacing-sm);grid-template-columns:1fr}.setting-item.full-width{grid-column:1}.settings-actions{align-items:stretch;flex-direction:column}.settings-action-btn,.settings-advanced-btn{text-align:center;width:100%}.allocation-chips{justify-content:center}}.urgent-tasks-banner{animation:pulse-urgent 2s infinite;background:#f8d7da;background:var(--color-urgent-light);border:1px solid #dc3545;border:1px solid var(--color-urgent);border-radius:4px;border-radius:var(--radius-sm);color:#b02a37;color:var(--color-urgent-dark);font-weight:500;font-weight:var(--font-weight-medium);margin-top:8px;margin-top:var(--spacing-sm);padding:8px;padding:var(--spacing-sm);text-align:center}@keyframes pulse-urgent{0%,to{opacity:1}50%{opacity:.8}}.action-section,.shopping-list-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.action-section{border:1px solid #e9ecef;border:1px solid var(--color-border)}.action-section h3{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--color-border);font-size:20px;font-size:var(--font-size-xl);font-weight:600;font-weight:var(--font-weight-semibold);margin:0;padding:24px;padding:var(--spacing-lg)}.plant-now h3{background:#d5f4e6;background:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.buy-now h3{background:#fdeaa7;background:var(--color-warning-light);color:#b7791f;color:var(--color-warning-dark)}.succession h3{background:#d6eaf8;background:var(--color-info-light);color:#2471a3;color:var(--color-info-dark)}.prepare h3{background:#f8f9fa;background:var(--color-background-light);color:#34495e;color:var(--color-text-secondary)}.action-list{padding:16px;padding:var(--spacing-md)}.action-item{background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:24px;padding:var(--spacing-lg)}.action-item:last-child{margin-bottom:0}.action-item.urgency-urgent{background:#fadbd8;background:var(--color-error-light);border-left:4px solid #e74c3c;border-left:4px solid var(--color-error)}.action-item .item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md)}.action-item .crop-name{color:#2c3e50;color:var(--color-text-primary);font-size:18px;font-size:var(--font-size-lg);margin:0}.urgency-badge{border-radius:var(--radius-lg);font-size:12px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--spacing-xs) var(--spacing-sm)}.urgency-badge:contains("URGENT"){background:#e74c3c;background:var(--color-error);color:#fff;color:var(--color-background)}.prepare-timing,.succession-note{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic}.action-info{background:#fafbfc;background:var(--color-background-subtle);border-radius:4px;border-radius:var(--radius-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.action-info>div{margin-bottom:4px;margin-bottom:var(--spacing-xs)}.action-info>div:last-child{margin-bottom:0}.no-actions p{margin-bottom:16px;margin-bottom:var(--spacing-md)}.shopping-controls{grid-gap:24px;grid-gap:var(--spacing-lg);align-items:end;background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:1fr 1fr 1fr auto;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg)}@media (max-width:1024px){.shopping-controls{gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr}}@media (max-width:768px){.shopping-controls{align-items:stretch;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr}.garden-type-select,.planning-horizon-select,.season-select{min-width:100%}}.garden-type-selector,.planning-horizon-selector,.season-selector{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.garden-type-selector label,.planning-horizon-selector label,.season-selector label{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium)}.garden-type-select,.planning-horizon-select,.season-select{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#2c3e50;color:var(--color-text-primary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);min-width:180px;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.garden-type-select:hover,.planning-horizon-select:hover,.season-select:hover{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 0 0 2px #e8f5e8;box-shadow:0 0 0 2px var(--color-primary-light)}.garden-type-select:focus,.planning-horizon-select:focus,.season-select:focus{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 0 0 3px #e8f5e8;box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.details-toggle{align-items:center;color:#2c3e50;color:var(--color-text-primary);display:flex;font-weight:500;font-weight:var(--font-weight-medium);gap:8px;gap:var(--spacing-sm);-webkit-user-select:none;user-select:none;white-space:nowrap}.details-toggle input[type=checkbox]{background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;height:18px;margin:0;position:relative;width:18px}.details-toggle input[type=checkbox]:checked{background:#27ae60;background:var(--color-primary);border-color:#27ae60;border-color:var(--color-primary)}.details-toggle input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.details-toggle:hover input[type=checkbox]{border-color:#27ae60;border-color:var(--color-primary)}.shopping-summary{grid-gap:24px;grid-gap:var(--spacing-lg);background:#e8f5e8;background:var(--color-primary-light);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:32px;margin-bottom:var(--spacing-xl);padding:24px;padding:var(--spacing-lg)}.summary-stat strong{color:#2c3e50;color:var(--color-text-primary);display:block;font-size:14px;font-size:var(--font-size-sm);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.shopping-list,.upcoming-list{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg)}.shopping-item,.upcoming-item{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border-left:4px solid #27ae60;border:1px solid var(--color-border);border-left:4px solid var(--color-primary);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:32px;padding:var(--spacing-xl)}.shopping-item,.upcoming-item,.upcoming-needs{border-radius:8px;border-radius:var(--radius-md)}.upcoming-needs{background:#d6eaf8;background:var(--color-info-light);border-left:4px solid #3498db;border-left:4px solid var(--color-info);margin-top:32px;margin-top:var(--spacing-xl);padding:24px;padding:var(--spacing-lg)}.upcoming-needs h3{color:#2471a3;color:var(--color-info-dark);margin-bottom:24px;margin-bottom:var(--spacing-lg)}.upcoming-item{background:#fff;background:var(--color-background);border-left:4px solid #3498db;border-left:4px solid var(--color-info)}.purchase-timing{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);margin:16px 0;margin:var(--spacing-md) 0}.purchase-note,.succession-note{border-radius:4px;border-radius:var(--radius-sm);font-size:14px;font-size:var(--font-size-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.succession-note{background:#e8f5e8;background:var(--color-primary-light);color:#229954;color:var(--color-primary-dark)}.upcoming-timing{border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin-top:16px;margin-top:var(--spacing-md);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.no-upcoming,.upcoming-timing{background:#fafbfc;background:var(--color-background-subtle)}.no-upcoming{border-radius:8px;border-radius:var(--radius-md);color:#7f8c8d;color:var(--color-text-tertiary);margin-top:24px;margin-top:var(--spacing-lg);padding:24px;padding:var(--spacing-lg);text-align:center}.item-header{align-items:center;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.space-allocation{background:#2c3e50;background:var(--color-text-primary);border-radius:12px;border-radius:var(--radius-lg);color:#fff;color:var(--color-background);font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md)}.shopping-details{grid-gap:16px;grid-gap:var(--spacing-md);background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.shopping-details>div{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.current-season-tip{background:#e8f5e8;background:var(--color-primary-light);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);color:#2c3e50;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg);text-align:center}.recommendations-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.recommendations-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:24px;margin-top:var(--spacing-lg)}.recommendation-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border-left:4px solid #27ae60;border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.recommendation-card:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.recommendation-card h3{align-items:center;color:#2c3e50;color:var(--color-text-primary);display:flex;font-size:16px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.recommendation-icon{font-size:18px;font-size:var(--font-size-lg)}.recommendation-content{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.6;line-height:var(--line-height-relaxed)}.content-header{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);margin:16px 0 8px;margin:var(--spacing-md) 0 var(--spacing-sm) 0}.content-bullet{margin:4px 0;margin:var(--spacing-xs) 0;padding-left:16px;padding-left:var(--spacing-md);position:relative}.content-bullet:before{color:#27ae60;color:var(--color-primary);content:"•";font-weight:700;left:0;position:absolute}.recommendation-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.recommendation-item{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm)}.crop-item,.priority-item,.site-tip,.task-item{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.crop-item strong,.priority-item strong,.site-tip strong,.task-item strong{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold)}.amount,.reason,.timing{color:#7f8c8d;color:var(--color-text-tertiary);font-size:14px;font-size:var(--font-size-sm)}.urgency{border-radius:4px;border-radius:var(--radius-sm);display:inline-block;font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 8px;padding:2px var(--spacing-sm)}.urgency-high{background:#e74c3c;background:var(--color-error)}.urgency-high,.urgency-medium{color:#fff;color:var(--color-background)}.urgency-medium{background:#f39c12;background:var(--color-warning)}.urgency-low{background:#27ae60;background:var(--color-primary);color:#fff;color:var(--color-background)}.varieties{background:#f8fff9;background:var(--color-primary-pale);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);font-size:12px;font-size:var(--font-size-xs);margin-top:4px;margin-top:var(--spacing-xs);padding:8px;padding:var(--spacing-sm)}@media (max-width:768px){.App{padding:16px;padding:var(--spacing-md)}.header{padding:24px;padding:var(--spacing-lg)}.app-title{font-size:24px;font-size:var(--font-size-2xl)}.scenario-grid{gap:24px;gap:var(--spacing-lg)}.portfolio-grid,.scenario-grid{grid-template-columns:1fr}.results-grid{grid-template-columns:1fr 1fr}.calendar-grid,.recommendations-grid{grid-template-columns:1fr}.shopping-controls{align-items:stretch;flex-direction:column;gap:16px;gap:var(--spacing-md)}.shopping-details{grid-template-columns:1fr}.button{justify-content:center;width:100%}}@media (max-width:480px){.App{padding:8px;padding:var(--spacing-sm)}.card,.header,.portfolio-button,.scenario-button{padding:16px;padding:var(--spacing-md)}.results-grid{grid-template-columns:1fr}.summary-stat{text-align:left}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-sm{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:16px;margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.mt-0{margin-top:0}.mt-sm{margin-top:8px;margin-top:var(--spacing-sm)}.mt-md{margin-top:16px;margin-top:var(--spacing-md)}.mt-lg{margin-top:24px;margin-top:var(--spacing-lg)}.mt-xl{margin-top:32px;margin-top:var(--spacing-xl)}.hidden{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.font-bold{font-weight:700;font-weight:var(--font-weight-bold)}.font-semibold{font-weight:600;font-weight:var(--font-weight-semibold)}.font-medium{font-weight:500;font-weight:var(--font-weight-medium)}.text-primary{color:#2c3e50;color:var(--color-text-primary)}.text-secondary{color:#34495e;color:var(--color-text-secondary)}.text-tertiary{color:#7f8c8d;color:var(--color-text-tertiary)}.text-success{color:#27ae60;color:var(--color-success)}.text-warning{color:#f39c12;color:var(--color-warning)}.text-error{color:#e74c3c;color:var(--color-error)}.bg-primary{background-color:#27ae60;background-color:var(--color-primary)}.bg-primary-light{background-color:#e8f5e8;background-color:var(--color-primary-light)}.bg-white{background-color:#fff;background-color:var(--color-background)}.bg-light{background-color:#f8f9fa;background-color:var(--color-background-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.slide-in{animation:slideIn .3s ease-out}.button:focus,:focus,button:focus{outline:2px solid #27ae60;outline:2px solid var(--color-primary);outline-offset:2px}.loading{opacity:.6;pointer-events:none}.loading:after{animation:spin 1s linear infinite;border:2px solid #e9ecef;border-top-color:#27ae60;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);content:"";height:20px;left:50%;margin:-10px 0 0 -10px;position:absolute;top:50%;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.text-positive{color:#27ae60;color:var(--color-success)}.text-negative{color:#e74c3c;color:var(--color-error)}.text-neutral{color:#7f8c8d;color:var(--color-text-tertiary)}.bg-positive{background-color:#d5f4e6;background-color:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.bg-negative{background-color:#fadbd8;background-color:var(--color-error-light);color:#a93226;color:var(--color-error-dark)}.bg-warning{background-color:#fdeaa7;background-color:var(--color-warning-light);color:#b7791f;color:var(--color-warning-dark)}.border-positive{border-color:#27ae60;border-color:var(--color-success)}.border-negative{border-color:#e74c3c;border-color:var(--color-error)}.border-warning{border-color:#f39c12;border-color:var(--color-warning)}.value-display{font-size:18px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold)}.value-display.positive{color:#27ae60;color:var(--color-success)}.value-display.negative{color:#e74c3c;color:var(--color-error)}.value-display.zero{color:#7f8c8d;color:var(--color-text-tertiary)}.result-card.positive{background:linear-gradient(135deg,#fff,#d5f4e6);background:linear-gradient(135deg,var(--color-background) 0,var(--color-success-light) 100%);border-left:4px solid #27ae60;border-left:4px solid var(--color-success)}.result-card.negative{background:linear-gradient(135deg,#fff,#fadbd8);background:linear-gradient(135deg,var(--color-background) 0,var(--color-error-light) 100%);border-left:4px solid #e74c3c;border-left:4px solid var(--color-error)}.result-card.neutral{border-left:4px solid #dee2e6;border-left:4px solid var(--color-border-dark)}.metric-indicator{align-items:center;border-radius:4px;border-radius:var(--radius-sm);display:inline-flex;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);gap:4px;gap:var(--spacing-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.metric-indicator.positive{background:#d5f4e6;background:var(--color-success-light);color:#1e8449;color:var(--color-success-dark)}.metric-indicator.negative{background:#fadbd8;background:var(--color-error-light);color:#a93226;color:var(--color-error-dark)}.metric-indicator:before{content:"↗";font-size:16px;font-size:var(--font-size-base)}.metric-indicator.negative:before{content:"↘"}.chart-legend{background:#fafbfc;background:var(--color-background-subtle);border-radius:4px;border-radius:var(--radius-sm);display:flex;gap:24px;gap:var(--spacing-lg);justify-content:center;margin-top:16px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.legend-item{align-items:center;color:#34495e;color:var(--color-text-secondary);display:flex;font-size:14px;font-size:var(--font-size-sm);gap:4px;gap:var(--spacing-xs)}.legend-color{border-radius:4px;border-radius:var(--radius-sm);height:16px;width:16px}.legend-color.positive{background:#27ae60;background:var(--color-success)}.legend-color.negative{background:#e74c3c;background:var(--color-error)}.result-card.investment-analysis{overflow:hidden;position:relative}.result-card.investment-analysis:before{content:"💰";font-size:18px;font-size:var(--font-size-lg);opacity:.6;position:absolute;right:8px;right:var(--spacing-sm);top:8px;top:var(--spacing-sm)}.result-card.warning{background:linear-gradient(135deg,#fff,#fdeaa7);background:linear-gradient(135deg,var(--color-background) 0,var(--color-warning-light) 100%);border-left:4px solid #f39c12;border-left:4px solid var(--color-warning)}.text-warning{color:#b7791f;color:var(--color-warning-dark)}.investment-recommendations{background:#fafbfc;background:var(--color-background-subtle);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);margin-top:48px;margin-top:var(--spacing-2xl);padding:24px;padding:var(--spacing-lg)}.investment-recommendations h3{align-items:center;color:#2c3e50;color:var(--color-text-primary);display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:24px;margin-bottom:var(--spacing-lg)}.investment-breakdown{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.breakdown-header{align-items:center;border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.breakdown-header h4{color:#2c3e50;color:var(--color-text-primary);margin:0}.totals{display:flex;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);gap:24px;gap:var(--spacing-lg)}.actual-total{color:#27ae60;color:var(--color-primary)}.required-total{color:#34495e;color:var(--color-text-secondary)}.category-breakdown{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:16px;margin-top:var(--spacing-md)}.category-row{align-items:center;background:#fff;background:var(--color-background);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);display:flex;font-size:14px;font-size:var(--font-size-sm);justify-content:space-between;padding:8px;padding:var(--spacing-sm)}.category-name{color:#34495e;color:var(--color-text-secondary);text-transform:capitalize}.required-amount{color:#2c3e50;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium)}.recommendations-list{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.recommendations-list h4{color:#2c3e50;color:var(--color-text-primary);margin-bottom:16px;margin-bottom:var(--spacing-md)}.recommendation-item{background:#fff;background:var(--color-background);border-left:4px solid #e9ecef;border-left:4px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:16px;padding:var(--spacing-md)}.recommendation-item.excellent{background:#d5f4e6;background:var(--color-success-light);border-left-color:#27ae60;border-left-color:var(--color-success)}.recommendation-item.good{background:#e8f5e8;background:var(--color-primary-light);border-left-color:#27ae60;border-left-color:var(--color-primary)}.recommendation-item.caution{background:#fdeaa7;background:var(--color-warning-light);border-left-color:#f39c12;border-left-color:var(--color-warning)}.recommendation-item.warning{background:#fadbd8;background:var(--color-error-light);border-left-color:#e74c3c;border-left-color:var(--color-error)}.recommendation-text{line-height:1.6;line-height:var(--line-height-relaxed)}.critical-categories h4,.recommendation-text{color:#2c3e50;color:var(--color-text-primary)}.critical-categories h4,.critical-item{margin-bottom:16px;margin-bottom:var(--spacing-md)}.critical-item{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--spacing-md)}.critical-item.critical{background:#fadbd8;background:var(--color-error-light);border-left:4px solid #e74c3c;border-left:4px solid var(--color-error)}.critical-item.high{background:#fdeaa7;background:var(--color-warning-light);border-left:4px solid #f39c12;border-left:4px solid var(--color-warning)}.critical-item.medium{background:#d6eaf8;background:var(--color-info-light);border-left:4px solid #3498db;border-left:4px solid var(--color-info)}.critical-item.low{background:#f8f9fa;background:var(--color-background-light);border-left:4px solid #dee2e6;border-left:4px solid var(--color-border-dark)}.critical-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.critical-header strong{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold);text-transform:capitalize}.action-badge{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.action-badge.increase{background:#27ae60;background:var(--color-success);color:#fff;color:var(--color-background)}.action-badge.reduce{background:#f39c12;background:var(--color-warning);color:#fff;color:var(--color-background)}.critical-description{color:#34495e;color:var(--color-text-secondary);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.critical-amount,.critical-description{font-size:14px;font-size:var(--font-size-sm)}.critical-amount{color:#2c3e50;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium)}.loading-shimmer{background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);overflow:hidden;position:relative}.loading-shimmer:before{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#fff9,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}.shimmer-value{height:28px;height:var(--font-size-3xl);margin-bottom:8px;margin-bottom:var(--spacing-sm);width:60px}.shimmer-label,.shimmer-value{background:#f1f3f4;background:var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm)}.shimmer-label{height:14px;height:var(--font-size-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs);width:120px}.shimmer-confidence{height:12px;height:var(--font-size-xs);width:100px}.shimmer-confidence,.shimmer-text{background:#f1f3f4;background:var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm)}.shimmer-text{height:1em;min-width:80px}@keyframes shimmer{0%{left:-100%}to{left:100%}}.result-card .loading-shimmer{text-align:center}.result-card .loading-shimmer .shimmer-value{margin:0 auto 8px;margin:0 auto var(--spacing-sm) auto}.result-card .loading-shimmer .shimmer-label{margin:0 auto 4px;margin:0 auto var(--spacing-xs) auto}.result-card .loading-shimmer .shimmer-confidence{margin:0 auto}@media (max-width:768px){.breakdown-header{align-items:flex-start;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.totals{flex-direction:column;gap:4px;gap:var(--spacing-xs)}.category-breakdown{grid-template-columns:1fr}.critical-header{align-items:flex-start;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.results-grid{grid-template-columns:1fr}}.action-dashboard{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.action-dashboard .card-subtitle{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin-top:4px;margin-top:var(--spacing-xs)}.dashboard-controls{align-items:center;background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-top:24px;margin-top:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.view-controls{display:flex;gap:4px;gap:var(--spacing-xs)}.view-button{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);transition:all .2s ease}.view-button:hover{color:#27ae60;color:var(--color-primary)}.view-button.active,.view-button:hover{border-color:#27ae60;border-color:var(--color-primary)}.view-button.active{background:#27ae60;background:var(--color-primary);color:#fff;color:var(--color-background)}.quick-actions{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.quick-action-button{border:1px solid;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);transition:all .2s ease}.quick-action-button.urgent{background:#e74c3c;background:var(--color-error);border-color:#e74c3c;border-color:var(--color-error);color:#fff;color:var(--color-background)}.quick-action-button.urgent:hover{background:#a93226;background:var(--color-error-dark);border-color:#a93226;border-color:var(--color-error-dark)}.quick-action-button.secondary{background:#fff;background:var(--color-background);border-color:#e9ecef;border-color:var(--color-border);color:#34495e;color:var(--color-text-secondary)}.quick-action-button.secondary:hover{border-color:#34495e;border-color:var(--color-text-secondary);color:#2c3e50;color:var(--color-text-primary)}.filter-toggle{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);transition:all .2s ease}.filter-toggle.active,.filter-toggle:hover{border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.filter-toggle.active{background:#e8f5e8;background:var(--color-primary-light)}.filter-controls{grid-gap:16px;grid-gap:var(--spacing-md);background:#fafbfc;background:var(--color-background-subtle);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:16px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.filter-group{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.filter-group label{color:#34495e;color:var(--color-text-secondary);font-weight:500;font-weight:var(--font-weight-medium)}.filter-group label,.filter-group select{font-size:14px;font-size:var(--font-size-sm)}.filter-group select{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#2c3e50;color:var(--color-text-primary);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.filter-group select:focus{border-color:#27ae60;border-color:var(--color-primary);outline:none}.action-sections{display:flex;flex-direction:column;gap:48px;gap:var(--spacing-2xl);margin-top:24px;margin-top:var(--spacing-lg)}.action-section{border-radius:12px;border-radius:var(--radius-lg);overflow:hidden}.urgent-section{background:linear-gradient(135deg,#fadbd8,#fff 50%);background:linear-gradient(135deg,var(--color-error-light) 0,var(--color-background) 50%);border:2px solid #e74c3c;border:2px solid var(--color-error)}.month-section{background:linear-gradient(135deg,#e8f5e8,#fff 50%);background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-background) 50%);border:2px solid #27ae60;border:2px solid var(--color-primary)}.planning-section{background:linear-gradient(135deg,#d6eaf8,#fff 50%);background:linear-gradient(135deg,var(--color-info-light) 0,var(--color-background) 50%);border:2px solid #3498db;border:2px solid var(--color-info)}.section-header{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffc;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:24px;padding:var(--spacing-lg)}.section-title{font-size:20px;font-size:var(--font-size-xl);margin:0}.action-count{background:#2c3e50;background:var(--color-text-primary);border-radius:12px;border-radius:var(--radius-lg);color:#fff;color:var(--color-background);font-size:14px;font-size:var(--font-size-sm);font-weight:700;font-weight:var(--font-weight-bold);min-width:24px;padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);text-align:center}.no-actions{color:#7f8c8d;color:var(--color-text-tertiary);font-style:italic;padding:48px;padding:var(--spacing-2xl);text-align:center}.action-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.action-card,.action-grid{padding:24px;padding:var(--spacing-lg)}.action-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);overflow:hidden;position:relative;transition:all .2s ease}.action-card:before{background:#e9ecef;background:var(--color-border);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.action-card.urgent:before{background:#e74c3c;background:var(--color-error)}.action-card.month:before{background:#27ae60;background:var(--color-primary)}.action-card.planning:before{background:#3498db;background:var(--color-info)}.action-card:hover{box-shadow:0 4px 16px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.action-card.compact-mode{min-height:auto;padding:16px;padding:var(--spacing-md)}.action-card.compact-mode .action-header{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.action-card.compact-mode .action-title{font-size:14px;font-size:var(--font-size-sm);line-height:1.5;line-height:var(--line-height-normal)}.action-card.compact-mode .action-badges{flex-direction:row;gap:4px;gap:var(--spacing-xs)}.action-card.compact-mode .effort-badge,.action-card.compact-mode .impact-badge{font-size:10px;padding:1px 4px;padding:1px var(--spacing-xs)}.action-card.compact-mode .action-footer{margin-top:8px;margin-top:var(--spacing-sm)}.action-card.compact-mode .action-meta{align-items:center;flex-direction:row;gap:8px;gap:var(--spacing-sm)}.details-toggle.compact{align-items:center;background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:50%;color:#34495e;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:14px;font-size:var(--font-size-sm);font-weight:700;font-weight:var(--font-weight-bold);height:24px;justify-content:center;position:absolute;right:8px;right:var(--spacing-sm);top:8px;top:var(--spacing-sm);transition:all .2s ease;width:24px}.details-toggle.compact:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.action-header{gap:16px;gap:var(--spacing-md);justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md)}.action-header,.action-title-row{align-items:flex-start;display:flex}.action-title-row{flex:1 1;gap:8px;gap:var(--spacing-sm)}.completion-checkbox{align-items:center;background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#27ae60;color:var(--color-success);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-size:var(--font-size-sm);font-weight:700;font-weight:var(--font-weight-bold);height:20px;justify-content:center;margin-top:2px;transition:all .2s ease;width:20px}.completion-checkbox:hover{background:#d5f4e6;background:var(--color-success-light);border-color:#27ae60;border-color:var(--color-success)}.completion-checkbox.checked{background:#27ae60;background:var(--color-success);border-color:#27ae60;border-color:var(--color-success);color:#fff;color:var(--color-background)}.action-card.completed{background:#fafbfc;background:var(--color-background-subtle);opacity:.7}.completed-text{color:#7f8c8d;color:var(--color-text-tertiary);text-decoration:line-through}.action-title{color:#2c3e50;color:var(--color-text-primary);flex:1 1;font-size:16px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2;line-height:var(--line-height-tight);margin:0}.action-badges{align-items:flex-end;display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.effort-badge,.impact-badge{border-radius:4px;border-radius:var(--radius-sm);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 4px;padding:2px var(--spacing-xs);text-transform:uppercase;white-space:nowrap}.impact-badge.impact-high{background:#e74c3c;background:var(--color-error);color:#fff;color:var(--color-background)}.impact-badge.impact-medium{background:#f39c12;background:var(--color-warning);color:#fff;color:var(--color-background)}.impact-badge.impact-low{background:#27ae60;background:var(--color-success);color:#fff;color:var(--color-background)}.effort-badge.effort-high{background:#2c3e50;background:var(--color-text-primary);color:#fff;color:var(--color-background)}.effort-badge.effort-medium{background:#34495e;background:var(--color-text-secondary);color:#fff;color:var(--color-background)}.effort-badge.effort-low{background:#7f8c8d;background:var(--color-text-tertiary);color:#fff;color:var(--color-background)}.action-description{color:#34495e;color:var(--color-text-secondary);flex:1 1;font-size:14px;font-size:var(--font-size-sm);line-height:1.6;line-height:var(--line-height-relaxed);margin:0 0 24px;margin:0 0 var(--spacing-lg) 0}.action-footer{align-items:center;display:flex;gap:16px;gap:var(--spacing-md);justify-content:space-between;margin-top:auto}.action-meta{display:flex;flex:1 1;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.action-timeframe{color:#2c3e50;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium)}.action-category,.action-timeframe{font-size:12px;font-size:var(--font-size-xs)}.action-category{color:#7f8c8d;color:var(--color-text-tertiary);text-transform:uppercase}.action-button{background:#27ae60;background:var(--color-primary);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;color:var(--color-background);font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.action-button:hover{background:#229954;background:var(--color-primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-button:active{transform:translateY(0)}.more-actions{align-items:center;display:flex;justify-content:center;padding:24px;padding:var(--spacing-lg)}.show-more-btn{background:#0000;border:2px dashed #e9ecef;border:2px dashed var(--color-border);border-radius:8px;border-radius:var(--radius-md);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg);transition:all .2s ease}.show-more-btn:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.details-toggle{background:#0000;border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);margin:8px 0;margin:var(--spacing-sm) 0;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease;width:100%}.details-toggle:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.action-details{background:#f8f9fa;background:var(--color-background-light);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);margin-top:16px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.action-details h5{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm);font-weight:600;font-weight:var(--font-weight-semibold);margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.items-list{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs);margin-bottom:16px;margin-bottom:var(--spacing-md)}.item-row{align-items:center;background:#fff;background:var(--color-background);border-left:3px solid #e9ecef;border-left:3px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:8px;padding:var(--spacing-sm)}.item-row.urgent-item{background:#fadbd8;background:var(--color-error-light);border-left-color:#e74c3c;border-left-color:var(--color-error)}.item-info{display:flex;flex-direction:column;gap:2px}.item-info strong{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm)}.item-source{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs)}.item-price{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium)}.vendors-list{gap:4px;gap:var(--spacing-xs)}.vendor-row,.vendors-list{display:flex;flex-direction:column}.vendor-row{background:#fff;background:var(--color-background);border-radius:4px;border-radius:var(--radius-sm);gap:2px;padding:8px;padding:var(--spacing-sm)}.vendor-row strong{color:#2c3e50;color:var(--color-text-primary);font-size:14px;font-size:var(--font-size-sm)}.vendor-note{color:#34495e;color:var(--color-text-secondary);font-size:12px;font-size:var(--font-size-xs)}.instruction-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.instruction-item{background:#fff;background:var(--color-background);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);padding:16px;padding:var(--spacing-md)}.instruction-item strong{color:#2c3e50;color:var(--color-text-primary);display:block;font-size:14px;font-size:var(--font-size-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.instruction-item p{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.6;line-height:var(--line-height-relaxed);margin:0 0 4px;margin:0 0 var(--spacing-xs) 0}.timing-note{align-items:center;color:#27ae60;color:var(--color-primary);display:inline-flex;font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);gap:4px;gap:var(--spacing-xs)}.detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md)}.detail-header h5{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);margin:0}.expert-toggle{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:12px;font-size:var(--font-size-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.expert-toggle.active,.expert-toggle:hover{border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.expert-toggle.active{background:#e8f5e8;background:var(--color-primary-light)}.expert-details{background:#fafbfc;background:var(--color-background-subtle);border-left:3px solid #27ae60;border-left:3px solid var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);margin-top:8px;margin-top:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.expert-label{color:#27ae60;color:var(--color-primary);display:block;font-size:12px;font-size:var(--font-size-xs);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.expert-text{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic;line-height:1.6;line-height:var(--line-height-relaxed);margin:0}@media (max-width:768px){.dashboard-controls{align-items:stretch;flex-direction:column;gap:16px;gap:var(--spacing-md)}.quick-actions,.view-controls{justify-content:center}.quick-actions{flex-wrap:wrap}.action-grid,.filter-controls{grid-template-columns:1fr}.action-grid{padding:16px;padding:var(--spacing-md)}.action-header{align-items:flex-start;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.action-badges{align-items:center;flex-direction:row}.section-header{padding:16px;padding:var(--spacing-md)}.section-title{font-size:18px;font-size:var(--font-size-lg)}.action-footer{align-items:stretch;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.action-button{text-align:center;width:100%}}.actionable-recommendations{display:flex;flex-direction:column;gap:1rem}.actionable-recommendations .recommendation-item{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;transition:all .2s ease}.actionable-recommendations .recommendation-item.accepted{background:#f1f8e9;border-color:#4caf50}.actionable-recommendations .recommendation-item.rejected{background:#f5f5f5;border-color:#ccc;opacity:.7}.recommendation-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.item-info{flex:1 1}.item-name{font-size:.9rem;font-weight:500;margin:0 0 .25rem}.item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.price{color:#27ae60;font-size:1.1rem;font-weight:600}.urgency{border-radius:12px;font-size:.75rem;font-weight:600;padding:.2rem .5rem;text-transform:uppercase}.urgency-high{background:#ffebee;color:#c62828}.urgency-medium{background:#fff3e0;color:#ef6c00}.urgency-low{background:#e8f5e8;color:#2e7d32}.category{background:#e3f2fd;border-radius:4px;color:#1565c0;font-size:.75rem;font-weight:500;padding:.2rem .5rem}.action-buttons{display:flex;flex-shrink:0;gap:.125rem;opacity:.6;transition:opacity .2s ease}.recommendation-item:hover .action-buttons{opacity:.9}.accept-btn,.reject-btn{border:1px solid #0000;border-radius:3px;cursor:pointer;font-size:.7rem;font-weight:400;min-width:40px;opacity:.8;padding:.125rem .375rem;text-align:center;transition:all .15s ease}.accept-btn{background:#f8fff9;border:1px solid #e8f5e8;color:#4a9e5a}.accept-btn:hover:not(:disabled){background:#e8f5e8;border-color:#4a9e5a;opacity:1}.accept-btn.active{background:#27ae60;color:#fff;opacity:1}.accept-btn:disabled{cursor:default;opacity:.5}.reject-btn{background:#fafafa;border:1px solid #e9ecef;color:#8a9ba8}.reject-btn:hover:not(:disabled){background:#f0f0f0;border-color:#8a9ba8;opacity:1}.reject-btn.active{background:#e9ecef;color:#7f8c8d;opacity:1}.reject-btn:disabled{cursor:default;opacity:.5}.recommendation-details{display:flex;flex-direction:column;font-size:.9rem;gap:.5rem}.specs-section,.timing-section,.where-section,.why-section{line-height:1.4}.specs-section strong,.timing-section strong,.where-section strong,.why-section strong{color:#2c3e50;margin-right:.5rem}.accepted-summary{background:#e8f5e8;border:1px solid #4caf50;border-radius:8px;margin-top:1rem;padding:1rem}.accepted-summary h4{color:#2e7d32;margin:0 0 .5rem}.total-cost{color:#1b5e20;font-size:1.1rem;font-weight:600}@media (max-width:768px){.recommendation-header{flex-direction:column;gap:.75rem}.action-buttons{align-self:stretch}.accept-btn,.reject-btn{flex:1 1}.item-meta{gap:.5rem}}.App{display:flex;flex-direction:column;min-height:100vh}.App,.header{background:#fff;background:var(--color-background)}.header{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--color-border);padding:16px 0;padding:var(--spacing-md) 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{margin:0 auto;max-width:1200px;padding:0 24px;padding:0 var(--spacing-lg)}.header-main{text-align:center}.app-title{color:#2c3e50;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin:0}.app-subtitle{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin:.25rem 0 0}.navigation{background:#fff;background:var(--color-background);border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:center;overflow-x:auto;padding:8px 0;padding:var(--spacing-sm) 0}.nav-items{max-width:1200px;padding:0 24px;padding:0 var(--spacing-lg)}.nav-item,.nav-items{display:flex;gap:4px;gap:var(--spacing-xs)}.nav-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:.9rem;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);position:relative;transition:all .2s ease;white-space:nowrap}.nav-item:hover{background:#f8f9fa;background:var(--color-background-light);border-color:#e9ecef;border-color:var(--color-border);color:#2c3e50;color:var(--color-text-primary)}.nav-item.active{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary);color:#229954;color:var(--color-primary-dark)}.nav-item .nav-icon{font-size:1rem}.nav-badge{align-items:center;background:#e74c3c;background:var(--color-error);border-radius:50%;color:#fff;display:flex;font-size:.7rem;font-weight:600;height:16px;justify-content:center;position:absolute;right:-2px;top:-2px;width:16px}.nav-badge.new{background:#f39c12;background:var(--color-warning)}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:24px;padding:var(--spacing-lg);width:100%}.view-header{margin-bottom:32px;margin-bottom:var(--spacing-xl);text-align:center}.view-header h2{color:#2c3e50;color:var(--color-text-primary);font-size:1.8rem;font-weight:600;margin:0 0 8px;margin:0 0 var(--spacing-sm) 0}.view-subtitle{color:#34495e;color:var(--color-text-secondary);font-size:1rem;margin:0}.dashboard-view{display:flex;flex-direction:column;gap:24px;gap:var(--spacing-lg)}.dashboard-header{margin-bottom:24px;margin-bottom:var(--spacing-lg);text-align:center}.current-date{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin:8px 0 0;margin:var(--spacing-sm) 0 0 0}.priority-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.focus-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border-left:4px solid #27ae60;border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.focus-card h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.focus-content{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.focus-header{color:#2c3e50;color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0}.focus-bullet{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;padding-left:16px;padding-left:var(--spacing-md);position:relative}.focus-bullet:before{color:#27ae60;color:var(--color-primary);content:"•";left:0;position:absolute}.urgent-section{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border-left:4px solid #e74c3c;border:1px solid var(--color-border);border-left:4px solid var(--color-error);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.urgent-section h3{color:#a93226;color:var(--color-error-dark);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.quick-actions-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.quick-actions-card h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.quick-actions-grid{grid-gap:8px;grid-gap:var(--spacing-sm);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.quick-action{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;padding:8px;padding:var(--spacing-sm);transition:all .2s ease}.quick-action:hover{background:#f8fff9;background:var(--color-primary-pale);border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.status-summary{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.status-summary h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.status-items{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.status-item{align-items:center;display:flex;justify-content:space-between}.status-label{color:#34495e;color:var(--color-text-secondary);font-size:.9rem}.status-value{color:#2c3e50;color:var(--color-text-primary);font-weight:600}.shopping-view,.tasks-view{display:flex;flex-direction:column;gap:24px;gap:var(--spacing-lg)}.planned-shopping-section,.upcoming-tasks-section,.urgent-shopping-section,.urgent-tasks-section{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.urgent-shopping-section h3,.urgent-tasks-section h3{color:#a93226;color:var(--color-error-dark);font-size:1.2rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.planned-shopping-section h3,.upcoming-tasks-section h3{color:#2c3e50;color:var(--color-text-primary);font-size:1.2rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.section-description{font-size:.9rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.no-shopping,.no-tasks,.section-description{color:#34495e;color:var(--color-text-secondary)}.no-shopping,.no-tasks{padding:32px;padding:var(--spacing-xl);text-align:center}.shopping-help,.tasks-help{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);margin-top:24px;margin-top:var(--spacing-lg);padding:24px;padding:var(--spacing-lg)}.shopping-help h4,.tasks-help h4{color:#2c3e50;color:var(--color-text-primary);font-size:1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.shopping-help ul,.tasks-help ul{margin:0;padding-left:24px;padding-left:var(--spacing-lg)}.shopping-help li,.tasks-help li{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.config-view,.results-view{display:flex;flex-direction:column;gap:24px;gap:var(--spacing-lg)}@media (max-width:768px){.main-content{padding:16px;padding:var(--spacing-md)}.nav-items{padding:0 16px;padding:0 var(--spacing-md)}.nav-item{font-size:.8rem;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.priority-grid,.quick-actions-grid{grid-template-columns:1fr}.status-items{gap:4px;gap:var(--spacing-xs)}}.category-tag{align-items:center;background:#e9ecef;background:var(--color-border);border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;gap:var(--spacing-xs);padding:2px 6px}.category-fertilization{border-left:3px solid #4caf50}.category-mulching{border-left:3px solid #8d6e63}.category-watering{border-left:3px solid #2196f3}.category-pest_control{border-left:3px solid #ff9800}.category-protection{border-left:3px solid #9c27b0}.category-soil{border-left:3px solid #795548}.category-equipment{border-left:3px solid #607d8b}.category-planning{border-left:3px solid #3f51b5}.category-seeding{border-left:3px solid #8bc34a}.category-pruning{border-left:3px solid #f44336}.category-cultivation{border-left:3px solid #cddc39}.category-maintenance{border-left:3px solid #9e9e9e}.category-harvesting{border-left:3px solid #ff5722}.category-monitoring{border-left:3px solid #00bcd4}.task-item.priority-critical{background:#d32f2f0d;border-left:4px solid #d32f2f}.priority-badge.priority-critical{background:#d32f2f;color:#fff;font-weight:600}.activity-icon{font-size:.9rem;margin-right:4px;margin-right:var(--spacing-xs)}.activity-priority.priority-critical{background:#d32f2f}.activity-priority.priority-critical,.activity-priority.priority-high{border-radius:8px;color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px}.activity-priority.priority-high{background:#f57c00}.activity.activity-maintenance{background:#607d8b0d;border-left:3px solid #607d8b}.activity.priority-critical{background:#d32f2f14;border-left:4px solid #d32f2f;box-shadow:0 2px 4px #d32f2f1a}.activity-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.activity-crop{flex:1 1;font-weight:600}.view-mode-toggle{display:flex;gap:8px;gap:var(--spacing-sm);margin-top:16px;margin-top:var(--spacing-md)}.mode-button{background:#fff;background:var(--color-background);border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:var(--border-radius);color:#34495e;color:var(--color-text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.mode-button:hover{color:#27ae60;color:var(--color-primary)}.mode-button.active,.mode-button:hover{border-color:#27ae60;border-color:var(--color-primary)}.mode-button.active{background:#27ae60;background:var(--color-primary);color:#fff;font-weight:600}.annual-summary{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.annual-summary .summary-stats{display:flex;gap:24px;gap:var(--spacing-lg);margin-top:16px;margin-top:var(--spacing-md)}.stat{align-items:center;display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.stat strong{color:#27ae60;color:var(--color-primary);font-size:1.5rem}.stat span{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem;letter-spacing:.5px;text-transform:uppercase}.purchase-windows-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:24px;margin-bottom:var(--spacing-lg)}.purchase-window-panel{cursor:pointer}.purchase-window-panel.status-active{background:#4caf500d;border-left:4px solid #27ae60;border-left:4px solid var(--color-success)}.purchase-window-panel.status-upcoming{background:#2196f30d;border-left:4px solid #3498db;border-left:4px solid var(--color-info)}.window-info{flex:1 1}.window-name{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;margin:0}.window-timing{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin-top:4px;margin-top:var(--spacing-xs)}.window-stats{align-items:flex-end;display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.window-cost{color:#27ae60;color:var(--color-primary);font-size:1.2rem;font-weight:600}.window-count{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem}.status-indicator{border-radius:8px;font-size:.7rem;font-weight:600;padding:2px 6px}.status-indicator.status-active{background:#27ae60;background:var(--color-success);color:#fff}.status-indicator.status-upcoming{background:#3498db;background:var(--color-info);color:#fff}.window-description{background:var(--color-background-secondary);border-radius:var(--border-radius);color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin-top:8px;margin-top:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.window-items{border-top:1px solid #e9ecef;border-top:1px solid var(--color-border);margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.window-item{align-items:flex-start;background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:var(--border-radius);display:flex;justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.window-item:last-child{margin-bottom:0}.vendor-groups-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:24px;margin-bottom:var(--spacing-lg)}.vendor-group-panel{cursor:pointer}.vendor-info{flex:1 1}.vendor-name{color:#2c3e50;color:var(--color-text-primary);font-size:1.1rem;margin:0}.vendor-notes{color:#34495e;color:var(--color-text-secondary);font-size:.9rem;margin-top:4px;margin-top:var(--spacing-xs)}.vendor-stats{align-items:flex-end;display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.vendor-cost{color:#27ae60;color:var(--color-primary);font-size:1.2rem;font-weight:600}.vendor-count{color:#7f8c8d;color:var(--color-text-tertiary);font-size:.8rem}.shipping-info{border-radius:var(--border-radius);font-size:.9rem;font-weight:500;margin-top:8px;margin-top:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.shipping-info.free{background:#4caf501a;color:#27ae60;color:var(--color-success)}.shipping-info.paid{background:#ff98001a;color:#f39c12;color:var(--color-warning)}.vendor-actions{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--color-border);margin:16px 0;margin:var(--spacing-md) 0;padding-bottom:16px;padding-bottom:var(--spacing-md)}.bulk-add-button{background:#27ae60;background:var(--color-primary);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:background .2s ease}.bulk-add-button:hover{background:#229954;background:var(--color-primary-dark)}.plan-progress{margin-top:16px;margin-top:var(--spacing-md)}.progress-stats{display:flex;gap:16px;gap:var(--spacing-md);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.progress-stats .stat{font-size:.9rem;font-weight:500}.progress-stats .stat.owned{color:#27ae60;color:var(--color-success)}.progress-stats .stat.added{color:#3498db;color:var(--color-info)}.progress-stats .stat.needed{color:#f39c12;color:var(--color-warning)}.progress-bar{background:#e9ecef;background:var(--color-border);border-radius:3px;height:6px;overflow:hidden;position:relative}.progress-owned{background:#27ae60;background:var(--color-success);height:100%;position:absolute;transition:width .3s ease}.progress-added{background:#3498db;background:var(--color-info);height:100%;position:absolute;transition:width .3s ease,left .3s ease}.plan-filters{align-items:center;border-top:1px solid #e9ecef;border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-md);margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.category-filter select{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.needed-filter label{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:4px;gap:var(--spacing-xs)}.add-all-needed-button{background:#27ae60;background:var(--color-success);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:background .2s ease}.add-all-needed-button:hover{background:#218838}.items-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.plan-item{position:relative}.plan-item.added{background:#2196f30d;border-left:4px solid #3498db;border-left:4px solid var(--color-info)}.plan-item.owned{background:#4caf500d;border-left:4px solid #27ae60;border-left:4px solid var(--color-success)}.item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.item-name{color:#2c3e50;color:var(--color-text-primary);font-weight:600}.variety-info{font-size:.9rem;font-weight:400}.item-category,.variety-info{color:#34495e;color:var(--color-text-secondary)}.item-category{background:#e9ecef;background:var(--color-border);border-radius:8px;font-size:.7rem;font-weight:500;padding:2px 6px}.item-details{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.detail-row{display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.detail-label{color:#34495e;color:var(--color-text-secondary)}.detail-value{color:#2c3e50;color:var(--color-text-primary);font-weight:500}.item-notes{background:var(--color-background-secondary);border-radius:var(--border-radius);color:#34495e;color:var(--color-text-secondary);font-size:.9rem;padding:8px;padding:var(--spacing-sm)}.item-notes,.item-timing{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.item-timing{display:flex;font-size:.8rem;justify-content:space-between}.timing-label{color:#34495e;color:var(--color-text-secondary)}.timing-value{color:#27ae60;color:var(--color-primary);font-weight:500}.item-actions{display:flex;gap:8px;gap:var(--spacing-sm)}.action-button{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:var(--border-radius);color:#34495e;color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:.8rem;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.action-button:hover:not(:disabled){border-color:#27ae60;border-color:var(--color-primary);color:#27ae60;color:var(--color-primary)}.action-button:disabled{cursor:not-allowed;opacity:.6}.add-button:hover:not(:disabled){background:#3498db;background:var(--color-info);border-color:#3498db;border-color:var(--color-info);color:#fff}.owned-button:hover:not(:disabled){background:#27ae60;background:var(--color-success);border-color:#27ae60;border-color:var(--color-success);color:#fff}.expand-button{background:none;border:none;color:#7f8c8d;color:var(--color-text-tertiary);cursor:pointer;padding:4px;padding:var(--spacing-xs);transition:color .2s ease}.expand-button:hover{color:#2c3e50;color:var(--color-text-primary)}.specific-ordering-instructions{border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:4px;border-radius:var(--radius-sm);margin-top:16px;margin-top:var(--spacing-md);overflow:hidden}.instructions-toggle{background:#f8f9fa;background:var(--color-background-light);border:none;color:#27ae60;color:var(--color-primary);cursor:pointer;font-weight:500;list-style:none;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);text-align:left;width:100%}.instructions-toggle:hover{background:#e8f5e8;background:var(--color-primary-light)}.instructions-toggle::-webkit-details-marker{display:none}.instructions-content{background:#fff;background:var(--color-background);border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding:16px;padding:var(--spacing-md)}.instructions-content pre{color:#2c3e50;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:.9rem;line-height:1.6;margin:0;white-space:pre-wrap}.vendor-link{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.vendor-link a{color:#27ae60;color:var(--color-primary);font-weight:500;text-decoration:none}.vendor-link a:hover{text-decoration:underline}.ordering-timeline-guide{margin:32px 0;margin:var(--spacing-xl) 0}.ordering-timeline-guide h4{color:#27ae60;color:var(--color-primary);font-size:1.3rem;margin:0 0 24px;margin:0 0 var(--spacing-lg) 0}.timeline-months{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:32px;margin-bottom:var(--spacing-xl)}.timeline-month{background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.timeline-month h5{border-bottom:2px solid #e8f5e8;border-bottom:2px solid var(--color-primary-light);color:#229954;color:var(--color-primary-dark);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0;padding-bottom:4px;padding-bottom:var(--spacing-xs)}.timeline-month ul{list-style:disc;margin:0;padding-left:24px;padding-left:var(--spacing-lg)}.timeline-month li{line-height:1.5;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.timeline-key-tips{background:#f8fff9;background:var(--color-primary-pale);border:1px solid #e8f5e8;border:1px solid var(--color-primary-light);border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.timeline-key-tips h5{color:#229954;color:var(--color-primary-dark);font-size:1.1rem;margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.timeline-key-tips ul{list-style:disc;margin:0;padding-left:24px;padding-left:var(--spacing-lg)}.timeline-key-tips li{line-height:1.5;margin-bottom:8px;margin-bottom:var(--spacing-sm)}@media (max-width:768px){.items-grid,.purchase-windows-grid,.vendor-groups-grid{grid-template-columns:1fr}.annual-summary .summary-stats{flex-direction:column;gap:8px;gap:var(--spacing-sm)}.plan-filters{align-items:stretch;flex-direction:column}}.critical-alerts{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.alert{align-items:flex-start;border-left:4px solid;display:flex;gap:16px;gap:var(--spacing-md)}.alert-high{background:#fff3cd;border-color:#f39c12;border-color:var(--color-warning);color:#856404}.alert-medium{background:#d1ecf1;border-color:#3498db;border-color:var(--color-info);color:#0c5460}.alert-icon{flex-shrink:0;font-size:1.2em}.alert-content{flex:1 1}.alert-action{color:#2c3e50;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium);margin-top:4px;margin-top:var(--spacing-xs)}.dashboard-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-top:24px;margin-top:var(--spacing-lg)}.critical-timing .timing-window{background:#f8f9fa;background:var(--color-background-light);border-left:4px solid #e74c3c;border-left:4px solid var(--color-error);border-radius:8px;border-radius:var(--radius-md);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.timing-header{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.timing-icon{font-size:1.1em}.days-left{background:#e74c3c;background:var(--color-error);border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);margin-left:auto;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.timing-message{color:#34495e;color:var(--color-text-secondary);margin:8px 0;margin:var(--spacing-sm) 0}.timing-action{color:#27ae60;color:var(--color-success);font-weight:500;font-weight:var(--font-weight-medium)}.harvest-ready .harvest-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.harvest-item{background:#f8fff9;background:var(--color-primary-pale);border-left:4px solid #27ae60;border-left:4px solid var(--color-success);border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--spacing-md)}.harvest-main{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.harvest-value{color:#27ae60;color:var(--color-success);font-weight:500;font-weight:var(--font-weight-medium);margin-left:auto}.variety{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.harvest-now{background:#e74c3c;background:var(--color-error)}.harvest-now,.harvest-soon{border-radius:4px;border-radius:var(--radius-sm);color:#fff;display:inline-block;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);margin-bottom:4px;margin-bottom:var(--spacing-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.harvest-soon{background:#3498db;background:var(--color-info)}.harvest-note{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic}.investment-performance .performance-stats{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.stat-item{align-items:center;border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:8px 0;padding:var(--spacing-sm) 0}.stat-item:last-child{border-bottom:none}.stat-label{font-size:14px;font-size:var(--font-size-sm)}.stat-value{font-size:16px;font-size:var(--font-size-base);font-weight:500;font-weight:var(--font-weight-medium)}.stat-value.positive{color:#27ae60;color:var(--color-success)}.stat-value.neutral{color:#7f8c8d;color:var(--color-text-tertiary)}.roi-success{background:#d5f4e6;background:var(--color-success-light);border-radius:8px;border-radius:var(--radius-md);color:#1e8449;color:var(--color-success-dark);font-weight:500;font-weight:var(--font-weight-medium);margin-top:16px;margin-top:var(--spacing-md);padding:8px;padding:var(--spacing-sm);text-align:center}.actionable-guidance .guidance-section{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.guidance-section:last-child{margin-bottom:0}.guidance-section h4{align-items:center;color:#2c3e50;color:var(--color-text-primary);display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.guidance-icon{font-size:1.1em}.guidance-actions{list-style:none;margin:0;padding:0}.guidance-actions li{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);padding:4px 0;padding:var(--spacing-xs) 0;padding-left:24px;padding-left:var(--spacing-lg);position:relative}.guidance-actions li:before{color:#27ae60;color:var(--color-primary);content:"→";font-weight:500;font-weight:var(--font-weight-medium);left:0;position:absolute}.shopping-list-condensed,.task-list-condensed{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.shopping-item-condensed,.task-item-condensed{align-items:center;background:#f8f9fa;background:var(--color-background-light);border:1px solid #f1f3f4;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:8px;gap:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.shopping-urgency,.task-urgency{background:#e74c3c;background:var(--color-error);border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);min-width:30px;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-align:center}.shopping-name,.task-name{color:#2c3e50;color:var(--color-text-primary);flex:1 1}.shopping-name,.shopping-price,.task-name{font-size:14px;font-size:var(--font-size-sm)}.shopping-price{color:#34495e;color:var(--color-text-secondary);font-weight:500;font-weight:var(--font-weight-medium)}.shopping-add-btn,.task-complete-btn{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;display:flex;font-size:14px;font-size:var(--font-size-sm);height:28px;justify-content:center;transition:all .2s ease;width:28px}.shopping-add-btn:hover,.task-complete-btn:hover{background:#e8f5e8;background:var(--color-primary-light);border-color:#27ae60;border-color:var(--color-primary)}.shopping-add-btn:disabled,.task-complete-btn:disabled{background:#27ae60;background:var(--color-success);border-color:#27ae60;border-color:var(--color-success);color:#fff;cursor:default}.view-all-shopping,.view-all-tasks{background:#e8f5e8;background:var(--color-primary-light);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);color:#229954;color:var(--color-primary-dark);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:8px;padding:var(--spacing-sm);transition:all .2s ease;width:100%}.view-all-shopping:hover,.view-all-tasks:hover{background:#27ae60;background:var(--color-primary);color:#fff}@media (max-width:768px){.dashboard-grid{gap:16px;gap:var(--spacing-md);grid-template-columns:1fr}.alert{gap:8px;gap:var(--spacing-sm)}.alert,.harvest-main{flex-direction:column}.harvest-main{align-items:flex-start;gap:4px;gap:var(--spacing-xs)}.harvest-value{margin-left:0}.shopping-item-condensed,.task-item-condensed,.timing-header{flex-wrap:wrap}}.urgency-urgent{background:#f8d7da!important;background:var(--color-urgent-light)!important;border-left:4px solid #dc3545!important;border-left:4px solid var(--color-urgent)!important}.urgency-high{background:#ffe5d0!important;background:var(--color-high-light)!important;border-left:4px solid #fd7e14!important;border-left:4px solid var(--color-high)!important}.urgency-medium{background:#fff3cd!important;background:var(--color-medium-light)!important;border-left:4px solid #ffc107!important;border-left:4px solid var(--color-medium)!important}.urgency-low{background:#d4edda!important;background:var(--color-low-light)!important;border-left:4px solid #28a745!important;border-left:4px solid var(--color-low)!important}.urgency-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;letter-spacing:.05em;line-height:1;padding:2px 8px}.urgency-badge.urgent{background:#dc3545;background:var(--color-urgent)}.urgency-badge.high{background:#fd7e14;background:var(--color-high)}.urgency-badge.medium{background:#ffc107;background:var(--color-medium);color:#d39e00;color:var(--color-medium-dark)}.urgency-badge.low{background:#28a745;background:var(--color-low);color:#fff}.timing-indicator{align-items:center;display:inline-flex;font-weight:600;gap:4px;gap:var(--spacing-xs)}.timing-indicator.urgent{color:#b02a37;color:var(--color-urgent-dark)}.timing-indicator.high{color:#d63384;color:var(--color-high-dark)}.timing-indicator.medium{color:#d39e00;color:var(--color-medium-dark)}.timing-indicator.low{color:#1e7e34;color:var(--color-low-dark)}.alert{border-left:4px solid #0000;border-radius:8px;border-radius:var(--radius-md);margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:16px;padding:var(--spacing-md)}.alert.alert-urgent{background:#f8d7da;background:var(--color-urgent-light);border-left-color:#dc3545;border-left-color:var(--color-urgent);color:#b02a37;color:var(--color-urgent-dark)}.alert.alert-high{background:#ffe5d0;background:var(--color-high-light);border-left-color:#fd7e14;border-left-color:var(--color-high);color:#d63384;color:var(--color-high-dark)}.alert.alert-medium{background:#fff3cd;background:var(--color-medium-light);border-left-color:#ffc107;border-left-color:var(--color-medium);color:#d39e00;color:var(--color-medium-dark)}.alert.alert-low{background:#d4edda;background:var(--color-low-light);border-left-color:#28a745;border-left-color:var(--color-low);color:#1e7e34;color:var(--color-low-dark)}.card.urgent-card{border:2px solid #dc3545;border:2px solid var(--color-urgent);box-shadow:0 0 0 3px #f8d7da;box-shadow:0 0 0 3px var(--color-urgent-light)}.card.high-card{border:2px solid #fd7e14;border:2px solid var(--color-high);box-shadow:0 0 0 3px #ffe5d0;box-shadow:0 0 0 3px var(--color-high-light)}.shopping-item.urgent,.task-item.urgent{background:#f8d7da;background:var(--color-urgent-light);border-left:4px solid #dc3545;border-left:4px solid var(--color-urgent)}.shopping-item.high,.task-item.high{background:#ffe5d0;background:var(--color-high-light);border-left:4px solid #fd7e14;border-left:4px solid var(--color-high)}.shopping-item.medium,.task-item.medium{background:#fff3cd;background:var(--color-medium-light);border-left:4px solid #ffc107;border-left:4px solid var(--color-medium)}.shopping-item.low,.task-item.low{background:#d4edda;background:var(--color-low-light);border-left:4px solid #28a745;border-left:4px solid var(--color-low)}.days-remaining{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:700;height:24px;justify-content:center;line-height:1;min-width:32px}.days-remaining.urgent{background:#dc3545;background:var(--color-urgent);color:#fff}.days-remaining.high{background:#fd7e14;background:var(--color-high);color:#fff}.days-remaining.medium{background:#ffc107;background:var(--color-medium);color:#d39e00;color:var(--color-medium-dark)}.days-remaining.low{background:#28a745;background:var(--color-low);color:#fff}.compact-settings-panel{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:24px;margin-bottom:var(--spacing-lg);overflow:hidden}.settings-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg);text-align:left;transition:background-color .2s ease;width:100%}.settings-toggle:hover:not(:disabled){background:#f8f9fa;background:var(--color-background-light)}.settings-toggle:disabled{cursor:default;opacity:.7}.settings-toggle.expanded{background:#f8fff9;background:var(--color-primary-pale);border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--color-border)}.settings-icon{flex-shrink:0;font-size:1.2rem}.settings-summary{display:flex;flex:1 1;flex-direction:column;gap:2px}.current-selection{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);font-weight:500;font-weight:var(--font-weight-medium)}.toggle-hint{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs)}.expand-arrow{color:#34495e;color:var(--color-text-secondary);flex-shrink:0;font-size:.875rem;transition:transform .2s ease}.expand-arrow.down,.expand-arrow.up{transform:rotate(0deg)}.settings-content{background:#f8f9fa;background:var(--color-background-light);border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);padding:24px;padding:var(--spacing-lg)}.setting-group{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.setting-group:last-child{margin-bottom:0}.setting-title{align-items:center;color:#2c3e50;color:var(--color-text-primary);display:flex;font-size:16px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);gap:4px;gap:var(--spacing-xs);margin:0 0 16px;margin:0 0 var(--spacing-md) 0}.setting-row{display:flex;flex-wrap:wrap;gap:24px;gap:var(--spacing-lg)}.setting-item{display:flex;flex:1 1;flex-direction:column;gap:4px;gap:var(--spacing-xs);min-width:200px}.setting-item.full-width{flex:1 1 100%;min-width:0;min-width:auto}.setting-label{color:#34495e;color:var(--color-text-secondary);font-weight:500;font-weight:var(--font-weight-medium)}.setting-label,.setting-select{font-size:14px;font-size:var(--font-size-sm)}.setting-select{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);color:#2c3e50;color:var(--color-text-primary);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:border-color .2s ease,box-shadow .2s ease}.setting-select:focus{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 0 0 3px #e8f5e8;box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.setting-select:disabled{background:#f0f4f1;background:var(--color-background-dark);color:#7f8c8d;color:var(--color-text-tertiary);cursor:not-allowed}.setting-input{background:#fff;background:var(--color-background);border-radius:8px;border-radius:var(--radius-md);color:#2c3e50;color:var(--color-text-primary);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:border-color .2s ease,box-shadow .2s ease}.setting-input:focus{border-color:#27ae60;border-color:var(--color-primary);box-shadow:0 0 0 3px #e8f5e8;box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.setting-input:disabled{background:#f0f4f1;background:var(--color-background-dark);color:#7f8c8d;color:var(--color-text-tertiary);cursor:not-allowed}.portfolio-summary{margin-top:8px;margin-top:var(--spacing-sm)}.allocation-chips{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.allocation-chip{background:#e8f5e8;background:var(--color-primary-light);border-radius:4px;border-radius:var(--radius-sm);color:#229954;color:var(--color-primary-dark);font-size:12px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);padding:2px 4px;padding:2px var(--spacing-xs)}.investment-summary{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.total-investment{align-items:center;display:flex;font-weight:600;font-weight:var(--font-weight-semibold);justify-content:space-between}.total-label{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.total-value{color:#229954;color:var(--color-primary-dark);font-size:16px;font-size:var(--font-size-base);font-weight:700;font-weight:var(--font-weight-bold)}.settings-actions{border-top:1px solid #f1f3f4;border-top:1px solid var(--color-border-light);display:flex;gap:16px;gap:var(--spacing-md);justify-content:flex-end;margin-top:24px;margin-top:var(--spacing-lg);padding-top:24px;padding-top:var(--spacing-lg)}.settings-action-btn{background:#27ae60;background:var(--color-primary);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:background-color .2s ease}.settings-action-btn:hover{background:#229954;background:var(--color-primary-dark)}.settings-advanced-btn{background:none;border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);color:#27ae60;color:var(--color-primary);cursor:pointer;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.settings-advanced-btn:hover{background:#27ae60;background:var(--color-primary);color:#fff}@media (max-width:768px){.settings-toggle{padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.settings-content{padding:16px;padding:var(--spacing-md)}.setting-row{flex-direction:column;gap:16px;gap:var(--spacing-md)}.setting-item{min-width:0;min-width:auto}.settings-actions{flex-direction:column-reverse;gap:8px;gap:var(--spacing-sm)}.settings-action-btn,.settings-advanced-btn{text-align:center;width:100%}.allocation-chips{justify-content:center}}.welcome-screen{align-items:center;background:linear-gradient(135deg,#fff,#f8f9fa);background:linear-gradient(135deg,var(--color-background) 0,var(--color-background-light) 100%);display:flex;justify-content:center;min-height:100vh;padding:32px;padding:var(--spacing-xl)}.welcome-content{max-width:900px;text-align:center;width:100%}.welcome-header h1{color:#27ae60;color:var(--color-primary);font-size:3rem;font-weight:700;font-weight:var(--font-weight-bold);margin-bottom:16px;margin-bottom:var(--spacing-md)}.welcome-subtitle{color:#34495e;color:var(--color-text-secondary);font-size:18px;font-size:var(--font-size-lg);line-height:1.6;margin-bottom:32px;margin-bottom:var(--spacing-xl)}.welcome-features{margin:32px 0;margin:var(--spacing-xl) 0}.feature-grid{grid-gap:32px;grid-gap:var(--spacing-xl);display:grid;gap:32px;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px;margin-bottom:var(--spacing-xl)}.feature-item{background:#fff;border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:32px;padding:var(--spacing-xl);transition:transform .2s ease,box-shadow .2s ease}.feature-item:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-icon{font-size:2.5rem;margin-bottom:16px;margin-bottom:var(--spacing-md)}.feature-item h3{color:#27ae60;color:var(--color-primary);font-size:18px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.feature-item p{color:#34495e;color:var(--color-text-secondary);line-height:1.5}.welcome-actions{margin:32px 0;margin:var(--spacing-xl) 0}.create-garden-btn{background:#27ae60;background:var(--color-primary);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:18px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:24px 32px;padding:var(--spacing-lg) var(--spacing-xl);transition:all .2s ease}.create-garden-btn:hover{background:#229954;background:var(--color-primary-dark);transform:translateY(-1px)}.welcome-note{color:#7f8c8d;color:var(--color-text-tertiary);font-size:14px;font-size:var(--font-size-sm);margin:0}.welcome-location{background:#e8f5e8;background:var(--color-primary-light);border:1px solid #27ae60;border:1px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-md);margin-top:32px;margin-top:var(--spacing-xl);padding:24px;padding:var(--spacing-lg)}.location-info strong{color:#229954;color:var(--color-primary-dark);display:block;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.location-info p{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);margin:0}.fork-garden-btn,.new-garden-btn,.share-garden-btn{align-items:center;background:#27ae60;background:var(--color-primary);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);gap:4px;gap:var(--spacing-xs);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease;white-space:nowrap}.header-garden-btn{font-size:14px;font-size:var(--font-size-sm);gap:2px;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.fork-garden-btn:hover,.new-garden-btn:hover,.share-garden-btn:hover{background:#229954;background:var(--color-primary-dark);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.share-garden-btn{background:#3498db;background:var(--color-info)}.share-garden-btn:hover{background:#2471a3;background:var(--color-info-dark)}.garden-id-display{align-items:center;display:flex;font-size:14px;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm)}.garden-id-display .garden-id{background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);font-family:monospace;font-size:12px;font-size:var(--font-size-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.garden-id-display .garden-readonly{color:#b7791f;color:var(--color-warning-dark);font-size:12px;font-size:var(--font-size-xs)}.garden-id-display .garden-owned{color:#1e8449;color:var(--color-success-dark);font-size:12px;font-size:var(--font-size-xs)}@media (max-width:768px){.welcome-screen{padding:24px;padding:var(--spacing-lg)}.welcome-header h1{font-size:2rem}.welcome-subtitle{font-size:var(--font-size-md)}.feature-grid{gap:24px;gap:var(--spacing-lg);grid-template-columns:1fr}.feature-item{padding:24px;padding:var(--spacing-lg)}.create-garden-btn{font-size:var(--font-size-md);padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:16px;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.shopping-suggestion-modal .modal-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.shopping-suggestion-modal .modal-header h3{color:#059669;font-size:20px;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:24px;padding:8px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#111827}.modal-body{background:#fff;flex:1 1;overflow-y:auto;padding:24px}.activity-context{background:#ecfdf5;border:1px solid #d1fae5;border-radius:8px;margin-bottom:24px;padding:16px}.activity-context p{color:#111827;font-size:14px;margin:0}.activity-context strong{color:#059669;font-weight:600}.suggestion-intro{color:#6b7280;margin-top:8px!important}.suggestions-list{display:flex;flex-direction:column;gap:16px}.suggestion-item{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:16px;transition:all .2s ease}.suggestion-item:hover{background:#f0fdf4;border-color:#10b981;box-shadow:0 4px 6px -1px #0000001a}.suggestion-item.selected{background:#d1fae5;border-color:#059669;box-shadow:0 4px 6px -1px #0000001a}.suggestion-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.suggestion-title{align-items:center;display:flex;flex:1 1;gap:12px}.suggestion-title input[type=checkbox]{margin:0}.suggestion-name{color:#111827;font-size:16px;font-weight:600}.suggestion-price{color:#059669;font-size:14px;font-weight:600}.suggestion-details{color:#6b7280;font-size:12px;line-height:1.4}.suggestion-category{background:#e5e7eb;border-radius:4px;color:#374151;display:inline-block;font-size:11px;font-weight:500;letter-spacing:.025em;margin-bottom:8px;padding:4px 8px;text-transform:uppercase}.suggestion-reason{color:#4b5563;font-style:italic;margin-bottom:8px}.suggestion-timing,.suggestion-why{color:#6b7280;margin-bottom:8px}.suggestion-consequences{color:#f59e0b;font-weight:500}.urgency-badge{border-radius:4px;font-size:11px;font-weight:600;letter-spacing:.025em;padding:4px 8px;text-transform:uppercase}.urgency-badge.urgent{background:#dc2626;color:#fff}.urgency-badge.high{background:#f59e0b;color:#fff}.modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:12px;padding:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-actions .btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.modal-actions .btn-primary{background:#059669;color:#fff}.modal-actions .btn-primary:hover:not(:disabled){background:#047857}.modal-actions .btn-outline{background:#fff;border:1px solid #059669;color:#059669}.modal-actions .btn-outline:hover:not(:disabled){background:#f0fdf4}.modal-actions .btn-secondary{background:#f3f4f6;color:#374151}.modal-actions .btn-secondary:hover:not(:disabled){background:#e5e7eb}.modal-actions .btn:disabled{cursor:not-allowed;opacity:.5}.selection-summary{color:#6b7280;font-size:12px;text-align:center}@media (max-width:768px){.modal-overlay{padding:12px}.modal-content{max-height:95vh}.modal-actions,.suggestion-header{flex-direction:column}.suggestion-header{align-items:flex-start;gap:8px}.suggestion-title{width:100%}}.coordinate-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm)}.coordinate-inputs input{flex:1 1;min-width:120px}.geolocation-btn{background:#27ae60;background:var(--color-primary);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:14px;font-size:var(--font-size-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:background-color .2s ease;white-space:nowrap}.geolocation-btn:hover{background:#229954;background:var(--color-primary-dark)}.geolocation-btn:active{transform:translateY(1px)}.location-setup{background:var(--color-background-alt);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);margin-top:8px;margin-top:var(--spacing-sm);padding:16px;padding:var(--spacing-md)}.setting-item.coordinate-group,.setting-item.full-width{flex:1 1;width:100%}.setting-input{border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);font-size:14px;font-size:var(--font-size-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);width:100%}.setting-actions{display:flex;gap:8px;gap:var(--spacing-sm);justify-content:flex-end;margin-top:8px;margin-top:var(--spacing-sm);width:100%}.button.primary{background:#27ae60;background:var(--color-primary);color:#fff}.button.primary:hover{background:#229954;background:var(--color-primary-dark)}.button.primary:disabled{background:#7f8c8d;background:var(--color-text-tertiary);cursor:not-allowed}.probabilistic-calendar{margin-top:32px;margin-top:var(--spacing-xl)}.calendar-section{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.section-title{border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--color-border);color:#2c3e50;color:var(--color-text-primary);font-size:18px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:4px;padding-bottom:var(--spacing-xs)}.predictions-grid,.recommendations-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:24px;margin-bottom:var(--spacing-lg)}.prediction-card,.recommendation-card{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.prediction-card:hover,.recommendation-card:hover{border-color:#e8f5e8;border-color:var(--color-primary-light);box-shadow:0 4px 12px #0000001a}.prediction-header,.recommendation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md)}.crop-name{color:#2c3e50;color:var(--color-text-primary);font-size:18px;font-size:var(--font-size-lg);margin:0}.confidence-badge,.crop-name{font-weight:600;font-weight:var(--font-weight-semibold)}.confidence-badge{border-radius:var(--radius-full);font-size:12px;font-size:var(--font-size-xs);letter-spacing:.5px;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.recommendation-details{margin-bottom:16px;margin-bottom:var(--spacing-md)}.date-range{background:#f8f9fa;background:var(--color-background-light);border-left:4px solid #27ae60;border-left:4px solid var(--color-primary);border-radius:4px;border-radius:var(--radius-sm);color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);padding:8px;padding:var(--spacing-sm)}.date-range,.scenario-info{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.scenario-info{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.scenario-count{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs);margin-left:4px;margin-left:var(--spacing-xs)}.recommendation-text{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic;margin-bottom:16px;margin-bottom:var(--spacing-md)}.confidence-bar-container{margin-top:16px;margin-top:var(--spacing-md)}.confidence-label{color:#34495e;color:var(--color-text-secondary);font-size:12px;font-size:var(--font-size-xs);letter-spacing:.5px;margin-bottom:4px;margin-bottom:var(--spacing-xs);text-transform:uppercase}.confidence-bar{background:#f8f9fa;background:var(--color-background-light);border-radius:var(--radius-full);height:8px;overflow:hidden}.confidence-fill{border-radius:var(--radius-full);height:100%;transition:width .3s ease}.prediction-timeline{margin-bottom:16px;margin-bottom:var(--spacing-md)}.harvest-phase{align-items:center;background:#f8f9fa;background:var(--color-background-light);border-radius:4px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;margin-bottom:4px;margin-bottom:var(--spacing-xs);padding:8px;padding:var(--spacing-sm)}.harvest-phase.peak{background:#e8f5e8;background:var(--color-primary-light);font-weight:500;font-weight:var(--font-weight-medium)}.phase-label{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm)}.phase-date{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);font-weight:500;font-weight:var(--font-weight-medium)}.prediction-text{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic}.critical-events-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.critical-event{background:#fff;background:var(--color-background);border:1px solid #e9ecef;border:1px solid var(--color-border);border-left-width:4px;border-radius:8px;border-radius:var(--radius-md);padding:24px;padding:var(--spacing-lg)}.critical-event.priority-critical{background:#fadbd8;background:var(--color-error-light);border-left-color:#e74c3c;border-left-color:var(--color-error)}.critical-event.priority-high{background:#fdeaa7;background:var(--color-warning-light);border-left-color:#f39c12;border-left-color:var(--color-warning)}.critical-event.priority-medium{background:#e8f5e8;background:var(--color-primary-light);border-left-color:#27ae60;border-left-color:var(--color-primary)}.event-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.event-type{color:#2c3e50;color:var(--color-text-primary);font-weight:600;font-weight:var(--font-weight-semibold);text-transform:capitalize}.event-date{background:#fff;background:var(--color-background);border-radius:4px;border-radius:var(--radius-sm);color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.event-frequency{color:#7f8c8d;color:var(--color-text-tertiary);font-size:12px;font-size:var(--font-size-xs);font-weight:600;font-weight:var(--font-weight-semibold);text-transform:uppercase}.event-description{color:#2c3e50;color:var(--color-text-primary);font-size:16px;font-size:var(--font-size-base);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.event-recommendation{color:#34495e;color:var(--color-text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic}.calendar-summary{grid-gap:16px;grid-gap:var(--spacing-md);background:#f8f9fa;background:var(--color-background-light);border:1px solid #e9ecef;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-lg);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:32px;margin-top:var(--spacing-xl);padding:24px;padding:var(--spacing-lg)}.summary-stat{padding:16px;padding:var(--spacing-md);text-align:center}.stat-label{color:#34495e;color:var(--color-text-secondary);display:block;font-size:12px;font-size:var(--font-size-xs);letter-spacing:.5px;margin-bottom:4px;margin-bottom:var(--spacing-xs);text-transform:uppercase}.stat-value{color:#27ae60;color:var(--color-primary);display:block;font-size:20px;font-size:var(--font-size-xl);font-weight:700;font-weight:var(--font-weight-bold)}@media (max-width:768px){.predictions-grid,.recommendations-grid{grid-template-columns:1fr}.event-header{align-items:flex-start;flex-direction:column}.calendar-summary{grid-template-columns:repeat(2,1fr)}}
/*# sourceMappingURL=main.7e1fcc24.css.map*/