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