:root{--primary-color: #ff6b6b;--secondary-color: #4ecdc4;--background-color: #f7f9fc;--text-color: #2d3436;--font-family: "Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--text-color);line-height:1.6;overflow-x:hidden}.app-shell{max-width:800px;margin:0 auto;padding:1rem;width:100%}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem 0;border-bottom:2px solid #eee}.header-top{display:flex;align-items:center;gap:1rem}.nav-list{display:flex;list-style:none;gap:1.5rem;align-items:center}.nav-list a.active{color:var(--primary-color)!important;font-weight:700!important;position:relative}.nav-list a.active:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background-color:var(--primary-color)}.user-info{display:flex;align-items:center;gap:1rem}.user-email{font-size:.8rem;color:#666}.action-bar{display:flex;gap:1rem;margin-bottom:2rem}.mobile-only{display:none!important}.desktop-only{display:flex!important}.flex-responsive{display:flex;justify-content:space-between;align-items:center;gap:1rem}@media(max-width:600px){.header{flex-direction:column;gap:1rem;align-items:flex-start}.nav-list{width:100%;justify-content:space-between;gap:.5rem}.user-email{display:none}.action-bar,.flex-responsive,.form-inline{flex-direction:column;align-items:stretch}.header-top{width:100%}.mobile-only{display:flex!important}.desktop-only{display:none!important}.flex-responsive>*,.form-inline>*,.btn-block-mobile{width:100%}}.form-inline{display:flex;gap:.5rem;align-items:center}h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-weight:600}button{cursor:pointer;border:none;background-color:var(--primary-color);color:#fff;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;transition:background-color .2s ease}@media(hover:hover){button:hover{filter:brightness(1.1)}}button:active{filter:brightness(.9);transform:scale(.98)}input,textarea,select{font-family:inherit;padding:.5rem;border:1px solid #ccc;border-radius:4px}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;padding:2rem;border-radius:16px;width:90%;max-width:400px;box-shadow:0 10px 25px #0000001a;animation:slideUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h2{margin:0;font-size:1.25rem;color:var(--text-color)}.modal-body{margin-bottom:2rem;color:#666}.modal-footer{display:flex;gap:1rem;justify-content:flex-end}.close-button{background:none;border:none;color:#999;font-size:1.5rem;padding:0;line-height:1}@media(hover:hover){.close-button:hover{color:var(--text-color)}}button.danger{background-color:#ff6b6b}button.secondary{background-color:#edf2f7;color:#4a5568}@media(hover:hover){button.secondary:hover{background-color:#e2e8f0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:1.25rem;height:1.25rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.spinner-large{width:3rem;height:3rem;border-width:4px;color:var(--primary-color)}.loading-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.loading-full-page{position:fixed;inset:0;background-color:var(--background-color);z-index:2000}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:1rem}.login-card{background:#fff;padding:3rem;border-radius:24px;box-shadow:0 20px 40px #0003;text-align:center;color:var(--text-color);width:100%;max-width:450px;animation:slideUp .5s ease-out}@media(max-width:480px){.login-card{padding:2rem 1.5rem;border-radius:20px}}.meal-plan{padding:1rem 0}.week-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000000d;border:1px solid #eee}.week-section.current-week{border:2px solid var(--primary-color);background:#fffcfc}.week-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.week-title-group h2{margin:0;font-size:1.25rem;color:#4a5568}.current-week-badge{display:block;font-size:.75rem;color:var(--primary-color);font-weight:700;margin-top:.2rem;text-transform:uppercase;letter-spacing:.05em}.week-label{font-size:.9rem;color:#718096;font-weight:500}.days-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:.75rem}@media(max-width:800px){.days-grid{grid-template-columns:1fr}}.day-slot{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.3rem;min-height:90px;padding:.75rem;background:#f8fafc;border-radius:12px;border:1px dashed #cbd5e0;cursor:pointer;transition:all .2s ease;position:relative;text-align:center}.day-slot:not(.past):hover{background:#edf2f7;border-color:#a0aec0}.day-slot.has-content{border-style:solid;background:#fff;border-color:#e2e8f0;box-shadow:0 2px 4px #00000005}@media(min-width:801px){.day-slot{grid-column:span 3}.day-slot:nth-child(n+5){grid-column:span 4}}.day-slot.has-recipe{justify-content:flex-start;padding-top:1.5rem;min-height:130px}.day-name{font-size:.7rem;font-weight:700;color:#a0aec0;text-transform:uppercase;letter-spacing:.05em;position:absolute;top:.5rem;left:.5rem}.day-content{font-size:.85rem;font-weight:600;color:#2d3748;display:flex;flex-direction:column;align-items:center;gap:.4rem;line-height:1.2}.recipe-name-display{display:block;font-size:1rem;font-weight:600;color:#2d3748;margin:1rem 0 .2rem;line-height:1.2}.meal-plan-ingredients{width:100%;transform:scale(.9);transform-origin:top center}.day-clear,.lock-icon-container{position:absolute;top:.4rem;right:.4rem;padding:.3rem;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2;border-radius:6px;width:24px;height:24px}.day-clear{cursor:pointer;opacity:1;background:#fff5f5;color:#ff6b6b;border:1px solid #fed7d7}.lock-icon-container{background:#f1f5f9;color:#94a3b8;border:1px solid #e2e8f0;cursor:default}.day-clear:hover{background:#fed7d7;color:#e53e3e}.day-slot.past{cursor:default;background:#f1f5f9;border-color:#e2e8f0;border-style:solid;opacity:.7;-webkit-tap-highlight-color:transparent}.day-slot.past .day-clear{display:none}.placeholder-plus{color:#cbd5e0;opacity:.6}.prepared-badge{color:#38a169;font-size:.8rem;display:flex;align-items:center}.special-type-indicator{display:none}.day-slot.takeout{background:#feebc8;border-color:#fbd38d;color:#744210}.day-slot.takeout .day-name{color:#74421066}.day-slot.takeout .day-content{color:#744210}.day-slot.leftovers{background:#edf2f7;border-color:#cbd5e0;color:#2d3748}.day-slot.leftovers .day-name{color:#2d374866}.day-slot.no-dinner{background:#fed7d7;border-color:#feb2b2;color:#822727}.day-slot.no-dinner .day-name{color:#82272766}.day-slot-icon{margin-bottom:.2rem;opacity:.8}.recipe-picker-modal{max-width:500px!important;max-height:90vh;display:flex;flex-direction:column}.special-types-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.special-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.3rem;padding:.5rem;border-radius:12px;font-size:.75rem;font-weight:600}.special-type-btn.takeout{background:#feebc8;color:#92400e}.special-type-btn.leftovers{background:#e2e8f0;color:#4a5568}.special-type-btn.no-dinner{background:#fed7d7;color:#9b2c2c}.search-container{position:relative;margin-bottom:.75rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#a0aec0}.search-container input{width:100%;padding:.6rem .6rem .6rem 2.2rem;border-radius:8px;border:1px solid #e2e8f0;font-size:.95rem}.recipe-selection-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem;margin-top:.25rem;padding-right:.25rem;min-height:200px}.recipe-option-container{text-align:left;background:#fff;color:#2d3748;border:1px solid #e2e8f0;padding:.75rem;width:100%;border-radius:12px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.5rem}.recipe-option-container:hover{background:#f7fafc;border-color:var(--primary-color)}.recipe-option-container.random-selected{background:#f0fff4;border:2px solid #38a169}.recipe-option-container.random-selected:hover{background:#e6fffa}.recipe-option-name{font-weight:700;font-size:1rem;color:#2d3748}.recipe-option-ingredients{transform:scale(.9);transform-origin:top left}.no-results{text-align:center;color:#a0aec0;padding:1.5rem;font-style:italic;font-size:.9rem}.load-history-container{display:flex;justify-content:center;margin-bottom:1.5rem}.btn-load-history{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;background:#fff;color:#4a5568;border:1px solid #e2e8f0;border-radius:99px;box-shadow:0 2px 4px #0000000d;transition:all .2s}.btn-load-history:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.btn-add-week{width:100%;margin-top:.5rem;background:#f7fafc;color:#718096;border:2px dashed #e2e8f0;padding:1rem;font-weight:600;font-size:.9rem}.btn-add-week:hover{background:#edf2f7;border-color:#cbd5e0;color:#4a5568}.icon-btn{padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid #e2e8f0;background:#f8f9fa;color:#4a5568;cursor:pointer;transition:all .15s}.icon-btn:hover{background:#edf2f7}.icon-btn-danger{padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .15s;background:#fff5f5;color:#ff6b6b;border:1px solid #fed7d7}.icon-btn-danger:hover{background:#fee}.icon-btn-success{padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .15s;background:#f0fff4;color:#48bb78;border:1px solid #c6f6d5}.icon-btn-success:hover{background:#e6ffed}.icon-btn-warning{padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .15s;background:#fefcbf;color:#b7791f;border:1px solid #faf089}.icon-btn-warning:hover{background:#fef9c3}.icon-btn-info{padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .15s;background:#ebf8ff;color:#3182ce;border:1px solid #bee3f8}.icon-btn-info:hover{background:#dbeafe}.ingredient-chip{padding:4px 10px;border-radius:12px;font-size:.8rem;cursor:pointer;border:1px solid;transition:all .15s;background:#f0fff4;color:#276749;border-color:#c6f6d5}.ingredient-chip--missing{background:#fff5f5;color:#c53030;border-color:#fed7d7;text-decoration:line-through}.recipe-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.section-header{font-size:1.1rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.section-header--success{color:#276749}.section-header--muted{color:#a0aec0}.empty-state{color:#666;font-style:italic}.flex-col{display:flex;flex-direction:column}.flex-col--sm{gap:.5rem}.flex-col--md{gap:1rem}.flex-col--lg{gap:1.5rem}.flex-row{display:flex;gap:.4rem}.history-entry{display:flex;justify-content:space-between;align-items:center;padding:.6rem;background:#f8f9fa;border-radius:8px;border:1px solid #eee}.history-entry__date{flex:1;font-size:.9rem;color:#4a5568}.history-month-header{font-size:.85rem;color:#718096;text-transform:capitalize;margin-bottom:.5rem;border-bottom:1px solid #edf2f7;padding-bottom:.2rem}.page-padding{padding:1rem}.form-input{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.action-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:.5rem}.modal-subtitle{margin-bottom:1rem;font-size:1.1rem}.shopping-list-modal{max-width:500px!important;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;padding:1.5rem!important}.shopping-settings{background:#f8fafc;padding:1rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid #edf2f7}.setting-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.shopping-day-select{flex:1;padding:.6rem;border-radius:8px;border:1px solid #e2e8f0;font-size:.9rem}.date-range-display{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#718096;font-weight:500}.shopping-list-content{flex:1;overflow-y:auto;padding-right:.5rem}.shopping-list-items{display:flex;flex-direction:column;gap:.5rem}.shopping-list-item{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;background:#fff;border:1px solid #edf2f7;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.shopping-list-item:hover{border-color:var(--primary-color);background:#fffcfc;transform:translate(4px)}.shopping-list-item.checked{background:#f8fafc;opacity:.7}.shopping-list-item.checked .ingredient-name{text-decoration:line-through;color:#a0aec0}.ingredient-checkbox{display:flex;align-items:center;justify-content:center;color:#cbd5e0;transition:color .2s}.shopping-list-item:hover .ingredient-checkbox{color:var(--primary-color)}.shopping-list-item.checked .ingredient-checkbox{color:var(--secondary-color)}.ingredient-name{font-size:.95rem;font-weight:500;color:var(--text-color)}.empty-shopping-list{text-align:center;padding:3rem 1rem;color:#a0aec0}.shopping-list-content::-webkit-scrollbar{width:6px}.shopping-list-content::-webkit-scrollbar-track{background:transparent}.shopping-list-content::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:10px}
