:root{--color-primary:#2d6a4f;--color-accent:#52b788;--color-bg:#f4f9f6;--color-surface:#e8f4ed;--color-text:#1b3a2d;--color-muted:#6b9e85;--color-border:#c8e6d4;--color-white:#fff;--color-error:#c0392b;--color-warning:#e9a84c;--color-success:#52b788;--font-heading:"Playfair Display", serif;--font-body:"DM Sans", sans-serif;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-pill:999px;--shadow-sm:0 1px 3px #2d6a4f14, 0 1px 2px #2d6a4f0f;--shadow-md:0 4px 12px #2d6a4f1a, 0 2px 4px #2d6a4f14;--shadow-lg:0 8px 24px #2d6a4f1f, 0 4px 8px #2d6a4f14;--nav-height:64px;--header-height:56px;--max-width:480px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;min-height:100vh;line-height:1.5}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text);font-weight:600;line-height:1.25}h1{font-size:1.75rem}h2{font-size:1.375rem}h3{font-size:1.125rem}p{line-height:1.6}a{color:var(--color-primary);text-decoration:none}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:var(--font-body);font-size:1rem}img{max-width:100%;display:block}.app-container{max-width:var(--max-width);background:var(--color-bg);min-height:100vh;margin:0 auto;position:relative;box-shadow:0 0 40px #0000000f}.app-header{z-index:100;height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 1rem;display:flex;position:sticky;top:0}.app-header__logo{font-family:var(--font-heading);color:var(--color-primary);align-items:center;gap:.5rem;font-size:1.375rem;font-weight:700;display:flex}.app-header__logo svg{color:var(--color-accent)}.page-content{padding:1rem 1rem calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + 1.5rem);min-height:calc(100vh - var(--header-height))}.bottom-nav{width:100%;max-width:var(--max-width);height:calc(var(--nav-height) + env(safe-area-inset-bottom,0px));background:var(--color-white);border-top:1px solid var(--color-border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0px);align-items:flex-start;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -2px 12px #2d6a4f14}.bottom-nav__item{height:var(--nav-height);color:var(--color-muted);text-transform:uppercase;letter-spacing:.03em;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:4px 0;font-size:.625rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav__item svg{width:20px;height:20px;transition:transform .15s}.bottom-nav__item.active{color:var(--color-primary)}.bottom-nav__item.active svg{transform:scale(1.1)}.bottom-nav__item:active{opacity:.7}.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1rem;transition:box-shadow .2s,transform .2s}.card--interactive{cursor:pointer}.card--interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card--interactive:active{box-shadow:var(--shadow-sm);transform:translateY(0)}.btn{border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;line-height:1;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:var(--color-white)}.btn--primary:hover:not(:disabled){box-shadow:var(--shadow-sm);background:#245a42}.btn--accent{background:var(--color-accent);color:var(--color-white)}.btn--accent:hover:not(:disabled){background:#43a478}.btn--outline{color:var(--color-primary);border:1.5px solid var(--color-primary);background:0 0}.btn--outline:hover:not(:disabled){background:var(--color-surface)}.btn--ghost{color:var(--color-muted);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--color-surface);color:var(--color-primary)}.btn--danger{background:var(--color-error);color:var(--color-white)}.btn--danger:hover:not(:disabled){background:#a93226}.btn--full{width:100%}.btn--sm{padding:.4rem .875rem;font-size:.8125rem}.btn--lg{border-radius:var(--radius-lg);padding:.875rem 1.5rem;font-size:1rem}.input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:1rem;font-family:var(--font-body);background:var(--color-white);color:var(--color-text);outline:none;padding:.625rem .875rem;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #52b78826}.input::placeholder{color:var(--color-muted)}textarea.input{resize:vertical;min-height:80px}.tag{border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-border);align-items:center;padding:.2rem .625rem;font-size:.75rem;font-weight:500;display:inline-flex}.tag--accent{color:var(--color-primary);background:#52b78826;border-color:#52b7884d}.section-title{font-family:var(--font-heading);color:var(--color-text);margin-bottom:.875rem;font-size:1.25rem}.divider{background:var(--color-border);height:1px;margin:1rem 0}.empty-state{text-align:center;color:var(--color-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2.5rem 1rem;display:flex}.empty-state svg{opacity:.5}.empty-state p{font-size:.9375rem}.loading-spinner{border:2.5px solid;border-top-color:#0000;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-border) 50%, var(--color-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toggle-group{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);gap:.25rem;padding:.25rem;display:flex}.toggle-group__btn{border-radius:var(--radius-sm);color:var(--color-muted);cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;flex:1;padding:.4rem .75rem;transition:all .15s}.toggle-group__btn.active{background:var(--color-white);color:var(--color-primary);box-shadow:var(--shadow-sm)}.pill-selector{flex-wrap:wrap;gap:.5rem;display:flex}.pill-selector__btn{border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-muted);cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font-body);padding:.375rem .875rem;transition:all .15s}.pill-selector__btn.active{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.overlay{z-index:200;background:#00000073;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-white);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:1.25rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom,0));width:100%;max-width:var(--max-width);max-height:90vh;animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal__handle{background:var(--color-border);border-radius:2px;width:36px;height:4px;margin:0 auto 1rem}.modal__title{font-family:var(--font-heading);margin-bottom:1rem;font-size:1.25rem}.form-group{margin-bottom:1rem}.form-label{color:var(--color-text);margin-bottom:.375rem;font-size:.875rem;font-weight:500;display:block}.recipe-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.recipe-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s;overflow:hidden}.recipe-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.recipe-card:active{transform:translateY(0)}.recipe-card__body{padding:.75rem}.recipe-card__name{font-family:var(--font-heading);color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.25rem;font-size:.9375rem;font-weight:600;display:-webkit-box;overflow:hidden}.recipe-card__desc{color:var(--color-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:.8125rem;display:-webkit-box;overflow:hidden}.recipe-card__meta{color:var(--color-muted);flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.75rem;display:flex}.star-rating{gap:2px;display:flex}.star-rating__star{cursor:pointer;color:var(--color-border);background:0 0;border:none;padding:0;font-size:1.125rem;line-height:1;transition:transform .1s}.star-rating__star.filled{color:#f0a500}.star-rating__star:hover{transform:scale(1.2)}.generate-page{flex-direction:column;gap:1rem;display:flex}.generate-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.25rem}.generate-card__title{font-family:var(--font-heading);align-items:center;gap:.5rem;margin-bottom:.875rem;font-size:1.125rem;display:flex}.lucky-section{background:linear-gradient(135deg, var(--color-primary) 0%, #1a4a35 100%);border-radius:var(--radius-xl);color:var(--color-white);padding:1.5rem}.lucky-section__title{font-family:var(--font-heading);color:var(--color-white);margin-bottom:.375rem;font-size:1.25rem}.lucky-section__subtitle{opacity:.8;margin-bottom:1rem;font-size:.875rem}.lucky-buttons{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.btn--lucky{color:var(--color-white);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1.5px solid #ffffff4d}.btn--lucky:hover:not(:disabled){background:#ffffff40}.animation-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem 1rem;display:flex}.animation-container p{color:var(--color-muted);font-size:.9375rem}.recipe-result{animation:.4s fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.recipe-result__header{margin-bottom:1rem}.recipe-result__name{font-family:var(--font-heading);margin-bottom:.375rem;font-size:1.5rem}.recipe-result__desc{color:var(--color-muted);margin-bottom:.875rem;font-size:.9375rem}.recipe-result__meta{flex-wrap:wrap;gap:1rem;margin-bottom:.875rem;display:flex}.recipe-result__meta-item{color:var(--color-muted);align-items:center;gap:.375rem;font-size:.875rem;display:flex}.recipe-result__tags{flex-wrap:wrap;gap:.375rem;margin-bottom:1rem;display:flex}.recipe-result__section{margin-bottom:1.25rem}.recipe-result__section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);margin-bottom:.5rem;font-size:.8125rem;font-weight:600}.ingredient-item{border-bottom:1px solid var(--color-surface);align-items:center;gap:.5rem;padding:.375rem 0;font-size:.9375rem;display:flex}.ingredient-item:last-child{border-bottom:none}.ingredient-item__amount{color:var(--color-muted);flex-shrink:0;min-width:60px;font-size:.875rem}.ingredient-item__pantry{color:var(--color-accent);margin-left:auto;font-size:.75rem}.step-item{gap:.75rem;padding:.5rem 0;font-size:.9375rem;display:flex}.step-item__num{background:var(--color-primary);width:24px;height:24px;color:var(--color-white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.75rem;font-weight:600;display:flex}.meal-plan-grid{flex-direction:column;gap:.625rem;display:flex}.meal-day-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1rem}.meal-day-card.completed{opacity:.6;background:var(--color-surface)}.meal-day-card__day{text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.meal-day-card__name{font-family:var(--font-heading);margin-bottom:.25rem;font-size:1.0625rem}.meal-day-card__desc{color:var(--color-muted);margin-bottom:.75rem;font-size:.875rem}.meal-day-card__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.difficulty-badge{border-radius:var(--radius-pill);align-items:center;padding:.2rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.difficulty-badge--easy{color:#1a6e45;background:#52b78826}.difficulty-badge--medium{color:#a0650a;background:#e9a84c26}.difficulty-badge--hard{color:#8b1a10;background:#c0392b26}.grocery-item{border-bottom:1px solid var(--color-surface);align-items:center;gap:.75rem;padding:.625rem 0;display:flex}.grocery-item:last-child{border-bottom:none}.grocery-item__check{border:2px solid var(--color-border);cursor:pointer;background:var(--color-white);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.grocery-item__check.checked{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.grocery-item__name{flex:1;font-size:.9375rem}.grocery-item__name.checked{color:var(--color-muted);text-decoration:line-through}.grocery-item__amount{color:var(--color-muted);font-size:.8125rem}.pantry-deduct-item{align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.pantry-deduct-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.pantry-prompt{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-top:.375rem;padding:.625rem .875rem;font-size:.875rem;animation:.2s fadeIn;display:flex}.category-header{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);border-bottom:1px solid var(--color-accent);margin-bottom:.25rem;padding:.75rem 0 .25rem;font-size:.8125rem;font-weight:700}.profile-avatar{border:3px solid var(--color-accent);object-fit:cover;border-radius:50%;width:72px;height:72px}.profile-avatar--placeholder{background:var(--color-surface);color:var(--color-muted);justify-content:center;align-items:center;display:flex}.welcome-page{min-height:calc(100vh - var(--header-height));flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.welcome-card{background:var(--color-white);border:2px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;cursor:pointer;width:100%;box-shadow:var(--shadow-sm);padding:1.75rem;transition:all .2s}.welcome-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.welcome-card__icon{margin-bottom:.75rem;font-size:2.5rem}.welcome-card__title{font-family:var(--font-heading);margin-bottom:.375rem;font-size:1.25rem}.welcome-card__desc{color:var(--color-muted);font-size:.875rem}.sort-bar{scrollbar-width:none;gap:.375rem;margin-bottom:.875rem;padding-bottom:2px;display:flex;overflow-x:auto}.sort-bar::-webkit-scrollbar{display:none}.sort-bar__btn{border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-muted);cursor:pointer;font-size:.8125rem;font-weight:500;font-family:var(--font-body);flex-shrink:0;padding:.3125rem .75rem;transition:all .15s}.sort-bar__btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.slide-panel{z-index:150;background:var(--color-bg);animation:.25s slideInRight;position:fixed;inset:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.slide-panel__header{background:var(--color-white);border-bottom:1px solid var(--color-border);z-index:10;box-shadow:var(--shadow-sm);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex;position:sticky;top:0}.slide-panel__back{color:var(--color-primary);cursor:pointer;font-size:.9375rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:.25rem;display:flex}.slide-panel__body{padding:1.25rem 1rem calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + 1.5rem)}.family-invite-code{letter-spacing:.15em;color:var(--color-primary);background:var(--color-surface);border-radius:var(--radius-md);border:1.5px dashed var(--color-accent);text-align:center;padding:.5rem 1rem;font-family:monospace;font-size:1.375rem;font-weight:700}.tabs{border-bottom:2px solid var(--color-border);gap:0;margin-bottom:1rem;display:flex}.tab{color:var(--color-muted);cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font-body);text-align:center;background:0 0;border:none;border-bottom:2.5px solid #0000;flex:1;margin-bottom:-2px;padding:.625rem .5rem;transition:all .15s}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.search-bar{margin-bottom:.875rem;position:relative}.search-bar input{padding-left:2.5rem}.search-bar__icon{color:var(--color-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.category-chips{scrollbar-width:none;gap:.375rem;margin-bottom:.875rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.category-chips::-webkit-scrollbar{display:none}.category-chip{border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-muted);cursor:pointer;font-size:.8125rem;font-family:var(--font-body);flex-shrink:0;padding:.25rem .75rem;font-weight:500;transition:all .15s}.category-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pantry-item{border-bottom:1px solid var(--color-surface);align-items:center;gap:.75rem;padding:.625rem 0;display:flex}.pantry-item:last-child{border-bottom:none}.pantry-item__info{flex:1;min-width:0}.pantry-item__name{white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:500;overflow:hidden}.pantry-item__amount{color:var(--color-muted);font-size:.8125rem}.pantry-item__badges{flex-shrink:0;gap:.375rem;display:flex}.badge-low{border-radius:var(--radius-pill);color:#a0650a;background:#e9a84c26;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.alert{border-radius:var(--radius-md);align-items:flex-start;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.alert--error{color:var(--color-error);background:#c0392b14;border:1px solid #c0392b33}.alert--success{color:var(--color-primary);background:#52b7881a;border:1px solid #52b78840}.tips-box{border-radius:var(--radius-md);color:var(--color-primary);background:#52b78814;border:1px solid #52b78833;padding:.875rem;font-size:.9rem}.reroll-bar{border-top:1px solid var(--color-border);gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}@media (width<=380px){.recipe-grid{grid-template-columns:1fr}}.fade-enter{opacity:0}.fade-enter-active{opacity:1;transition:opacity .25s}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity .25s}
