.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;padding:3rem;width:100%;max-width:440px;animation:slideUp .4s ease;position:relative}.back-btn{position:absolute;top:1.5rem;left:1.5rem;background:none;border:none;color:#667eea;font-size:1rem;font-weight:600;cursor:pointer;padding:.5rem;transition:all .2s ease;display:flex;align-items:center;gap:.25rem}.back-btn:hover{color:#5568d3;transform:translate(-3px)}.auth-icon{font-size:4rem;text-align:center;margin-bottom:1.5rem}.auth-title{font-size:2rem;color:#333;margin-bottom:1rem;text-align:center}.auth-subtitle{text-align:center;color:#666;font-size:1rem;line-height:1.5;margin-bottom:2rem;max-width:350px;margin-left:auto;margin-right:auto}.auth-note{text-align:center;color:#999;font-size:.85rem;margin-top:1.5rem;font-style:italic}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border-left:4px solid #c33}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#555;font-weight:500;font-size:.9rem}.form-group input{padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.btn{padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-google{background:#fff;color:#444;border:2px solid #e0e0e0}.btn-google:hover:not(:disabled){background:#f8f8f8;border-color:#ccc}.btn-google-primary{padding:1rem 2rem;font-size:1.125rem;font-weight:600;background:#fff;color:#444;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s ease;box-shadow:0 2px 8px #00000014;width:100%}.btn-google-primary:hover:not(:disabled){background:#f8f9fa;border-color:#4285f4;box-shadow:0 4px 12px #4285f433;transform:translateY(-2px)}.btn-google-primary:disabled{opacity:.6;cursor:not-allowed}.google-only{text-align:center}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:#999}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #e0e0e0}.divider span{padding:0 1rem;font-size:.9rem}.auth-toggle{text-align:center;color:#666;margin-top:1.5rem;font-size:.9rem}.toggle-btn{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline}.toggle-btn:hover:not(:disabled){color:#5568d3}.prompt-list{animation:fadeIn .5s ease}.filters{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.search-box{flex:1}.search-input{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.favorites-toggle{display:flex;gap:.5rem;background:#fff;padding:.25rem;border-radius:10px;border:2px solid #e0e0e0}.toggle-btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:#666;transition:all .3s ease}.toggle-btn:hover{background:#f5f5f5}.toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.filter-selects{display:flex;gap:1rem;flex-wrap:wrap}.filter-select{padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;background:#fff;cursor:pointer;transition:all .3s ease;flex:1;min-width:200px}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.sort-select{background:linear-gradient(135deg,#f8f9fa,#e9ecef);font-weight:500;border-color:#667eea}.sort-select:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.clear-filters{padding:.875rem 1.5rem;background:#f5f5f5;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;color:#666;transition:all .3s ease}.clear-filters:hover{background:#e0e0e0}.results-info{color:#fff;margin-bottom:1rem;font-size:.9rem;opacity:.9}.empty-state{background:#fff;padding:4rem 2rem;border-radius:12px;text-align:center;color:#666}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;color:#333;margin-bottom:.5rem}.prompts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.prompt-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.prompt-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.prompt-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.prompt-title{font-size:1.25rem;color:#333;margin:0;flex:1}.prompt-actions{display:flex;gap:.5rem}.action-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:6px;transition:all .2s ease;opacity:.7}.action-btn:hover{opacity:1;background:#f5f5f5}.delete-btn:hover{background:#fee}.favorite-btn{font-size:1.5rem}.favorite-btn:hover{background:#fff9e6;transform:scale(1.1)}.favorite-btn.is-favorite{opacity:1;animation:pulse .3s ease}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.pdf-btn:hover{background:#e8f5e9}.prompt-description{color:#666;font-size:.95rem;line-height:1.5;margin:0}.prompt-meta{display:flex;flex-wrap:wrap;gap:.5rem}.meta-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.project-badge{background:#e3f2fd;color:#1976d2}.category-badge{background:#f3e5f5;color:#7b1fa2}.prompt-content-preview{background:#f8f9fa;border-radius:8px;padding:1rem;position:relative}.content-text{font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;color:#333;white-space:pre-wrap;word-break:break-word;max-height:120px;overflow:hidden;position:relative}.content-text.expanded{max-height:none}.content-text:not(.expanded):after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,#f8f9fa)}.expand-btn{margin-top:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:.85rem;color:#667eea;font-weight:500;transition:all .2s ease}.expand-btn:hover{background:#f5f5f5;border-color:#667eea}.prompt-footer{display:flex;justify-content:space-between;padding-top:1rem;border-top:1px solid #e0e0e0;font-size:.8rem;color:#999}@media (max-width: 768px){.prompts-grid{grid-template-columns:1fr}.filter-selects{flex-direction:column}.filter-select{min-width:100%}}.prompt-form{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 40px #0003}.form-title{font-size:1.75rem;color:#333;margin-bottom:2rem;text-align:center}.form-group label{display:block;color:#555;font-weight:600;margin-bottom:.5rem;font-size:.95rem}.required{color:#e74c3c}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;transition:all .3s ease}.form-group textarea{resize:vertical;font-family:Courier New,monospace;line-height:1.6}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.char-count{text-align:right;font-size:.85rem;color:#999;margin-top:.25rem}.project-selector{display:flex;flex-direction:column;gap:1rem}.radio-group{display:flex;gap:2rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400;color:#666}.radio-label input[type=radio]{width:auto;cursor:pointer}.project-select{width:100%}.category-input-group{display:flex;gap:.5rem}.category-input-group input{flex:1}.btn-add-category{padding:.875rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.btn-add-category:hover{background:#5568d3}.selected-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.category-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f3e5f5;color:#7b1fa2;border-radius:20px;font-size:.9rem;font-weight:500}.remove-category{background:none;border:none;color:#7b1fa2;font-size:1.5rem;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.remove-category:hover{background:#7b1fa233}.form-actions{display:flex;gap:1rem;margin-top:2rem;justify-content:flex-end}.btn-cancel,.btn-submit{padding:.875rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background:#f5f5f5;color:#666}.btn-cancel:hover{background:#e0e0e0}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}@media (max-width: 768px){.prompt-form{padding:1.5rem}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.prompt-manager{animation:fadeIn .5s ease}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.stats{display:flex;gap:1rem;flex-wrap:wrap}.stat-card{background:#fff;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;min-width:120px;text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#667eea}.stat-label{font-size:.85rem;color:#666;margin-top:.25rem}.btn-add-prompt{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.btn-add-prompt:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease}.form-container{max-width:800px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#fff}.loading-state .spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.madplan-container{max-width:1200px;margin:0 auto;padding:2rem}.madplan-container h1{text-align:center;margin-bottom:2rem;color:#2c3e50}.form-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.form-section h2{margin-top:0;margin-bottom:1rem;color:#34495e;font-size:1.3rem}.days-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.day-item{background:#f8f9fa;padding:1rem;border-radius:6px;border:1px solid #e9ecef}.day-item label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.day-item input[type=checkbox]{cursor:pointer}.day-options{margin-top:.75rem;padding-left:1.5rem;display:flex;flex-direction:column;gap:.5rem}.day-options label{font-weight:400;font-size:.9rem}.recipe-input{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:.9rem}.action-buttons{display:flex;gap:1rem;margin:1.5rem 0;padding:1.5rem 0;border-top:2px solid #e9ecef;border-bottom:2px solid #e9ecef}.action-btn{flex:1;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 6px #667eea4d}.primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 6px #f093fb4d}.secondary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #f093fb66}.tertiary-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 4px 6px #4facfe4d}.tertiary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #4facfe66}.extra-ingredients-section{margin:1.5rem 0}.extra-ingredients-section h2{margin-bottom:.5rem}.section-hint{color:#6c757d;font-size:.9rem;margin:0 0 .75rem;font-style:italic}.ingredients-textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:6px;font-size:.95rem;font-family:inherit;resize:vertical;transition:border-color .2s,box-shadow .2s}.ingredients-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.ingredients-overview{margin-top:2rem;padding-top:1.5rem;border-top:2px solid #e9ecef}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.overview-header h2{margin:0}.food-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;box-shadow:0 2px 4px #667eea4d}.food-loading{color:#6c757d;font-style:italic;padding:1.5rem;text-align:center;background:#f8f9fa;border-radius:6px}.categorized-food{margin-top:1rem}.food-categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.food-category-compact{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000000d}.food-category-compact .category-title{font-size:.95rem;font-weight:600;color:#495057;margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.food-category-compact .category-items{min-height:auto}.food-category-compact .food-item{font-size:.85rem;color:#495057;padding:.2rem 0;line-height:1.5}.output-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.output-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e9ecef}.output-header h2{margin:0}.download-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;box-shadow:0 4px 6px #667eea4d;transition:all .2s ease}.download-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.generated-plan{background:#f8f9fa;padding:1.5rem;border-radius:6px;border:1px solid #dee2e6}.generated-plan pre{white-space:pre-wrap;word-wrap:break-word;font-family:inherit;margin:0}.shopping-list{background:#fff3cd;padding:1.5rem;border-radius:6px;border-left:4px solid #ffc107;margin-bottom:2rem}.recipe{background:#fff;padding:1.5rem;border-radius:6px;border-left:4px solid #667eea;margin-bottom:1.5rem}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:6px;border-left:4px solid #f5c6cb;margin-top:1rem}@media print{.page-break{page-break-before:always}}@media (max-width: 768px){.madplan-container{padding:1rem}.action-buttons{flex-direction:column}.food-categories-grid{grid-template-columns:1fr}.output-header{flex-direction:column;gap:1rem;align-items:stretch}}.food-item-with-edit{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.edit-item-btn-small{background:#fff;border:2px solid #e0e7ff;color:#667eea;font-size:.85rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:all .2s;opacity:.7}.edit-item-btn-small:hover{background:#e0e7ff;opacity:1;transform:scale(1.1);box-shadow:0 2px 6px #667eea33}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.modal-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .2s;line-height:1}.modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.add-category-btn{padding:.75rem 1.5rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.add-category-btn:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 15px #fff3}.modal-body{padding:0}.modal-loading{padding:3rem;text-align:center;color:#666}.inventory-list{padding:1.5rem}.form-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#0009!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:2000!important;padding:2rem!important;animation:fadeIn .2s ease!important}.form-content{background:#fff!important;border-radius:16px!important;max-width:550px!important;width:100%!important;max-height:90vh!important;overflow-y:auto!important;box-shadow:0 20px 60px #0000004d!important;position:relative!important;animation:slideUp .3s ease!important}.form-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px 16px 0 0}.form-header h3{margin:0;font-size:1.4rem;font-weight:700;color:#fff}.form-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .2s;line-height:1}.form-close:hover{background:#ffffff4d;transform:scale(1.1)}.add-food-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.form-error{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.btn-cancel,.btn-submit{padding:.75rem 2rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;font-size:1rem}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover:not(:disabled){background:#e5e7eb;transform:translateY(-2px)}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-cancel:disabled,.btn-submit:disabled{opacity:.5;cursor:not-allowed}.parent-category{background:#fff;border-radius:12px;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s ease}.parent-category:hover{box-shadow:0 4px 12px #00000026}.parent-header{display:flex;align-items:center;padding:1.25rem;cursor:pointer;background:linear-gradient(135deg,#f8f9ff,#f0f0ff);transition:all .2s}.parent-header:hover{background:linear-gradient(135deg,#f0f0ff,#e8e8ff)}.expand-icon{margin-right:1rem;font-size:1rem;color:#667eea;transition:transform .2s}.parent-emoji{font-size:1.8rem;margin-right:1rem}.parent-name{font-weight:700;font-size:1.1rem;color:#1f2937;flex:1}.item-count{color:#667eea;font-weight:600;font-size:.9rem;margin-right:1rem}.category-actions{display:flex;gap:.5rem}.action-icon-btn{background:#fff;border:2px solid #e5e7eb;font-size:1.1rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .2s}.action-icon-btn:hover{background:#f9fafb;border-color:#667eea;transform:translateY(-2px);box-shadow:0 2px 8px #667eea33}.action-icon-btn.delete-btn:hover{border-color:#ef4444;box-shadow:0 2px 8px #ef444433}.children-list{padding:.5rem 1rem 1rem}.child-category{margin-bottom:.75rem}.child-header{display:flex;align-items:center;padding:1rem;background:#fff;border-radius:10px;border:2px solid #e5e7eb;transition:all .2s}.child-header:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.child-emoji{font-size:1.3rem;margin-right:.75rem}.child-name{font-weight:600;color:#374151;flex:1}.child-actions{display:flex;gap:.5rem;align-items:center}.action-icon-btn-small{background:#fff;border:2px solid #e5e7eb;font-size:.9rem;cursor:pointer;padding:.4rem .6rem;border-radius:6px;transition:all .2s}.action-icon-btn-small:hover{background:#f9fafb;border-color:#667eea;transform:translateY(-2px);box-shadow:0 2px 8px #667eea33}.action-icon-btn-small.delete-btn:hover{border-color:#ef4444;box-shadow:0 2px 8px #ef444433}.add-item-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #f093fb4d}.add-item-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f093fb66}.items-list{padding:.75rem 0 0 3rem}.food-item-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;color:#4b5563}.food-item-text{flex:1}.edit-item-btn{background:#fff;border:2px solid #e0e7ff;color:#667eea;font-size:.9rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .2s}.edit-item-btn:hover{background:#e0e7ff;transform:scale(1.1);box-shadow:0 2px 6px #667eea33}.delete-item-btn{background:#fff;border:2px solid #fee2e2;color:#ef4444;font-size:.9rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .2s}.delete-item-btn:hover{background:#fee2e2;transform:scale(1.1);box-shadow:0 2px 6px #ef444433}.empty-state{text-align:center;padding:3rem;color:#9ca3af}.empty-state p{margin-bottom:.5rem}.form-warning{background:#fef3c7;color:#92400e;padding:.75rem;border-radius:6px;font-size:.9rem;border:1px solid #fde68a}.mealplan-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem;animation:fadeIn .2s ease}.mealplan-modal-content{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mealplan-modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px 16px 0 0}.mealplan-modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.mealplan-download-btn{padding:.75rem 1.5rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mealplan-download-btn:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 15px #fff3}.mealplan-modal-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .2s;line-height:1}.mealplan-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.mealplan-modal-body{flex:1;overflow-y:auto;padding:2rem;background:#f9fafb}.mealplan-display{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.mealplan-display pre{white-space:pre-wrap;word-wrap:break-word;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#1f2937}.mealplan-display .shopping-list{background:#f0fdf4;padding:1.5rem;border-radius:8px;margin-bottom:2rem;border-left:4px solid #10b981}.mealplan-display .recipe{background:#fef3c7;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid #f59e0b}.mealplan-display strong{color:#667eea;font-weight:700}.app{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header{background:#fffffff2;box-shadow:0 2px 10px #0000001a;padding:1rem 0;margin-bottom:2rem}.header-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:2rem;color:#667eea;margin:0}.user-info{display:flex;align-items:center;gap:1rem}.user-email{color:#666;font-size:.9rem}.logout-btn{padding:.5rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.logout-btn:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.app-main{max-width:1400px;margin:0 auto;padding:0 2rem 2rem}.back-button-container{max-width:1400px;margin:0 auto;padding:1rem 2rem .5rem}.back-btn{padding:8px 16px;font-size:14px;border:none;border-radius:8px;background:#ffffff1a;color:#fff;cursor:pointer;transition:all .2s;font-weight:500}.back-btn:hover{background:#fff3;transform:translate(-2px)}
