:root{--bg:#f8f8f6;--card:#fff;--text:#111110;--text-muted:#72706d;--border:#e4e4e0;--surface:#f1f1ef;--protein:#0d9488;--fat:#d97706;--carbs:#dc2626;--calories:#7c3aed;--accent:#16a34a;--accent-hover:#15803d;--warning:#ef4444;--success:#16a34a;--color-warn-bg:#fffbeb;--color-warn-border:#fde68a;--color-warn-text:#92400e;--color-success-bg:#f0fdf4;--color-success-border:#bbf7d0;--color-delete-hover-bg:#fee2e2;--color-delete-hover-border:#fca5a5;--color-heart-hover:#e05c6f;--color-surface-hover:#eaeae8;--color-recipe-chip-bg:#eef2ee;--color-recipe-chip-border:#c5d4c5;--color-recipe-chip-hover-bg:#e2ebe2;--color-recipe-chip-hover-border:#a8c0a8;--color-stepper-disabled:#d6d6d2;--color-stepper-disabled-border:#bebebe;--color-lock-default:#c4c4c0;--color-lock-locked:#6b6b68;--color-header-hover:#fafafa;--color-summary-inline:#444442;--color-chevron:#9a9a96;--color-ing-card-hover-border:#d6d6d2;--color-border-hover:#b4b4b0;--color-border-hover-muted:#cacac6;--space-1:4px;--space-2:8px;--space-3:16px;--space-4:24px;--space-5:32px;--space-6:48px;--space-7:64px;--space-8:96px;--text-display:36px;--text-h1:32px;--text-h2:24px;--text-body:16px;--text-sm:14px;--text-caption:13px;--text-xs:12px;--text-xxs:11px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-pill:999px;--radius:14px;--touch-target:44px;--font:"Plus Jakarta Sans", sans-serif;--shadow-sm:0 1px 2px #10100e0a, 0 2px 8px #10100e0f;--shadow-md:0 2px 4px #10100e0a, 0 8px 24px #10100e1a;--shadow-lg:0 4px 8px #10100e0d, 0 16px 48px #10100e21}[data-theme=dark]{--bg:#111113;--card:#1a1a1d;--text:#f2f2f0;--text-muted:#8b8b91;--border:#2e2e33;--surface:#222226;--protein:#2dd4bf;--fat:#fb923c;--carbs:#f87171;--calories:#a78bfa;--accent:#34d399;--accent-hover:#6ee7b7;--warning:#f87171;--success:#34d399;--color-warn-bg:#1a1100;--color-warn-border:#3d2800;--color-warn-text:#fbbf24;--color-success-bg:#04160a;--color-success-border:#14532d;--color-delete-hover-bg:#1a0808;--color-delete-hover-border:#5c1a1a;--color-heart-hover:#fb7185;--color-surface-hover:#2a2a2e;--color-recipe-chip-bg:#181e14;--color-recipe-chip-border:#263320;--color-recipe-chip-hover-bg:#1e2818;--color-recipe-chip-hover-border:#324224;--color-stepper-disabled:#2e2e34;--color-stepper-disabled-border:#3d3d44;--color-lock-default:#484852;--color-lock-locked:#888890;--color-header-hover:#1e1e22;--color-summary-inline:#d4d4d0;--color-chevron:#686870;--color-ing-card-hover-border:#38383e;--color-border-hover:#484852;--color-border-hover-muted:#3c3c42;--shadow-sm:0 1px 2px #0003, 0 2px 8px #0000002e;--shadow-md:0 2px 4px #0003, 0 8px 24px #0000004d;--shadow-lg:0 4px 8px #0000003d, 0 16px 48px #00000061}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overflow-y:scroll}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{padding:72px var(--space-3) var(--space-8)}@media (width>=480px){#root{padding:100px var(--space-3) var(--space-5)}}.app-layout{grid-template-areas:"sidebar""feed";display:grid}.sidebar{grid-area:sidebar}.feed{padding-top:var(--space-3);grid-area:feed;min-width:0}@media (width>=900px){.navbar{width:calc(100% - 80px);max-width:1120px}#root{max-width:1200px;padding:100px 40px var(--space-6);margin:0 auto}.app-layout{grid-template-columns:1fr 400px;grid-template-areas:"feed sidebar";align-items:start;gap:40px}.sidebar{position:sticky;top:92px}.feed{max-width:680px;padding-top:0}.onboarding{max-width:480px;margin:0 auto}}.loading-screen{text-align:center;color:var(--text-muted);padding-top:120px;font-size:15px}.navbar{display:none}@media (width>=480px){.navbar{top:var(--space-3);width:calc(100% - var(--space-5));z-index:20;-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-pill);background:#fffffff0;border:1px solid #e3ddd4e6;justify-content:center;align-items:center;height:52px;padding:0 20px;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #1a0f081a,0 1px 4px #1a0f080f}}.navbar-brand{letter-spacing:-.02em;color:var(--text);font-size:17px;font-weight:700;line-height:1}@media (width>=480px){.navbar-brand{letter-spacing:-.02em;font-size:18px;position:absolute;left:20px}}.navbar-links{display:none}@media (width>=480px){.navbar-links{background:var(--surface);border-radius:var(--radius-pill);border:1px solid var(--border);gap:2px;padding:3px;display:flex}}.navbar-link{cursor:pointer;font-family:var(--font);font-size:var(--text-sm);color:var(--text-muted);border-radius:var(--radius-pill);white-space:nowrap;background:0 0;border:none;align-items:center;gap:5px;padding:7px 14px;font-weight:500;transition:color .15s,background .15s;display:flex}.navbar-link:hover{color:var(--text);background:var(--surface)}.navbar-link.active{color:var(--card);background:var(--text);font-weight:600}.navbar-mobile-gradient{background:linear-gradient(to bottom, var(--bg) 56px, transparent 72px);pointer-events:none;z-index:19;height:72px;position:fixed;top:0;left:0;right:0}@media (width>=480px){.navbar-mobile-gradient{background:linear-gradient(to bottom, var(--bg) 68px, transparent 100%);height:120px;display:block}}.navbar-avatar-mobile{top:var(--space-3);right:var(--space-3);z-index:20;background:var(--accent);color:#fff;width:36px;height:36px;font-family:var(--font);font-size:var(--text-sm);cursor:pointer;box-shadow:var(--shadow-md);border:none;border-radius:50%;justify-content:center;align-items:center;font-weight:700;transition:background .15s;display:flex;position:fixed}.navbar-avatar-mobile:active{background:var(--accent-hover)}@media (width>=480px){.navbar-avatar-mobile{display:none}}.bottom-tabs{bottom:var(--space-4);transform-origin:bottom;z-index:20;gap:var(--space-1);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-pill);background:#fffffff0;border:1px solid #e3ddd4e6;padding:6px;transition:transform .25s,opacity .25s;display:flex;position:fixed;left:50%;transform:translate(-50%)scale(1);box-shadow:0 4px 24px #1a0f081a,0 1px 4px #1a0f080f}.bottom-tabs--small{opacity:.85;transform:translate(-50%)scale(.75)}@media (width>=480px){.bottom-tabs{display:none}}.bottom-tab{cursor:pointer;min-height:var(--touch-target);border-radius:var(--radius-pill);color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:10px 18px;transition:color .15s,background .15s;display:flex}.bottom-tab svg{width:20px;height:20px}.bottom-tab:hover{color:var(--text);background:var(--surface)}.bottom-tab.active{color:var(--card);background:var(--text)}[data-theme=dark] .navbar,[data-theme=dark] .bottom-tabs{background:#111113e6;border-color:#2e2e33e6;box-shadow:0 4px 24px #0000005c,0 1px 4px #00000038}.theme-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:color .15s,background .15s;display:none}.theme-toggle:hover{color:var(--text);background:var(--surface)}@media (width>=480px){.theme-toggle{display:flex}}.theme-toggle-mobile{top:var(--space-3);left:var(--space-3);z-index:20;background:var(--card);width:36px;height:36px;color:var(--text-muted);border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:fixed}.theme-toggle-mobile:active{background:var(--surface)}@media (width>=480px){.theme-toggle-mobile{display:none}}.page-placeholder{min-height:calc(100dvh - 196px);color:var(--text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}@media (width>=480px){.page-placeholder{min-height:calc(100dvh - 132px)}}@media (width>=900px){.page-placeholder{min-height:calc(100dvh - 148px)}}.budget-bar{z-index:10;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--border);padding:14px 12px 18px;position:sticky;top:80px}@media (width<=899px){.budget-bar{padding:16px 16px 20px}}@media (width>=900px){.budget-bar{padding:20px 20px 24px;position:static}}.budget-date{font-size:var(--text-xs);color:var(--text-muted);text-align:center;letter-spacing:.03em;margin-bottom:var(--space-3);font-weight:500}.budget-calories{justify-content:center;margin-bottom:20px;display:flex}.budget-macros{grid-template-columns:repeat(3,1fr);place-items:start center;display:grid}.donut-wrap{flex-direction:column;align-items:center;gap:5px;display:flex}.donut-wrap-lg{gap:7px}.donut-inner{fill:var(--text);font-size:14px;font-weight:700}.donut-label{font-size:var(--text-xxs);letter-spacing:.02em;font-weight:600}.donut-sublabel{fill:var(--text-muted);font-size:10px}.donut-target{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:10px}.budget-overshot{color:var(--warning)!important}.budget-banner{border-radius:var(--radius-md);font-size:var(--text-caption);text-align:center;margin-top:14px;padding:9px 14px;font-weight:600}.budget-banner.warning{background:var(--color-warn-bg);color:var(--color-warn-text);border:1px solid var(--color-warn-border)}.budget-banner.complete{background:var(--color-success-bg);color:var(--success);border:1px solid var(--color-success-border)}.ingredient-cards{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.no-ingredients-hint{min-height:57px;color:var(--text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;margin:0;display:flex}.add-ingredient-btn{justify-content:center;align-items:center;gap:var(--space-1);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;min-height:57px;font-family:var(--font);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:8px 14px;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:flex}.add-ingredient-btn:hover{color:var(--text);border-color:var(--color-border-hover);background:var(--surface)}.ingredient-row{background:var(--surface);border-radius:var(--radius-md);border:1px solid #0000;justify-content:space-between;align-items:center;gap:12px;min-height:57px;padding:6px 14px;transition:border-color .15s,background .15s;display:flex}.ingredient-row:hover{border-color:var(--border);background:var(--color-surface-hover)}.ingredient-name{font-size:var(--text-sm);flex:1;min-width:0;font-weight:500}.ingredient-stepper{flex-shrink:0;align-items:center;gap:6px;display:flex}.stepper-input{text-align:center;width:56px;font-size:var(--text-sm);font-variant-numeric:tabular-nums;font-weight:600;font-family:var(--font);border:1px solid var(--border);background:var(--card);color:var(--text);-moz-appearance:textfield;border-radius:8px;padding:6px 4px;transition:border-color .15s}.stepper-input:focus{border-color:var(--accent);outline:none}.stepper-input::-webkit-inner-spin-button{-webkit-appearance:none}.stepper-input::-webkit-outer-spin-button{-webkit-appearance:none}.stepper-input:disabled{background:var(--color-stepper-disabled);border-color:var(--color-stepper-disabled-border);color:var(--text-muted);cursor:not-allowed}.ingredient-unit{font-size:var(--text-caption);color:var(--text-muted);width:12px;font-weight:500}.ingredient-row.disabled .ingredient-name{color:var(--text-muted)}.ingredient-row.logged{cursor:default}.ingredient-logged-amount{font-size:var(--text-sm);color:var(--text-muted);font-variant-numeric:tabular-nums;font-weight:600}.ingredient-lock-btn{cursor:pointer;color:var(--color-lock-default);min-width:var(--touch-target);min-height:var(--touch-target);border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:color .15s;display:flex}.ingredient-lock-btn:hover{color:var(--text-muted)}.ingredient-lock-btn.locked{color:var(--color-lock-locked)}.ingredient-remove-btn{cursor:pointer;color:var(--text-muted);min-width:var(--touch-target);min-height:var(--touch-target);border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.ingredient-remove-btn:hover{color:var(--warning);background:var(--color-delete-hover-bg)}.ingredient-search{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;min-height:57px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.ingredient-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #16653414}.ingredient-search-row{flex:1;align-items:center;display:flex}.ingredient-search-input-wrap{flex:1;position:relative}.ingredient-search-input{width:100%;font-family:var(--font);font-size:var(--text-sm);color:var(--text);background:0 0;border:none;outline:none;padding:8px 38px 8px 14px}.ingredient-search-input::placeholder{color:var(--text-muted)}.ingredient-search-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;position:absolute;top:50%;right:36px;transform:translateY(-50%)}.ingredient-search-close{cursor:pointer;width:24px;height:24px;color:var(--text-muted);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;line-height:1;transition:color .15s,background .15s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.ingredient-search-close:hover{color:var(--text);background:var(--border)}@keyframes spin{to{transform:rotate(360deg)}}.ingredient-search-dropdown{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;max-height:320px;list-style:none;overflow-y:auto}.ingredient-search-dropdown li{cursor:pointer;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 14px;transition:background .1s;display:flex}.ingredient-search-dropdown li:hover{background:var(--surface)}.ingredient-search-dropdown li.active{background:var(--color-success-bg);border-left:3px solid var(--accent);padding-left:11px}.search-load-more{text-align:center;font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-2) var(--space-3);pointer-events:none}.search-result-name{font-size:var(--text-caption);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.search-result-macros{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.search-result-unit{color:var(--border)}.search-grams-input{text-align:center;font-variant-numeric:tabular-nums;width:60px;font-size:14px;font-weight:600;font-family:var(--font);border:1px solid var(--border);background:var(--card);color:var(--text);-moz-appearance:textfield;border-radius:8px;flex-shrink:0;padding:8px 4px;transition:border-color .15s}.search-grams-input:focus{border-color:var(--accent);outline:none}.search-grams-input::-webkit-inner-spin-button{-webkit-appearance:none}.search-grams-input::-webkit-outer-spin-button{-webkit-appearance:none}.search-add-btn{background:var(--accent);color:#fff;font-size:var(--text-caption);font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;border-radius:9px;padding:9px 18px;transition:background .15s,box-shadow .15s}.search-add-btn:hover{background:var(--accent-hover);box-shadow:0 2px 8px #16653440}.lock-button{background:var(--accent);color:#fff;border-radius:var(--radius-pill);min-height:57px;font-family:var(--font);cursor:pointer;border:none;flex:1;padding:15px 24px;font-size:15px;font-weight:600;transition:background .15s,box-shadow .15s,transform .15s;display:block;box-shadow:0 2px 8px #16a34a33}.lock-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 16px #16a34a4d}.lock-button:active{transform:translateY(0);box-shadow:0 2px 8px #16a34a33}.lock-button:disabled{background:var(--border);color:var(--text-muted);box-shadow:none;cursor:default;transform:none}[data-theme=dark] .lock-button:not(.outline):not(:disabled){color:#052e16}.lock-button.outline{color:var(--accent);border:1.5px solid var(--accent);background:0 0;transition:background .15s,box-shadow .15s,transform .15s;box-shadow:0 2px 8px #16a34a1a}.lock-button.outline:hover{background:var(--color-success-bg);transform:translateY(-2px);box-shadow:0 4px 16px #16a34a2e}.lock-button.outline:disabled{border-color:var(--border);color:var(--text-muted);background:0 0}.lock-button.outline .spinner{border-color:currentColor #0000 #0000}.lock-button .spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}[data-theme=dark] .lock-button:not(.outline):not(:disabled) .spinner{border-color:#052e16 #052e1640 #052e1640}.meal-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-md);margin-bottom:12px;transition:box-shadow .2s,border-color .2s;overflow:visible}.meal-card:hover{box-shadow:var(--shadow-lg)}.meal-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius);align-items:center;gap:12px;min-height:77px;padding:18px 22px;transition:background .15s;display:flex}.meal-card-header:hover{background:var(--color-header-hover)}.meal-card.expanded .meal-card-header:hover{background:0 0}.meal-label{font-size:var(--text-body);letter-spacing:.02em;color:var(--text);flex:1;font-weight:600}.locked-card-actions{gap:10px;margin-top:4px;display:flex}.locked-edit-btn,.locked-delete-btn{background:var(--surface);border:1px solid var(--border);font-family:var(--font);font-size:var(--text-caption);color:var(--text-muted);cursor:pointer;border-radius:12px;flex-shrink:0;padding:10px 20px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.locked-edit-btn:hover{background:var(--border);color:var(--text);border-color:var(--color-border-hover-muted)}.locked-delete-btn:hover{background:var(--color-delete-hover-bg);color:var(--warning);border-color:var(--color-delete-hover-border)}.meal-card.locked .meal-label{color:var(--text-muted)}.meal-card.locked .meal-card-header{cursor:pointer}.meal-summary-inline{font-size:var(--text-caption);color:var(--color-summary-inline);font-variant-numeric:tabular-nums}.meal-mini-donuts{align-items:center;width:100%;display:flex}.mini-donut-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1px;display:flex}.mini-donut-wrap.large{gap:2px}.mini-donut-wrap.large .mini-donut-value{font-size:var(--text-xs)}.mini-donut-label{color:var(--text-muted);letter-spacing:.02em;font-size:10px;font-weight:500}.mini-donut-value{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;font-weight:600}.meal-chevron{font-size:var(--text-body);color:var(--color-chevron);transition:transform .2s}.meal-chevron.open{transform:rotate(180deg)}.meal-card-body{padding:0 22px 22px}.meal-header-donut-slot{flex:2;position:relative}.meal-header-donut-slot .meal-mini-donuts{justify-content:flex-end;gap:4px;width:auto}.meal-header-donut-slot .mini-donut-wrap{flex:none}.meal-summary-pill{background:var(--surface);margin-top:var(--space-2);text-align:center;border:1px solid var(--border);border-radius:12px;padding:12px 16px 8px}.meal-donuts{justify-content:space-around;display:flex}.meal-donut-wrap{flex-direction:column;align-items:center;gap:2px;display:flex}.meal-donut-value{font-size:var(--text-xxs);font-weight:700}.meal-donut-label{font-size:var(--text-xxs);font-weight:600}.meal-donut-footer{padding:12px 0 4px}.meal-card-accordion{opacity:0;grid-template-rows:0fr;transition:grid-template-rows .25s ease-in-out,opacity .2s ease-in-out;display:grid}.meal-card-accordion.expanded{opacity:1;grid-template-rows:1fr}.meal-card-accordion-inner{overflow:hidden}.meal-card-reveal-gradient{border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);background:linear-gradient(to bottom, transparent, var(--card));pointer-events:none;z-index:1;height:64px;position:absolute;bottom:0;left:0;right:0}.balance-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);width:57px;color:var(--text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.balance-btn:hover:not(:disabled){background:var(--surface);border-color:var(--color-border-hover);color:var(--text)}.balance-btn:disabled{opacity:.45;cursor:default}.suggestions-hint{font-size:var(--text-xs);color:var(--text-muted);text-align:center;padding:var(--space-2) 0 var(--space-1);margin:0}.suggestions-row{padding:12px 0}.suggestions-scroll-wrap{width:100%;position:relative}.suggestions-scroll-wrap:before,.suggestions-scroll-wrap:after{content:"";pointer-events:none;z-index:1;opacity:0;width:48px;transition:opacity .15s;position:absolute;top:0;bottom:0}@media (width>=900px){.suggestions-scroll-wrap:before,.suggestions-scroll-wrap:after{width:72px}}.suggestions-scroll-wrap:before{background:linear-gradient(to right, var(--card) 30%, transparent);left:0}.suggestions-scroll-wrap:after{background:linear-gradient(to left, var(--card) 30%, transparent);right:0}.suggestions-scroll-wrap[data-scroll-left=true]:before,.suggestions-scroll-wrap[data-scroll-right=true]:after{opacity:1}.suggestions-label{font-size:var(--text-xxs);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600;display:block}.suggestions-chips{gap:var(--space-2);scrollbar-width:none;flex-wrap:nowrap;padding-bottom:6px;display:flex;overflow-x:auto}.suggestions-chips::-webkit-scrollbar{display:none}.suggestion-chip{align-items:center;gap:var(--space-2);min-height:var(--touch-target);background:var(--surface);border:1.5px solid var(--border);font-family:var(--font);font-size:var(--text-caption);cursor:pointer;text-align:left;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:7px 12px 7px 14px;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.suggestion-chip:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.suggestion-chip-name{color:var(--text);font-weight:500}.suggestion-chip-add{flex-shrink:0;display:block}.recipe-chip{background:var(--color-recipe-chip-bg);border-color:var(--color-recipe-chip-border)}.recipe-chip:hover{background:var(--color-recipe-chip-hover-bg);border-color:var(--color-recipe-chip-hover-border);box-shadow:var(--shadow-sm)}.custom-actions{margin-top:var(--space-3)}.bottom-actions{align-items:stretch;gap:var(--space-2);width:100%;display:flex}.save-fav-icon-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:57px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.save-fav-icon-btn:hover{background:var(--surface);color:var(--text);border-color:var(--color-border-hover)}.save-fav-icon-btn.saved{color:var(--accent);border-color:var(--accent)}.save-fav-icon-btn.delete-icon:hover{background:var(--color-delete-hover-bg);color:var(--warning);border-color:var(--color-delete-hover-border)}.save-favorite-row{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;min-height:57px;transition:border-color .15s,box-shadow .15s;display:flex}.save-favorite-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #16653414}.save-favorite-input{font-family:var(--font);font-size:var(--text-sm);color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:8px 12px}.save-favorite-input::placeholder{color:var(--text-muted)}.save-favorite-confirm{background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-caption);cursor:pointer;border:none;margin-right:8px;padding:8px 14px;font-weight:600;transition:background .15s}.save-favorite-confirm:hover{background:var(--accent-hover)}.save-favorite-cancel{background:var(--surface);color:var(--text-muted);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-caption);cursor:pointer;border:none;margin-right:8px;padding:8px 14px;font-weight:500;transition:background .15s}.save-favorite-cancel:hover{background:var(--border)}.ingredients-page{padding-bottom:var(--space-6)}.ingredients-header{align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:20px;display:flex}@media (width<=899px){.ingredients-header{flex-direction:column;align-items:stretch}}.ingredients-title{letter-spacing:-.01em;color:var(--text);flex-shrink:0;font-size:22px;font-weight:700}.ingredients-title-group{flex-direction:column;gap:2px;display:flex}.ingredients-subtitle{font-size:var(--text-caption);color:var(--text-muted);margin:0}.ingredients-search{font-family:var(--font);font-size:var(--text-sm);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);color:var(--text);outline:none;flex:1;padding:9px 14px;transition:border-color .15s,box-shadow .15s}.ingredients-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16653414}.ingredients-list{gap:var(--space-2);flex-direction:column;display:flex}.ing-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:14px 16px;transition:box-shadow .15s,border-color .15s}.ing-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-ing-card-hover-border)}.ing-card-top{margin-bottom:var(--space-2);align-items:center;gap:10px;display:flex}.ing-card-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.ing-heart-btn{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:3px;transition:color .15s,transform .1s;display:flex}.ing-heart-btn:hover{color:var(--color-heart-hover);transform:scale(1.15)}.ing-heart-btn.favorited{color:var(--color-heart-hover)}.ing-name{font-size:var(--text-sm);flex:1;min-width:0;font-weight:600}.ing-category{font-size:var(--text-xxs);color:var(--text-muted);background:var(--surface);border-radius:var(--radius-sm);padding:2px var(--space-2);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;max-width:180px;font-weight:500;overflow:hidden}.ing-macros{flex-direction:column;gap:5px;display:flex}.ing-macro-bar{background:var(--border);border-radius:3px;height:5px;display:flex;overflow:hidden}.ing-macro-seg{height:100%}.seg-p{background:var(--protein)}.seg-f{background:var(--fat)}.seg-c{background:var(--carbs)}.ing-macro-nums{font-size:var(--text-xs);font-variant-numeric:tabular-nums;align-items:center;gap:10px;font-weight:600;display:flex}.ing-cal{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;margin-left:auto;font-weight:500}.ing-per{font-size:var(--text-xxs);color:var(--text-muted)}.ing-load-more{margin-top:var(--space-2);background:var(--surface);border-radius:var(--radius-md);width:100%;font-family:var(--font);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;border:none;padding:12px;font-weight:500;transition:background .15s,color .15s}.ing-load-more:hover{background:var(--border);color:var(--text)}.ing-loading,.ing-empty{text-align:center;padding:var(--space-5);color:var(--text-muted);font-size:var(--text-sm)}.favorites-panel{flex-direction:column;gap:28px;display:flex}.favorites-section-title{font-size:var(--text-xxs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-weight:700}.favorites-empty{font-size:var(--text-caption);color:var(--text-muted);padding:var(--space-1) 0}.favorites-list{gap:var(--space-1);flex-direction:column;list-style:none;display:flex}.fav-recipe-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-caption);color:var(--text);padding:9px 12px;font-weight:500}.fav-recipe-name{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.fav-ing-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:var(--space-2);padding:8px 12px;display:flex}.fav-ing-name{font-size:var(--text-caption);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.fav-ing-macros{font-size:var(--text-xxs);font-variant-numeric:tabular-nums;flex-shrink:0;gap:6px;font-weight:600;display:flex}.page-container{max-width:680px;padding-top:var(--space-3);margin:0 auto}.weight-slider-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.weight-slider-label{width:80px;font-weight:500;font-size:var(--text-sm);flex-shrink:0}.weight-slider-input{accent-color:var(--accent);flex:1}.weight-slider-value{text-align:right;width:44px;font-size:var(--text-caption);color:var(--text-muted);font-variant-numeric:tabular-nums}.meal-size-preview{padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--border);gap:var(--space-2);flex-direction:column;margin-top:0;display:flex}.meal-size-bar-row{align-items:center;gap:10px;display:flex}.meal-size-label{width:120px;font-size:var(--text-caption);color:var(--text-muted);flex-shrink:0}.meal-size-bar-track{background:var(--surface);border-radius:5px;flex:1;height:8px;overflow:hidden}.meal-size-bar-fill{background:var(--accent);border-radius:5px;height:100%;transition:width .2s}.meal-size-cal{text-align:right;width:60px;font-size:var(--text-caption);color:var(--text-muted);font-variant-numeric:tabular-nums}.settings-page{max-width:480px;padding-bottom:var(--space-6);margin:0 auto}.settings-section{margin-bottom:var(--space-4)}.settings-label{font-size:var(--text-xxs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:0 var(--space-1);margin-bottom:var(--space-2);font-weight:700}.settings-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.field-group{align-items:center;gap:var(--space-3);padding:13px var(--space-4);border-bottom:1px solid var(--border);display:flex}.field-group:last-of-type{border-bottom:none}.field-group label{font-size:var(--text-sm);flex:1;font-weight:500}.field-group input[type=number]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);color:var(--text);font-variant-numeric:tabular-nums;text-align:right;appearance:textfield;width:88px;padding:7px 10px;transition:border-color .15s}.field-group input[type=number]::-webkit-inner-spin-button{display:none}.field-group input[type=number]::-webkit-outer-spin-button{display:none}.field-group input[type=number]:focus{border-color:var(--accent);outline:none}.field-input-disabled{opacity:.5;cursor:default}.meals-grid{gap:var(--space-2);padding:var(--space-4);display:flex}.meal-option{border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:52px;height:44px;color:var(--text-muted);font-family:var(--font);font-size:var(--text-body);cursor:pointer;font-weight:500;transition:border-color .15s,color .15s,background .15s}.meal-option.selected{border-color:var(--accent);color:var(--accent);background:var(--color-success-bg);font-weight:700}.meal-option:hover:not(.selected){border-color:var(--color-border-hover);color:var(--text)}.sliders-wrap{padding:var(--space-3) var(--space-4) var(--space-2)}.settings-save-btn{background:var(--accent);color:#fff;border-radius:var(--radius-pill);width:100%;font-family:var(--font);font-size:var(--text-body);cursor:pointer;margin-top:var(--space-4);border:none;padding:15px;font-weight:600;transition:background .15s,box-shadow .15s,transform .15s;display:block;box-shadow:0 2px 8px #16a34a33}.settings-save-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 16px #16a34a4d}[data-theme=dark] .settings-save-btn{color:#052e16}[data-theme=dark] .settings-save-btn:disabled{color:var(--text-muted)}.settings-save-btn:disabled{background:var(--border);color:var(--text-muted);cursor:default;transform:none}.settings-signout{margin:var(--space-3) auto 0;color:var(--text-muted);font-family:var(--font);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2);background:0 0;border:none;transition:color .15s;display:block}.settings-signout:hover{color:var(--warning)}
