@import"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Nunito:wght@400;500;600;700;800&display=swap";:root{--color-primary-green: #006e03;--color-secondary-green: #34c759;--color-recipe-green: #008b06;--color-success-green: #218a3c;--color-background: #f3f2f5;--color-surface: #ffffff;--color-card-bg: #f9f9f9;--color-text-primary: #1a1c18;--color-text-secondary: #51534e;--color-text-tertiary: #767872;--color-outline: #6d7b66;--color-outline-variant: #bccbb3;--color-border: #e2e3dc;--color-active-bg: #f9faf3;--color-on-surface: #151e13;--color-surface-variant: #e7f1df;--color-green-light: #acd19f;--color-orange-accent: #fd8738;--color-orange-bg: #fff5f0;--color-green-bg: #f0f9f4;--color-iron: #af311a;--color-calcium: #fbc163;--color-b12: #57e1f7;--color-tabbar-bg: #e2e3dc;--color-tabbar-selected: #006e03;--color-tabbar-unselected: #767872;--color-black: #000000;--color-white: #ffffff;--color-muted-soft: #888888;--color-hero-green: #14340f;--color-heading-strong: #222720;--color-error: #b00020;--color-overlay-soft: rgba(0, 0, 0, .06);--color-overlay: rgba(0, 0, 0, .08);--color-overlay-strong: rgba(0, 0, 0, .12);--color-surface-tint: rgba(255, 255, 255, .82);--color-surface-raised: rgba(255, 255, 255, .88);--color-surface-raised-strong: rgba(255, 255, 255, .9);--color-surface-border: rgba(255, 255, 255, .68);--color-surface-border-strong: rgba(255, 255, 255, .74);--color-green-wash: rgba(0, 110, 3, .08);--color-green-wash-strong: rgba(0, 110, 3, .12);--color-green-border-soft: rgba(0, 110, 3, .08);--color-green-border: rgba(0, 110, 3, .1);--color-green-border-strong: rgba(0, 110, 3, .36);--color-onboarding-check-bg: #eaf6e5;--color-membership-pro-bg: #14340f;--color-membership-pro-fg: #fff5d6;--color-membership-free-bg: #edf2ea;--color-purchase-plan-bg: #e7f1df;--color-note-bg: #f7faf4;--page-bg-top: #f9faf8;--page-bg-mid: #f3f2f5;--page-bg-bottom: #eef1ec;--page-glow-white: rgba(255, 255, 255, .92);--page-glow-white-soft: rgba(255, 255, 255, .72);--page-glow-green: rgba(172, 209, 159, .2);--page-glow-blue: rgba(87, 225, 247, .11);--color-lock-overlay: rgba(243, 242, 245, .85);--color-fab-green-bright: #1fb44f;--color-progress-track: #dbe8d2;--color-scrim-strong: rgba(0, 0, 0, .45);--color-icon-subtle: rgba(0, 0, 0, .45);--color-avatar-bg: rgba(0, 0, 0, .06);--color-stat-surface: rgba(255, 255, 255, .72);--glass-white: rgba(255, 255, 255, .68);--glass-strong: rgba(255, 255, 255, .84);--glass-stroke: rgba(255, 255, 255, .72);--glass-stroke-soft: rgba(255, 255, 255, .78);--glass-stroke-strong: rgba(255, 255, 255, .84);--glass-stroke-bright: rgba(255, 255, 255, .88);--glass-shadow: 0 18px 60px rgba(24, 34, 21, .14);--glass-inner-shadow: inset 0 1px 0 rgba(255, 255, 255, .95);--shadow-card: 0 2px 10px rgba(0, 0, 0, .05);--shadow-card-soft: 0 4px 6px rgba(0, 0, 0, .03);--shadow-raised-soft: 0 14px 34px rgba(20, 38, 24, .06);--shadow-raised-md: 0 14px 36px rgba(20, 38, 24, .07);--shadow-raised-lg: 0 18px 40px rgba(20, 38, 24, .08);--shadow-raised-xl: 0 20px 48px rgba(20, 38, 24, .08);--shadow-press-soft: 0 10px 28px rgba(20, 38, 24, .08);--shadow-action-green: 0 10px 20px rgba(0, 110, 3, .16);--shadow-onboarding-panel: 0 18px 40px rgba(15, 30, 19, .08);--shadow-onboarding-card-active: 0 10px 20px rgba(0, 110, 3, .1);--shadow-tab-active: inset 0 1px 0 rgba(255, 255, 255, .98), inset 0 -8px 18px rgba(255, 255, 255, .22), 0 12px 26px rgba(22, 43, 26, .12);--shadow-fab: 0 20px 36px rgba(0, 110, 3, .34), 0 0 0 9px rgba(255, 255, 255, .44), inset 0 1px 0 rgba(255, 255, 255, .52);--shadow-fab-hover: 0 24px 40px rgba(0, 110, 3, .28), 0 0 0 10px rgba(255, 255, 255, .48), inset 0 1px 0 rgba(255, 255, 255, .6);--gradient-page-backdrop: radial-gradient(circle at top center, var(--page-glow-white) 0%, rgba(255, 255, 255, 0) 38%), radial-gradient(circle at 12% 18%, var(--page-glow-green) 0%, rgba(172, 209, 159, 0) 28%), radial-gradient(circle at 88% 12%, var(--page-glow-blue) 0%, rgba(87, 225, 247, 0) 22%), linear-gradient(180deg, var(--page-bg-top) 0%, var(--page-bg-mid) 44%, var(--page-bg-bottom) 100%);--gradient-layout-halo: radial-gradient(circle at 50% 0%, var(--page-glow-white-soft) 0%, rgba(255, 255, 255, 0) 58%), linear-gradient(180deg, rgba(255, 255, 255, .22) 0%, rgba(255, 255, 255, .02) 100%);--gradient-overview-card: linear-gradient(180deg, rgba(255, 255, 255, .92) 0%, rgba(248, 251, 246, .96) 100%);--gradient-tabbar-surface: linear-gradient(180deg, rgba(255, 255, 255, .8) 0%, rgba(241, 246, 239, .62) 100%);--gradient-tabbar-sheen: linear-gradient(180deg, rgba(255, 255, 255, .56) 0%, rgba(255, 255, 255, .08) 54%, rgba(255, 255, 255, .24) 100%);--gradient-tabbar-toplight: linear-gradient(180deg, rgba(255, 255, 255, .56) 0%, rgba(255, 255, 255, 0) 100%);--gradient-tab-active: linear-gradient(180deg, rgba(255, 255, 255, .66) 0%, rgba(232, 244, 233, .5) 100%);--gradient-tab-active-gloss: linear-gradient(180deg, rgba(255, 255, 255, .52) 0%, rgba(255, 255, 255, 0) 100%);--gradient-fab: radial-gradient(circle at 30% 28%, rgba(157, 246, 173, .95) 0%, rgba(157, 246, 173, 0) 38%), linear-gradient(180deg, var(--color-fab-green-bright) 0%, var(--color-primary-green) 100%);--gradient-fab-halo: radial-gradient(circle, rgba(255, 255, 255, .42) 0%, rgba(255, 255, 255, 0) 68%);--gradient-onboarding-panel: linear-gradient(180deg, var(--color-white) 0%, #f3f8ee 100%);--gradient-onboarding-card-active: linear-gradient(180deg, var(--color-white) 0%, #f3fbf1 100%);--component-card-radius: 20px;--component-card-radius-lg: 24px;--component-card-padding: 20px;--component-card-padding-compact: 18px;--component-btn-radius: 12px;--component-btn-padding-y: 14px;--component-btn-padding-x: 20px;--component-chip-radius: 999px;--component-sheet-radius: 20px;--component-input-radius: 16px;--component-touch-target: 44px;--component-press-scale: .985;--component-focus-ring: 0 0 0 4px var(--color-green-wash-strong);--component-transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease, opacity .18s ease;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--page-section-gap: 18px;--page-section-gap-tight: 14px;--page-section-gap-loose: 24px;--font-nunito: "Nunito", system-ui, sans-serif;--font-baloo: "Baloo 2", system-ui, sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--gradient-page-backdrop);color:var(--color-text-primary);min-height:100dvh;font-family:var(--font-nunito);font-size:14px;font-weight:500;-webkit-tap-highlight-color:transparent;background-attachment:fixed}#app{min-height:100dvh}.layout{min-height:100dvh;display:flex;flex-direction:column;padding-bottom:calc(126px + env(safe-area-inset-bottom,0));position:relative}.layout:before{content:"";position:fixed;left:50%;bottom:calc(22px + env(safe-area-inset-bottom,0));transform:translate(-50%);width:min(640px,calc(100vw - 28px));height:132px;border-radius:42px;background:var(--gradient-layout-halo);opacity:.8;filter:blur(28px);pointer-events:none;z-index:30}.layout--scan{padding-bottom:env(safe-area-inset-bottom,0)}.main{flex:1;padding:18px 18px 10px;max-width:760px;margin:0 auto;width:100%;position:relative;z-index:1}.main--transition-fade{animation:pageFadeIn .22s ease}.main--transition-forward{animation:pageSlideForward .26s cubic-bezier(.22,.8,.24,1)}.main--transition-back{animation:pageSlideBack .26s cubic-bezier(.22,.8,.24,1)}.main--transition-sheet{animation:pageSheetIn .26s cubic-bezier(.22,.8,.24,1)}.page-shell{display:flex;flex-direction:column;gap:var(--page-section-gap)}.page-shell--recipes{gap:var(--page-section-gap-tight)}.page-shell--profile{gap:var(--page-section-gap-loose)}.page-shell .screen-title-row,.page-shell .recipes-title-bar,.page-shell .week-cal,.page-shell .overview-card,.page-shell .meal-card,.page-shell .filter-section,.page-shell .recipe-list,.page-shell .load-trigger,.page-shell .energy-card,.page-shell .impact-hint,.page-shell .animal-grid,.page-shell .pwa-note,.page-shell .profile-summary,.page-shell .profile-goals-card,.page-shell .chart-card{margin-bottom:0;margin-top:0}.boot,.err-box{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:12px;text-align:center;padding:24px}.err-box p{color:var(--color-text-secondary);max-width:320px}.screen-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-top:var(--space-1)}.day-slots-card{display:flex;flex-direction:column;gap:12px;padding:16px 18px;border-radius:20px;background:var(--color-surface-raised);border:1px solid var(--color-surface-border);box-shadow:var(--shadow-raised-soft)}.day-slots-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px}.day-slots-card__eyebrow,.energy-card__eyebrow,.sanctuary-card__eyebrow,.inbox-card__eyebrow{margin:0;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-green)}.day-slots-card__meta{margin:0;font-size:13px;color:var(--color-text-secondary)}.day-slots-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.day-slot{display:flex;flex-direction:column;gap:6px;padding:14px 12px;border-radius:16px;background:var(--color-card-bg);border:1px solid transparent;text-align:left;font:inherit;width:100%;cursor:pointer;transition:var(--component-transition)}.day-slot--done{background:var(--color-green-wash);border-color:var(--color-green-border)}.day-slot--open{background:linear-gradient(180deg,#ffffffeb,#f7f9f4fa);border-color:var(--color-border)}.day-slot__top{display:flex;align-items:center;justify-content:space-between;gap:8px}.day-slot__pill{padding:5px 8px;border-radius:999px;background:#ffffffad;color:var(--color-text-secondary);font-size:11px;font-weight:700;letter-spacing:.02em}.day-slot__label{font-size:14px;font-weight:700;color:var(--color-text-primary)}.day-slot__state{font-size:12px;color:var(--color-text-secondary);line-height:1.45}.day-slot:hover{transform:translateY(-1px);box-shadow:var(--shadow-card-soft)}.day-slot:active{transform:scale(var(--component-press-scale))}.day-slot:focus-visible{outline:none;box-shadow:var(--component-focus-ring)}.celebration-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:20px;border:1px solid var(--color-surface-border-strong);background:linear-gradient(180deg,#fffffff0,#f4f9f1f5);box-shadow:var(--shadow-raised-soft)}.celebration-card--saved{background:linear-gradient(180deg,#fffffff0,#f7f8f5fa)}.celebration-card__icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--color-green-wash);color:var(--color-primary-green);font-size:24px;flex-shrink:0}.celebration-card__copy{min-width:0;flex:1}.celebration-card__eyebrow{margin:0 0 4px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-green)}.celebration-card__text{margin:0;color:var(--color-text-secondary);font-size:14px;line-height:1.5}.celebration-card__close{width:36px;height:36px;border:none;border-radius:50%;background:transparent;color:var(--color-text-tertiary);font-size:24px;line-height:1;cursor:pointer;flex-shrink:0}.screen-title{font-family:var(--font-nunito);font-size:22px;font-weight:700;color:var(--color-black);margin:0}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--color-black);padding:0;transition:var(--component-transition)}.icon-btn svg{width:25px;height:25px}.icon-btn__img{width:25px;height:25px;object-fit:contain;image-rendering:-webkit-optimize-contrast}.meal-type-icon{display:block;object-fit:contain;image-rendering:-webkit-optimize-contrast}.meal-type-icon--slot{width:20px;height:20px}.meal-type-icon--card{width:28px;height:28px}.meal-type-icon--row{width:22px;height:22px}.meal-type-icon--chip{width:18px;height:18px}.scan-header__back,.scan-header__action,.meal-card__chev,.meal-card__add,.filter-tag,.type-chip,.btn,.purchase-plan,.purchase-close,.onboarding-card,.recipe-card-h,.date-modal__input,.onboarding-input input,.settings-select{transition:var(--component-transition)}.icon-btn:focus-visible,.scan-header__back:focus-visible,.scan-header__action:focus-visible,.meal-card__chev:focus-visible,.meal-card__add:focus-visible,.filter-tag:focus-visible,.type-chip:focus-visible,.btn:focus-visible,.purchase-plan:focus-visible,.purchase-close:focus-visible,.onboarding-card:focus-visible,.recipe-card-h:focus-visible,.date-modal__input:focus-visible,.onboarding-input input:focus-visible,.settings-select:focus-visible{outline:none;box-shadow:var(--component-focus-ring)}.week-cal{display:flex;background:var(--color-surface-tint);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-1);margin-bottom:var(--space-4);box-shadow:var(--shadow-raised-soft);border:1px solid var(--glass-white);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.week-cal__day{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 2px;border:none;background:transparent;cursor:pointer;font-family:var(--font-baloo);border-radius:var(--radius-md)}.week-cal__day--selected{background:var(--color-active-bg)}.week-cal__dow{font-size:14px;font-weight:600}.week-cal__dow--future{color:var(--color-outline-variant)}.week-cal__dow--muted{color:var(--color-outline)}.week-cal__dow--sel{color:var(--color-primary-green)}.week-cal__ring{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.week-cal__ring svg{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotate(-90deg)}.week-cal__num{position:relative;z-index:1;font-weight:700;color:var(--color-on-surface)}.week-cal__num--lg{font-size:20px}.week-cal__num--sm{font-size:14px}.week-cal__num--future{color:var(--color-outline-variant)}.overview-card{background:var(--gradient-overview-card);border-radius:var(--component-card-radius);padding:var(--component-card-padding);margin-bottom:var(--space-4);box-shadow:var(--shadow-raised-xl);border:1px solid var(--glass-strong)}.overview-card__title{font-size:18px;font-weight:500;margin:0 0 var(--space-5);color:var(--color-black)}.overview-top{display:flex;gap:var(--space-4);align-items:flex-start;margin-bottom:var(--space-5)}.protein-ring-wrap{position:relative;width:120px;height:120px;flex-shrink:0}.protein-ring{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--color-primary-green) calc(var(--ring-p, 0) * 360deg),var(--color-overlay-strong) 0);-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 14px),var(--color-black) calc(100% - 13px));mask:radial-gradient(farthest-side,transparent calc(100% - 14px),var(--color-black) calc(100% - 13px))}.protein-ring__label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none}.protein-ring__val{font-size:16px;font-weight:700;color:var(--color-black)}.protein-ring__sub{font-size:12px;color:var(--color-muted-soft)}.overview-side{flex:1;display:flex;flex-direction:column;gap:12px;min-width:0}.mini-card__body{flex:1;min-width:0}.mini-card{display:flex;align-items:center;gap:8px;padding:12px;border-radius:var(--radius-md);border:1px solid transparent}.mini-card--orange{background:var(--color-orange-bg);border-color:var(--color-orange-accent)}.mini-card--green{background:var(--color-green-bg);border-color:var(--color-success-green)}.mini-card__emoji{font-size:20px}.mini-card__title{font-size:14px;font-weight:500;margin:0}.mini-card--orange .mini-card__title{color:var(--color-orange-accent)}.mini-card--green .mini-card__title{color:var(--color-success-green)}.mini-bar{height:4px;background:var(--color-overlay);border-radius:2px;overflow:hidden;flex:1;min-width:40px}.mini-bar>i{display:block;height:100%;border-radius:2px;background:var(--color-orange-accent);width:var(--w, 0%)}.mini-card__row{display:flex;align-items:center;gap:4px;width:100%}.mini-card__pct{font-size:14px;font-weight:700;color:var(--color-black)}.mini-card__co2{font-size:18px;font-weight:700;color:var(--color-black)}.nutrient-row{display:flex;gap:16px;margin-top:4px}.nutrient-item{flex:1;min-width:0}.nutrient-item__head{display:flex;align-items:center;gap:4px;margin-bottom:4px}.nutrient-dot{width:6px;height:6px;border-radius:50%;background:var(--nutrient-accent, var(--color-primary-green))}.nutrient-name{font-size:12px;color:var(--color-muted-soft)}.nutrient-bar{height:4px;background:var(--color-overlay);border-radius:2px;overflow:hidden;margin-bottom:4px}.nutrient-bar>i{display:block;height:100%;width:var(--nutrient-progress, 0%);border-radius:2px;background:var(--nutrient-accent, var(--color-primary-green))}.nutrient-val{font-size:11px;color:var(--color-black)}.sources-link{display:flex;justify-content:flex-end;margin-top:8px}.sources-link button{border:none;background:none;font-family:var(--font-nunito);font-size:11px;color:var(--color-text-tertiary);cursor:pointer;display:inline-flex;align-items:center;gap:4px}.meal-card{background:var(--color-surface-raised);border-radius:var(--component-card-radius);margin-bottom:var(--space-4);overflow:hidden;box-shadow:var(--shadow-raised-md);border:1px solid var(--color-surface-border)}.meal-card__head{display:flex;align-items:center;gap:12px;padding:var(--space-4)}.meal-card__icon{width:28px;height:28px;flex-shrink:0}.meal-card__title{flex:1;font-size:18px;font-weight:500;color:var(--color-black);margin:0;text-align:left}.meal-card__chev{border:none;background:none;color:var(--color-muted-soft);cursor:pointer;width:36px;height:36px;border-radius:50%;padding:0}.meal-card__add{width:40px;height:40px;border-radius:12px;border:none;background:var(--color-primary-green);color:var(--color-white);font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.meal-card__summary{padding:0 var(--space-4) var(--space-4);font-size:14px;color:var(--color-muted-soft);margin:0}.meal-card__body{padding:0 var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.meal-row{display:flex;gap:12px;padding:12px;background:var(--color-card-bg);border-radius:var(--radius-md);align-items:center}.meal-row__img{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;background:var(--color-border)}.meal-row__emoji{width:60px;height:60px;border-radius:var(--radius-sm);background:var(--color-avatar-bg);display:flex;align-items:center;justify-content:center;font-size:28px}.meal-row__meta{flex:1;min-width:0}.meal-row__name{font-size:16px;font-weight:500;color:var(--color-black);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.meal-row__protein{font-size:18px;font-weight:700;color:var(--color-primary-green);margin:0 0 4px}.meal-row__micro{font-size:12px;color:var(--color-muted-soft);margin:0}.recipes-title-bar{height:44px;display:flex;align-items:center;margin:-4px 0 0;padding:0 var(--space-1)}.recipes-title-bar h1{font-size:22px;font-weight:700;margin:0;color:var(--color-text-primary)}.filter-section{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-5)}.filter-section__label{font-family:var(--font-baloo);font-size:14px;font-weight:600;color:var(--color-text-primary);width:50px;flex-shrink:0;padding-left:8px}.filter-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 4px 8px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-scroll::-webkit-scrollbar{display:none}.filter-tag{flex-shrink:0;min-width:65px;max-width:85px;padding:8px 4px;font-family:var(--font-nunito);font-size:12px;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-secondary);cursor:pointer;text-align:center;line-height:1.2;min-height:40px}.filter-tag--on{background:var(--color-surface);border:2px solid var(--color-primary-green);color:var(--color-recipe-green)}.recipe-list{display:flex;flex-direction:column;gap:var(--space-7);padding-bottom:var(--space-6)}.recipe-card-h{display:flex;width:100%;min-height:128px;background:var(--color-surface-raised-strong);border-radius:var(--component-card-radius);border:none;padding:0;cursor:pointer;text-align:left;overflow:hidden;font:inherit;box-shadow:var(--shadow-raised-lg);border:1px solid var(--color-surface-border-strong);transition:var(--component-transition)}.recipe-card-h:active{transform:scale(var(--component-press-scale));box-shadow:var(--shadow-press-soft)}.recipe-card-h__img{width:128px;height:128px;object-fit:cover;flex-shrink:0;background:var(--color-card-bg)}.recipe-card-h__body{flex:1;padding:12px 12px 12px 16px;display:flex;flex-direction:column;justify-content:center;gap:12px;min-width:0}.recipe-card-h__name{font-size:22px;font-weight:500;color:var(--color-on-surface);margin:0;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-card-h__meta{font-size:14px;font-weight:500;color:var(--color-text-secondary);margin:0}.recipe-card-h__tags{font-size:16px;font-weight:600;color:var(--color-recipe-green);margin:0;line-height:1.3}.load-trigger{display:flex;justify-content:center;padding:16px;color:var(--color-text-secondary);font-size:14px}.load-trigger--hidden{display:none}.impact-hint{display:flex;align-items:flex-start;gap:var(--space-2);padding:0 var(--space-1);margin-bottom:var(--space-2)}.impact-hint__icon{color:var(--color-orange-accent);font-size:14px;margin-top:2px}.impact-hint__text{margin:0}.energy-card{background:var(--color-surface-raised);border-radius:var(--component-card-radius);padding:var(--component-card-padding) var(--space-4);box-shadow:var(--shadow-raised-lg);border:1px solid var(--color-surface-border);display:flex;flex-direction:column;gap:18px;margin-bottom:var(--space-4)}.energy-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.energy-card__title{margin:4px 0 0;font-size:24px;line-height:1.08;color:var(--color-heading-strong)}.energy-card__hint{max-width:220px;padding:10px 12px;border-radius:14px;background:var(--color-green-wash);color:var(--color-primary-green);font-size:12px;font-weight:700;line-height:1.45}.energy-card__stats{display:flex;align-items:stretch}.energy-card__slots{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.energy-slot{display:flex;align-items:center;justify-content:center;gap:6px;min-height:40px;border-radius:999px;background:#ffffffa3;border:1px solid var(--color-surface-border);color:var(--color-text-secondary);font-size:13px;font-weight:700}.energy-slot--done{background:var(--color-green-wash);border-color:var(--color-green-border);color:var(--color-primary-green)}.energy-slot__emoji{font-size:15px}.energy-progress{display:flex;flex-direction:column;gap:10px;padding:14px 16px;border-radius:18px;background:#ffffff94;border:1px solid var(--color-surface-border)}.energy-progress__copy{display:flex;flex-direction:column;gap:4px}.energy-progress__eyebrow{margin:0;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary)}.energy-progress__text{margin:0;font-size:14px;font-weight:700;line-height:1.45;color:var(--color-text-primary)}.energy-progress__bar{width:100%;height:8px;border-radius:999px;overflow:hidden;background:var(--color-progress-track)}.energy-progress__bar i{display:block;width:var(--w);height:100%;border-radius:inherit;background:linear-gradient(90deg,#8add8b 0%,var(--color-primary-green) 100%)}.energy-stat{flex:1;text-align:center}.energy-stat__big{font-size:28px;font-weight:700;color:var(--color-text-primary)}.energy-stat__big span{font-size:16px;font-weight:500;color:var(--color-text-secondary)}.energy-stat__label{font-size:12px;font-weight:500;color:var(--color-text-secondary);margin-top:4px}.energy-stat__med{font-size:20px;font-weight:600;color:var(--color-text-secondary)}.energy-div{width:1px;background:var(--color-border);margin:0 4px;align-self:stretch;min-height:40px}.animal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.sanctuary-card{display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:22px;background:linear-gradient(180deg,#ffffffeb,#f8fbf6f5),url(/ios-assets/garden-background.png) center/cover no-repeat;border:1px solid var(--color-surface-border);box-shadow:var(--shadow-raised-soft)}.sanctuary-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sanctuary-card__title{margin:4px 0 0;font-size:22px;color:var(--color-heading-strong)}.sanctuary-card__meta{padding:7px 10px;border-radius:999px;background:var(--color-card-bg);color:var(--color-text-secondary);font-size:12px;font-weight:700}.inbox-card{display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:22px;background:linear-gradient(180deg,#fffffff5,#f9f9f9fa);border:1px solid var(--color-surface-border);box-shadow:var(--shadow-raised-soft)}.inbox-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.inbox-card__header-copy{min-width:0}.inbox-card__icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--color-green-wash);color:var(--color-primary-green);font-size:24px;flex-shrink:0}.inbox-card__view-all{display:inline-flex;align-items:center;gap:4px;border:none;padding:0;background:transparent;color:var(--color-primary-green);font:inherit;font-size:14px;font-weight:700;cursor:pointer}.inbox-card__title{margin:4px 0 0;font-size:20px;color:var(--color-heading-strong)}.inbox-card__text{margin:0;color:var(--color-text-secondary);font-size:14px;line-height:1.55}.animal-tile{min-height:212px;border-radius:20px;background:var(--color-surface);border:1px solid var(--color-surface-border);display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:10px;padding:16px;font:inherit;text-align:left;cursor:pointer;position:relative;overflow:hidden;transition:var(--component-transition)}.animal-tile--ready{background:linear-gradient(180deg,#fffffffa,#f0f9f4fa);border-color:var(--color-green-border-strong)}.animal-tile--locked{background:linear-gradient(180deg,#fffffff5,#f6f7f4fa)}.animal-tile__badge{padding:5px 8px;border-radius:999px;background:#006e0314;color:var(--color-primary-green);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.animal-tile__emoji{font-size:38px;line-height:1}.animal-tile__title-row{display:flex;flex-direction:column;gap:2px}.animal-tile__name{font-size:17px;font-weight:800;color:var(--color-text-primary)}.animal-tile__cost{font-size:12px;font-weight:700;color:var(--color-text-secondary)}.animal-tile__hint{margin:0;font-size:13px;line-height:1.5;color:var(--color-text-secondary)}.animal-tile__cta{margin-top:auto;display:inline-flex;align-items:center;min-height:38px;padding:0 12px;border-radius:999px;background:#14340f14;color:var(--color-text-primary);font-size:12px;font-weight:800}.animal-tile:hover{transform:translateY(-1px);box-shadow:var(--shadow-card-soft)}.animal-tile:active{transform:scale(var(--component-press-scale))}.animal-tile:focus-visible,.inbox-card__view-all:focus-visible,.inbox-letter:focus-visible{outline:none;box-shadow:var(--component-focus-ring)}.inbox-letter{display:flex;align-items:center;gap:14px;width:100%;padding:14px;border:1px solid var(--color-surface-border);border-radius:20px;background:var(--color-surface);text-align:left;font:inherit;cursor:pointer;transition:var(--component-transition)}.inbox-letter__badge-wrap{position:relative;flex-shrink:0}.inbox-letter__badge{position:absolute;top:-6px;right:-8px;min-width:42px;height:20px;padding:0 6px;border-radius:999px;background:#ff4d4f;color:var(--color-white);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800}.inbox-letter__copy{min-width:0;flex:1}.inbox-letter__eyebrow{margin:0 0 4px;font-size:12px;font-weight:800;color:var(--color-primary-green)}.inbox-letter__author{margin:0 0 6px;font-size:15px;font-weight:800;color:var(--color-text-primary)}.inbox-letter__preview{margin:0;font-size:13px;line-height:1.5;color:var(--color-text-secondary)}.inbox-letter__chevron{color:var(--color-text-tertiary);flex-shrink:0}.inbox-letter:hover{transform:translateY(-1px);box-shadow:var(--shadow-card-soft)}.pwa-note{margin-top:24px;padding:16px;background:var(--color-surface);border-radius:var(--component-card-radius);font-size:13px;color:var(--color-text-secondary);line-height:1.45}.profile-summary{background:var(--color-surface);border-radius:var(--component-card-radius);padding:var(--component-card-padding);margin-bottom:var(--space-6);box-shadow:var(--shadow-card)}.profile-summary__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.profile-summary__hi{font-size:18px;font-weight:600;margin:0}.profile-avatar{width:40px;height:40px;border-radius:20px;background:var(--color-avatar-bg);display:flex;align-items:center;justify-content:center;color:var(--color-muted-soft)}.profile-stats{display:flex;align-items:stretch}.profile-stat{flex:1;text-align:center}.profile-stat__val{font-size:22px;font-weight:700;color:var(--color-recipe-green)}.profile-stat__lbl{font-size:12px;font-weight:500;color:var(--color-text-secondary);margin-top:4px}.profile-stat-div{width:1px;background:var(--color-overlay);margin:4px 0}.chart-card{background:var(--color-surface);border-radius:var(--component-card-radius);padding:var(--component-card-padding);margin-bottom:var(--space-5);box-shadow:var(--shadow-card-soft)}.chart-card__title{font-size:16px;font-weight:600;margin:0 0 var(--space-4)}.chart-bars{display:flex;align-items:flex-end;justify-content:space-between;gap:6px;min-height:108px;padding-top:8px}.chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:6px;min-width:0}.chart-bar{width:100%;max-width:36px;background:var(--color-primary-green);border-radius:4px 4px 0 0;height:var(--bar-h, 4px);min-height:4px;opacity:.85;flex-shrink:0}.chart-card__note{margin:12px 0 0;font-size:12px}.chart-dow{font-size:10px;font-weight:600;color:var(--color-text-tertiary);font-family:var(--font-baloo)}.scan-header{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px 10px;padding-top:max(12px,calc(12px + env(safe-area-inset-top)));background:var(--color-white);border-bottom:1px solid rgba(0,0,0,.04)}.scan-header__back,.scan-header__action,.scan-header__spacer{width:44px;height:44px;border-radius:50%;flex:0 0 44px}.scan-header__back,.scan-header__action{border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center}.scan-header__actions{display:flex;align-items:center;gap:4px;flex:0 0 auto}.scan-header__action{color:var(--color-text-primary)}.scan-header__action--active{color:#d59c00}.scan-header__back:disabled,.scan-header__action:disabled{opacity:.42;cursor:not-allowed}.scan-body{padding:16px;max-width:520px;margin:0 auto}.scan-screen{min-height:calc(100dvh - env(safe-area-inset-bottom,0));display:flex;flex-direction:column;background:var(--color-background);margin:-14px -14px -8px}.scan-screen--analysis,.scan-screen--result,.scan-screen--error{background:linear-gradient(180deg,#eef2eb 0%,var(--color-background) 32%,var(--color-background) 100%)}.scan-title{font-size:22px;font-weight:700;margin:0 0 8px}.scan-title--flush{margin:0;position:absolute;left:88px;right:88px;text-align:center;pointer-events:none}.scan-camera-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:28px 20px 12px;background:radial-gradient(circle at 50% 24%,#ffffff14,#fff0 30%),linear-gradient(180deg,#29342b,#202721)}.scan-camera-viewport{width:100%;max-width:440px;min-height:min(52dvh,540px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}.scan-live-preview{position:relative;width:100%;max-width:440px;aspect-ratio:.88;min-height:min(52dvh,540px);border-radius:28px;overflow:hidden;background:#0f1611;box-shadow:0 28px 48px #00000038;display:flex;align-items:center;justify-content:center}.scan-camera-video{width:100%;height:100%;object-fit:cover;display:block}.scan-live-preview__scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000002e,#0000000a 32%,#0000002e)}.scan-focus-frame{position:relative;width:min(58vw,192px);height:min(58vw,192px);z-index:1;display:flex;align-items:center;justify-content:center}.scan-focus-frame__img{width:100%;height:100%;object-fit:contain;image-rendering:-webkit-optimize-contrast}.scan-camera-copy{margin:0;font-size:16px;color:#ffffffeb;text-align:center;text-shadow:0 1px 6px rgba(0,0,0,.3);position:absolute;left:20px;right:20px;bottom:22px;z-index:1}.scan-camera-fallback{width:min(100%,420px);padding:28px 24px;border-radius:28px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);text-align:center;color:var(--color-white)}.scan-camera-fallback__icon{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff1f;font-size:28px}.scan-camera-fallback__icon-img{width:30px;height:30px;object-fit:contain;image-rendering:-webkit-optimize-contrast}.scan-camera-fallback__title{margin:0 0 10px;font-family:var(--font-baloo);font-size:28px;line-height:1.05}.scan-camera-fallback__copy{margin:0;color:#ffffffd6;line-height:1.5}.scan-camera-fallback__button{margin-top:18px;background:#ffffffe6}.scan-camera-dock{display:grid;grid-template-columns:80px 1fr 80px;align-items:center;gap:12px;padding:14px 20px calc(18px + env(safe-area-inset-bottom,0));background:var(--color-white);border-top:1px solid rgba(0,0,0,.04)}.scan-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.scan-library-action,.scan-library-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:48px;color:var(--color-text-tertiary);font-size:12px}.scan-library-action{gap:4px;cursor:pointer}.scan-library-action__icon-img{width:24px;height:24px;object-fit:contain;image-rendering:-webkit-optimize-contrast}.scan-capture-button{justify-self:center;width:76px;height:76px;border-radius:50%;border:4px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;background:transparent}.scan-capture-button__inner{width:60px;height:60px;border-radius:50%;background:var(--color-primary-green);box-shadow:0 10px 22px #006e033d}.scan-capture-button:disabled{opacity:.45;cursor:not-allowed}.scan-camera-caption{padding:0 20px 14px;background:var(--color-white);text-align:center}.scan-meal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:flex-end;justify-content:center}.scan-meal-overlay__backdrop,.scan-meal-overlay__scrim{position:absolute;top:0;right:0;bottom:0;left:0}.scan-meal-overlay__backdrop{background-position:center;background-size:cover;filter:blur(20px);transform:scale(1.06)}.scan-meal-overlay__scrim{background:#00000057}.scan-meal-sheet{position:relative;z-index:1;width:min(560px,100%);border-radius:28px 28px 0 0;background:var(--color-white);padding:12px 20px calc(28px + env(safe-area-inset-bottom,0));box-shadow:var(--shadow-raised-xl)}.scan-meal-sheet__grabber{width:38px;height:5px;border-radius:999px;margin:0 auto 18px;background:#00000029}.scan-meal-sheet__title{margin:0 0 18px;text-align:center;font-size:20px;font-weight:800;color:var(--color-primary-green)}.scan-meal-options{display:flex;flex-direction:column;gap:0;overflow:hidden;border-radius:16px;border:1px solid var(--color-border);background:var(--color-white)}.scan-meal-option{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:56px;padding:0 18px;border:none;border-bottom:1px solid var(--color-border);background:transparent;color:var(--color-text-primary);font:inherit;font-weight:700;cursor:pointer}.scan-meal-option:last-child{border-bottom:none}.scan-meal-option--active{color:var(--color-primary-green);background:var(--color-green-wash)}.scan-meal-option__check{color:var(--color-primary-green);font-size:16px}.scan-meal-sheet__actions{display:flex;gap:12px;margin-top:20px}.scan-meal-sheet__actions .btn{flex:1}.scan-analysis-view{flex:1;display:flex;flex-direction:column;justify-content:center;gap:22px;padding:28px 20px 48px}.scan-analysis-photo-shell{position:relative;width:min(100%,520px);aspect-ratio:3 / 4;margin:0 auto;border-radius:32px;overflow:hidden;background:var(--color-surface);box-shadow:0 20px 40px #00000029}.scan-analysis-photo-shell--empty{display:flex;align-items:center;justify-content:center}.scan-analysis-placeholder{width:40%;aspect-ratio:1;border-radius:28px;border:2px dashed var(--color-border)}.scan-analysis-photo{width:100%;height:100%;object-fit:cover}.scan-analysis-laser{position:absolute;left:0;right:0;top:14%;height:6px;background:linear-gradient(180deg,#00a80900,#00a809db,#00a80900);box-shadow:0 0 12px #00a80966;animation:scanSweep 2.1s ease-in-out infinite alternate}.scan-analysis-copy{text-align:center;display:flex;flex-direction:column;gap:12px}.scan-analysis-copy h2{margin:0;font-family:var(--font-baloo);font-size:30px;line-height:1.05;color:var(--color-primary-green)}.scan-progress{width:min(280px,100%);height:8px;margin:4px auto 0;border-radius:999px;overflow:hidden;background:#ffffffa6}.scan-progress i{display:block;width:40%;height:100%;border-radius:inherit;background:var(--color-primary-green);animation:scanProgress 1.1s ease-in-out infinite alternate}.scan-result-scroll{flex:1;overflow:auto;padding-bottom:calc(118px + env(safe-area-inset-bottom,0))}.scan-result-photo-wrap{margin:0 0 16px;background:linear-gradient(180deg,#fafcf8,#eef3eb)}.scan-result-photo{width:100%;height:min(44vh,320px);object-fit:cover;display:block}.scan-result-head,.scan-status-card,.scan-hero-card,.scan-micro-grid,.scan-stat-pills,.scan-section-card{margin-left:20px;margin-right:20px}.scan-result-head{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.scan-result-head__row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.scan-result-title{margin:0;font-family:var(--font-nunito);font-size:24px;font-weight:700;color:var(--color-text-primary)}.scan-result-subtitle{margin:0;color:var(--color-text-secondary);font-size:14px}.scan-inline-edit{border:none;background:var(--color-green-wash);color:var(--color-primary-green);border-radius:999px;padding:8px 12px;font:inherit;font-size:12px;font-weight:800;cursor:pointer;flex-shrink:0}.scan-warning-banner{margin:0 20px 16px;padding:14px 16px;border-radius:16px;background:var(--color-orange-bg);color:var(--color-orange-accent);font-size:13px;font-weight:700}.scan-hero-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px;border-radius:22px;background:var(--color-white);box-shadow:var(--shadow-card-soft);margin-bottom:14px}.scan-card-label{margin:0 0 6px;font-size:14px;color:var(--color-text-secondary)}.scan-hero-value{font-family:var(--font-baloo);font-size:44px;line-height:.95;color:var(--color-heading-strong)}.scan-hero-value span{font-family:var(--font-nunito);font-size:18px;font-weight:700;color:var(--color-text-secondary);margin-left:4px}.scan-hero-icon{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-green-wash);color:var(--color-primary-green);font-size:24px}.scan-micro-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:14px}.scan-micro-card{padding:14px;border-radius:18px;background:var(--color-white);box-shadow:var(--shadow-card-soft)}.scan-micro-card__label{margin:0 0 10px;font-size:12px;font-weight:800;color:var(--color-primary-green);text-transform:uppercase;letter-spacing:.04em}.scan-micro-card strong{font-family:var(--font-baloo);font-size:24px;line-height:1;color:var(--color-heading-strong)}.scan-micro-card strong span{margin-left:3px;font-family:var(--font-nunito);font-size:11px;font-weight:700;color:var(--color-text-secondary)}.scan-stat-pills{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}.scan-stat-pill{display:flex;flex-direction:column;gap:4px;padding:14px 16px;border-radius:18px;background:var(--color-surface-tint)}.scan-stat-pill strong{font-size:18px;color:var(--color-heading-strong)}.scan-stat-pill span{font-size:12px;color:var(--color-text-secondary)}.scan-section-card{padding:18px;border-radius:22px;background:var(--color-white);box-shadow:var(--shadow-card-soft);margin-bottom:14px}.scan-section-card__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.scan-section-title{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary)}.scan-section-caption{font-size:12px;color:var(--color-text-tertiary)}.scan-section-card__tools{display:flex;align-items:center;gap:10px}.type-chips--result{margin:0}.scan-ingredient-list{display:flex;flex-direction:column;gap:10px}.scan-ingredient-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;background:var(--color-card-bg)}.scan-ingredient-item strong,.scan-ingredient-item span{color:var(--color-text-primary)}.scan-ingredient-item__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.scan-ingredient-item strong{display:block;font-size:15px;margin-bottom:3px}.scan-ingredient-item small{color:var(--color-text-tertiary)}.scan-ingredient-action{border:none;background:transparent;color:var(--color-primary-green);font:inherit;font-size:12px;font-weight:800;cursor:pointer;padding:0}.scan-ingredient-action--danger{color:var(--color-error)}.scan-empty-note{margin:0}.scan-result-actions{position:fixed;left:50%;bottom:0;transform:translate(-50%);display:flex;gap:12px;width:min(560px,100%);padding:16px 20px calc(24px + env(safe-area-inset-bottom,0));background:linear-gradient(180deg,rgba(243,242,245,0) 0%,rgba(243,242,245,.9) 24%,var(--color-white) 100%)}.scan-status-card{margin-top:24px;padding:22px 20px;border-radius:24px;background:var(--color-white);box-shadow:var(--shadow-card-soft);text-align:center}.scan-status-card__icon{width:56px;height:56px;margin:0 auto 14px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-orange-bg);color:var(--color-orange-accent);font-size:28px;font-weight:800}.type-chips{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.type-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-background);font-family:var(--font-nunito);font-size:13px;font-weight:600;cursor:pointer;color:var(--color-text-secondary);min-height:40px}.type-chip--on{background:var(--color-surface-variant);border-color:var(--color-primary-green);color:var(--color-primary-green)}.file-pill{display:flex;align-items:center;justify-content:center;min-height:140px;border:2px dashed var(--color-green-light);border-radius:var(--component-card-radius);background:var(--color-surface);font-weight:600;color:var(--color-primary-green);font-size:15px}.file-label input{position:absolute;width:0;height:0;opacity:0}.file-label--stack{display:block}.file-label--md{margin-top:16px}.file-label--lg{margin-top:20px}.scan-section-label{margin-top:12px}.scan-copy--sm{font-size:13px}@keyframes scanSweep{0%{transform:translateY(-18%)}to{transform:translateY(260%)}}@keyframes scanProgress{0%{transform:translate(-70%)}to{transform:translate(170%)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--component-btn-radius);padding:var(--component-btn-padding-y) var(--component-btn-padding-x);font-size:16px;font-weight:600;font-family:var(--font-nunito);cursor:pointer;background:var(--color-primary-green);color:var(--color-white);text-decoration:none;width:100%;min-height:var(--component-touch-target);box-shadow:var(--shadow-card-soft)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn--section-top{margin-top:16px}.btn--section-top-sm{margin-top:12px}.btn--section-bottom{margin-bottom:16px}.btn--secondary{background:var(--color-surface);color:var(--color-primary-green);border:2px solid var(--color-green-light)}.btn--ghost{background:transparent;color:var(--color-primary-green);border:none;width:auto;padding:8px 12px;box-shadow:none}.muted{color:var(--color-text-secondary);font-size:14px;line-height:1.4}.danger{color:var(--color-error)}.tabbar-outer{position:fixed;left:0;right:0;bottom:0;z-index:40;height:calc(118px + env(safe-area-inset-bottom,0));pointer-events:none}.tabbar-row{pointer-events:auto;position:absolute;left:14px;right:14px;bottom:calc(10px + env(safe-area-inset-bottom,0));height:90px;display:flex;justify-content:center}.tabbar-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;width:100%;max-width:560px;position:relative;border-radius:34px;background:var(--gradient-tabbar-surface);backdrop-filter:blur(26px) saturate(160%);-webkit-backdrop-filter:blur(26px) saturate(160%);border:1px solid var(--glass-stroke-soft);box-shadow:var(--glass-inner-shadow),var(--glass-shadow)}.tabbar-inner:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:33px;background:var(--gradient-tabbar-sheen);pointer-events:none}.tabbar-inner:after{content:"";position:absolute;left:24px;right:24px;top:8px;height:16px;border-radius:999px;background:var(--gradient-tabbar-toplight);opacity:.8;pointer-events:none}.tab-cluster{display:flex;align-items:center;gap:14px;position:relative;z-index:1}.tab-cluster--right{gap:14px}.tab-item{flex:0 0 72px;display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--color-tabbar-unselected);font-size:11px;font-weight:700;font-family:system-ui,-apple-system,sans-serif;padding:0;margin:0;border:none;background:none;cursor:pointer;position:relative;transition:transform .18s ease,color .18s ease}.tab-item:active{transform:scale(.96)}.tab-item__chrome{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:72px;padding:8px 12px;border-radius:24px;transition:background .22s ease,box-shadow .22s ease,border-color .22s ease,transform .22s ease,color .22s ease;border:1px solid transparent}.tab-item__chrome:before{content:"";position:absolute;inset:1px 8px auto;height:14px;border-radius:999px;background:var(--gradient-tab-active-gloss);opacity:0;transition:opacity .22s ease}.tab-item svg{width:24px;height:24px;position:relative;z-index:1}.tab-item__icon{width:24px;height:24px;object-fit:contain;position:relative;z-index:1;image-rendering:-webkit-optimize-contrast}.tab-item__label{position:relative;z-index:1;letter-spacing:-.01em}.tab-item--active{color:var(--color-tabbar-selected)}.tab-item--active .tab-item__chrome{background:var(--gradient-tab-active);border-color:var(--glass-stroke-strong);box-shadow:var(--shadow-tab-active);transform:translateY(-2px)}.tab-item--active .tab-item__chrome:before{opacity:1}.tabbar-gap{width:86px;flex-shrink:0}.tabbar-fab{pointer-events:auto;position:absolute;left:50%;bottom:calc(36px + env(safe-area-inset-bottom,0));transform:translate(-50%) translateY(-30px);width:66px;height:66px;border-radius:50%;border:1px solid var(--glass-stroke-bright);background:var(--gradient-fab);color:var(--color-white);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-fab);transition:var(--component-transition)}.tabbar-fab:before{content:"";position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:50%;background:var(--gradient-fab-halo);z-index:-1}.tabbar-fab:active{transform:translate(-50%) translateY(-29px) scale(calc(var(--component-press-scale) - .015))}.tabbar-fab__icon{width:24px;height:24px;object-fit:contain;position:relative;z-index:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-scrim-strong);z-index:50;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:modalFadeIn .22s ease}.meal-save-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:flex;align-items:center;justify-content:center;padding:24px}.meal-save-overlay__scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000094;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.meal-save-overlay__card{position:relative;z-index:1;width:min(420px,100%);padding:28px 24px 24px;border-radius:28px;background:#fffffff5;box-shadow:var(--shadow-raised-xl);text-align:center;animation:screenSlideIn .26s cubic-bezier(.2,.8,.2,1)}.meal-save-overlay__badge{width:88px;height:88px;margin:0 auto 18px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#218a3c1f;color:var(--color-success-green);font-size:40px;box-shadow:inset 0 1px #ffffffd9}.meal-save-overlay__badge--earned{background:#006e0324;color:var(--color-primary-green)}.meal-save-overlay__title{margin:0 0 10px;font-family:var(--font-baloo);font-size:32px;line-height:1.04;color:var(--color-heading-strong)}.meal-save-overlay__copy{margin:0;color:var(--color-text-secondary);font-size:15px;line-height:1.55}.meal-save-overlay__actions{display:flex;gap:12px;margin-top:22px}.meal-save-overlay__actions .btn{flex:1}.modal-sheet{background:var(--color-surface);border-radius:var(--component-sheet-radius) var(--component-sheet-radius) 0 0;max-height:92vh;overflow:auto;width:100%;max-width:560px;padding:12px 20px calc(24px + env(safe-area-inset-bottom,0));animation:slideUp .22s ease-out;box-shadow:var(--shadow-raised-xl)}.modal-sheet--compact{max-height:70vh}.modal-backdrop--recipe,.modal-backdrop--settings{align-items:stretch}.modal-sheet--recipe{width:100%;max-width:none;height:100dvh;max-height:100dvh;border-radius:0;padding:0;overflow:auto;background:radial-gradient(circle at top center,var(--page-glow-white) 0%,rgba(255,255,255,0) 40%),linear-gradient(180deg,var(--page-bg-top) 0%,var(--color-surface) 38%,var(--page-bg-bottom) 100%);animation:screenSlideIn .26s cubic-bezier(.2,.8,.2,1)}.modal-sheet--settings{width:100%;max-width:none;height:100dvh;max-height:100dvh;border-radius:0;padding:0;overflow:auto;background:var(--color-background);animation:screenSlideIn .26s cubic-bezier(.2,.8,.2,1)}.recipe-detail-topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:calc(56px + env(safe-area-inset-top,0));padding:calc(8px + env(safe-area-inset-top,0)) 16px 8px;background:#f3f2f500;transition:background .22s ease,box-shadow .22s ease}.recipe-detail-topbar__title{flex:1;text-align:center;font-size:15px;font-weight:800;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;transform:translateY(4px);transition:opacity .22s ease,transform .22s ease}.recipe-detail-topbar__back,.recipe-detail-topbar__spacer{flex:0 0 44px}.recipe-detail-topbar__spacer{height:44px}.modal-sheet--recipe-scrolled .recipe-detail-topbar{background:#f3f2f5cc;box-shadow:0 1px #0000000a;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.modal-sheet--recipe-scrolled .recipe-detail-topbar__title{opacity:1;transform:translateY(0)}.recipe-detail-hero{width:100%;max-width:none;border-radius:0;height:320px;object-fit:contain;object-position:center;display:block;padding:calc(58px + env(safe-area-inset-top,0)) 24px 0;background:radial-gradient(circle at top center,var(--page-glow-white-soft) 0%,rgba(255,255,255,0) 62%),linear-gradient(180deg,var(--color-note-bg) 0%,var(--color-surface) 100%)}.recipe-detail-wrap{position:relative;padding-bottom:var(--space-5)}.recipe-detail-hero-shell{position:relative}.recipe-detail-head{display:flex;flex-direction:column;gap:12px;padding:0 24px}.recipe-detail-eyebrow{margin:0;color:var(--color-primary-green);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.recipe-detail-meta{display:flex;flex-wrap:wrap;gap:10px}.recipe-detail-pill{display:inline-flex;align-items:center;min-height:34px;padding:6px 12px;border-radius:var(--component-chip-radius);background:var(--color-surface-raised);border:1px solid var(--glass-stroke-soft);color:var(--color-text-secondary);font-size:13px;font-weight:700}.recipe-detail-pill--accent{background:var(--color-green-wash);border-color:var(--color-green-border);color:var(--color-primary-green)}.recipe-detail-body{display:flex;flex-direction:column;gap:16px;padding:0 20px calc(28px + env(safe-area-inset-bottom,0))}.recipe-detail-section{background:var(--color-surface-raised);border:1px solid var(--glass-stroke-soft);border-radius:24px;padding:18px 18px 16px;box-shadow:var(--shadow-raised-soft)}.recipe-detail-title{font-family:var(--font-baloo);font-size:30px;font-weight:600;color:var(--color-on-surface);margin:0;line-height:1.08}.recipe-detail-title--tight{margin-top:8px}.detail-section-title{font-size:18px;font-weight:600;margin:0 0 12px}.ingredient-list,.steps{margin:0;padding-left:18px;color:var(--color-text-secondary);font-size:15px;line-height:1.6}.steps li{margin-bottom:12px}.date-modal__title{font-size:17px;font-weight:600;text-align:center;margin:16px 0}.date-modal__input{width:100%;padding:12px;font-size:16px;font-family:var(--font-nunito);border:1px solid var(--color-border);border-radius:var(--component-input-radius);margin-bottom:16px;min-height:var(--component-touch-target)}.modal-actions{display:flex;gap:12px;margin-top:8px}.modal-actions .btn{flex:1}@keyframes slideUp{0%{transform:translateY(16px);opacity:.9}to{transform:translateY(0);opacity:1}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes screenSlideIn{0%{opacity:.92;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;bottom:138px;left:50%;transform:translate(-50%);background:var(--color-on-surface);color:var(--color-white);padding:10px 18px;border-radius:999px;font-size:13px;z-index:60;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pageSlideForward{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes pageSlideBack{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:translate(0)}}@keyframes pageSheetIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-secondary)}.empty-state svg{width:48px;height:48px;margin-bottom:12px;opacity:.4}.layout--onboarding{padding-bottom:0}.layout--onboarding .main{max-width:680px;padding:24px 16px 48px}.onboarding-shell{min-height:calc(100dvh - 48px);display:flex;flex-direction:column;gap:24px;padding-bottom:calc(112px + env(safe-area-inset-bottom,0))}.onboarding-logo{width:72px;height:72px;object-fit:contain}.onboarding-progress{width:100%;height:6px;background:var(--color-progress-track);border-radius:999px;overflow:hidden}.onboarding-progress i{display:block;height:100%;background:linear-gradient(90deg,var(--color-secondary-green) 0%,var(--color-primary-green) 100%);border-radius:inherit}.onboarding-hero,.onboarding-story,.summary-card{background:var(--gradient-onboarding-panel);border:1px solid var(--color-green-border-soft);border-radius:var(--component-card-radius-lg);padding:28px;box-shadow:var(--shadow-onboarding-panel)}.onboarding-hero{position:relative;overflow:hidden}.onboarding-hero--cover{padding-top:20px}.onboarding-hero__cover{position:relative;margin:-28px -28px 20px;height:240px;overflow:hidden;display:flex;align-items:flex-start;justify-content:center;background:linear-gradient(180deg,#f0f7ecfa,#ffffffeb)}.onboarding-hero__bg{width:min(100%,401px);height:auto;max-height:100%;object-fit:contain;object-position:center top;image-rendering:-webkit-optimize-contrast}.onboarding-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f1f111a,#fff0 46%,#ffffffeb)}.onboarding-hero__brand{display:flex;align-items:center;gap:14px;margin-bottom:16px}.onboarding-hero h1,.onboarding-copy h1,.onboarding-story h1{margin:0 0 12px;font-family:var(--font-baloo);font-size:34px;line-height:1.05;color:var(--color-hero-green)}.onboarding-hero p,.onboarding-copy p,.onboarding-story p{margin:0;color:var(--color-text-secondary);font-size:16px;line-height:1.5}.onboarding-hero__badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:var(--color-green-wash);color:var(--color-primary-green);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.onboarding-hero__stats,.impact-preview,.summary-card__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:22px}.onboarding-hero__stats div,.impact-preview div{display:flex;flex-direction:column;gap:4px;background:var(--color-stat-surface);border-radius:18px;padding:14px 16px}.onboarding-hero__stats strong,.impact-preview strong{font-size:24px;font-weight:800;color:var(--color-hero-green)}.onboarding-hero__stats span,.impact-preview span,.summary-card__label{color:var(--color-text-secondary);font-size:12px}.story-media{margin-top:18px;border-radius:24px;overflow:hidden;background:#ffffffb8;border:1px solid var(--color-surface-border);box-shadow:var(--shadow-card-soft);display:flex;justify-content:center;padding:12px}.story-media--impact{background:linear-gradient(180deg,#ffffffdb,#f0f9f4e0)}.story-media--comparison{background:linear-gradient(180deg,#f6f8f3f5,#fffffffa)}.story-media__img{display:block;width:100%;height:auto;image-rendering:-webkit-optimize-contrast}.story-media__img--phone{width:min(100%,335px)}.story-media__img--comparison{width:min(100%,560px)}.onboarding-copy{display:flex;flex-direction:column;gap:10px}.onboarding-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.onboarding-card{display:flex;flex-direction:column;gap:10px;align-items:flex-start;width:100%;min-height:140px;padding:18px;border:1px solid var(--color-green-border);border-radius:22px;background:var(--color-white);box-shadow:var(--shadow-card-soft);color:inherit;cursor:pointer;text-align:left}.onboarding-card strong{font-size:18px;line-height:1.15}.onboarding-card p{margin:0;color:var(--color-text-secondary);line-height:1.45}.onboarding-card--active{border-color:var(--color-green-border-strong);background:var(--gradient-onboarding-card-active);box-shadow:var(--shadow-onboarding-card-active)}.onboarding-card__row{display:flex;align-items:center;justify-content:space-between;width:100%}.onboarding-card__emoji{font-size:24px;min-height:28px}.onboarding-card__emoji--art{min-height:57px}.activity-level-icon{width:59px;height:57px;object-fit:contain;image-rendering:-webkit-optimize-contrast}.onboarding-card__check{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--color-onboarding-check-bg);color:var(--color-primary-green);font-size:14px;font-weight:800}.onboarding-input{display:flex;flex-direction:column;gap:10px;background:var(--color-white);border-radius:24px;padding:22px;box-shadow:var(--shadow-card-soft)}.onboarding-input span{font-size:13px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.onboarding-input input,.settings-select{width:100%;padding:14px 16px;font:inherit;color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--component-input-radius);background:var(--color-white);min-height:var(--component-touch-target)}.story-highlight{display:inline-flex;flex-direction:column;gap:4px;margin-top:18px;padding:16px 18px;border-radius:20px;background:var(--color-green-wash)}.story-highlight strong{font-size:34px;font-weight:800;color:var(--color-primary-green)}.story-list{margin:18px 0 0;padding-left:18px;color:var(--color-text-secondary)}.story-list li+li{margin-top:8px}.onboarding-actions{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom,0));transform:translate(-50%);width:min(648px,calc(100vw - 28px));margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:8;padding:10px;border-radius:22px;background:var(--glass-strong);border:1px solid var(--glass-stroke-soft);box-shadow:var(--glass-inner-shadow),var(--shadow-raised-soft);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%)}.onboarding-actions:before{content:"";position:absolute;inset:1px 16px auto;height:14px;border-radius:999px;background:linear-gradient(180deg,#ffffff9e,#fff0);pointer-events:none}.onboarding-actions__spacer,.onboarding-actions .btn{flex:1;min-width:0}.onboarding-actions .btn{position:relative;z-index:1;min-height:48px;border-radius:18px}.onboarding-actions .btn--secondary{background:#ffffffc2;border-color:#006e032e}.onboarding-actions__spacer{min-height:var(--component-touch-target)}.summary-card__grid{margin-top:0}.onboarding-finish-badge{display:inline-flex;align-items:center;justify-content:center;width:104px;height:104px;margin-bottom:16px;border-radius:28px;background:linear-gradient(180deg,#ffffffe6,#f4f9f1fa);box-shadow:var(--shadow-card-soft)}.onboarding-finish-badge__img{width:84px;height:84px;object-fit:contain;image-rendering:-webkit-optimize-contrast}.summary-card__grid div{display:flex;flex-direction:column;gap:6px;background:var(--color-surface-tint);border-radius:18px;padding:16px}.profile-summary__sub,.profile-summary__meta{margin:0;color:var(--color-text-secondary)}.profile-summary__badge-wrap{display:flex;align-items:center;gap:10px}.profile-summary__meta{margin-top:12px;font-size:13px}.profile-goals-card{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.goal-pill{display:flex;flex-direction:column;gap:6px;background:var(--color-white);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow-card-soft)}.goal-pill span{color:var(--color-text-secondary);font-size:12px}.goal-pill strong{font-size:18px}.purchase-shell{display:flex;flex-direction:column;gap:18px;max-width:640px;margin:0 auto}.purchase-topbar{display:flex;justify-content:flex-end}.purchase-close{border:none;background:transparent;color:var(--color-icon-subtle);font:inherit;cursor:pointer;min-height:var(--component-touch-target);padding:0 12px;border-radius:var(--component-chip-radius)}.purchase-hero,.purchase-card{background:var(--color-white);border-radius:var(--component-card-radius-lg);padding:24px;box-shadow:var(--shadow-card-soft)}.purchase-hero__badge{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;background:var(--color-membership-pro-bg);color:var(--color-membership-pro-fg);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin:0 auto 14px}.purchase-hero__art{display:flex;justify-content:center;margin:-24px -24px 18px;border-top-left-radius:inherit;border-top-right-radius:inherit;overflow:hidden;background:linear-gradient(180deg,#f4f9f1f0,#fffffffa)}.purchase-hero__art-img{width:min(100%,316px);max-width:316px;height:auto;object-fit:contain;image-rendering:-webkit-optimize-contrast}.purchase-hero h1{margin:0 0 16px;text-align:center;font-family:var(--font-baloo);font-size:34px;line-height:1.05}.purchase-features{display:flex;flex-direction:column;gap:12px;color:var(--color-heading-strong)}.purchase-card{display:flex;flex-direction:column;gap:12px}.purchase-plan{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;border:2px solid transparent;border-radius:18px;padding:18px;background:var(--color-purchase-plan-bg);cursor:pointer;text-align:left}.purchase-plan--active{border-color:var(--color-primary-green)}.purchase-plan strong{display:block;font-size:22px;color:var(--color-black)}.purchase-plan p{margin:4px 0 0;color:var(--color-outline)}.purchase-plan__right{display:flex;align-items:center;gap:10px}.purchase-plan__badge{padding:6px 10px;border-radius:999px;background:var(--color-green-wash-strong);color:var(--color-primary-green);font-size:12px;font-weight:800;text-transform:uppercase}.purchase-plan__radio{color:var(--color-primary-green);font-size:22px}.purchase-note{padding:14px 16px;border-radius:16px;background:var(--color-note-bg)}.purchase-note p{margin:6px 0 0;color:var(--color-text-secondary)}.purchase-cta{width:100%}.feedback-text{margin:0}.settings-stack{display:flex;flex-direction:column;gap:12px;margin:16px 0}.settings-panel{display:flex;flex-direction:column;gap:4px;padding:16px;border-radius:var(--radius-lg);background:var(--color-note-bg);border:1px solid var(--color-green-border-soft)}.settings-panel__head{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-copy{margin:6px 0 0}.settings-copy--first{margin-top:8px}.settings-copy--error{margin-top:10px}.settings-footnote{margin:10px 0 0;font-size:12px}.membership-chip{display:inline-flex;align-items:center;justify-content:center;min-width:60px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.membership-chip--pro{background:var(--color-membership-pro-bg);color:var(--color-membership-pro-fg)}.membership-chip--free{background:var(--color-membership-free-bg);color:var(--color-text-secondary)}.settings-row{display:flex;flex-direction:column;gap:8px}.settings-row__label{font-size:13px;font-weight:700;color:var(--color-text-secondary)}.settings-page{min-height:100dvh;background:var(--color-background)}.settings-page__nav{position:sticky;top:0;z-index:4;display:flex;align-items:center;justify-content:space-between;min-height:calc(58px + env(safe-area-inset-top,0));padding:calc(8px + env(safe-area-inset-top,0)) 16px 8px;background:#f3f2f5e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.settings-page__title{margin:0;font-size:18px;font-weight:800;color:var(--color-text-primary)}.settings-page__spacer{width:44px;height:44px}.settings-page__body{max-width:760px;margin:0 auto;padding:16px 16px calc(32px + env(safe-area-inset-bottom,0))}.settings-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.settings-group__label{margin:0;padding-left:16px;color:var(--color-primary-green);font-size:14px;font-weight:800}.settings-group__card{overflow:hidden;border-radius:16px;background:var(--color-white);box-shadow:var(--shadow-card-soft)}.settings-item{display:flex;align-items:center;gap:16px;width:100%;min-height:72px;padding:16px;background:transparent;border:none;color:inherit;text-align:left;text-decoration:none;cursor:pointer}.settings-item:disabled{cursor:not-allowed;opacity:.6}.settings-item__icon{display:flex;align-items:center;justify-content:center;flex:0 0 24px;width:24px;text-align:center;color:var(--color-primary-green);font-size:22px;line-height:1}.settings-item__icon-wrap{flex:0 0 36px;width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#006e0314}.settings-item__copy{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}.settings-item__copy strong{font-size:16px;font-weight:700;color:var(--color-text-primary)}.settings-item__copy small{color:var(--color-text-tertiary);font-size:12px;line-height:1.35}.settings-item__chevron{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-border);font-size:20px}.settings-divider{height:1px;margin-left:56px;background:var(--color-border)}.settings-inline-note{padding:0 16px 16px 56px;color:var(--color-text-secondary);font-size:12px;line-height:1.45}.settings-inline-note--error{color:var(--color-error)}.help-card{overflow:hidden}.help-item{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px;border:none;background:transparent;color:inherit;text-align:left;cursor:pointer;font:inherit}.help-item__question{font-size:16px;font-weight:700;color:var(--color-text-primary);line-height:1.4}.help-item__toggle{flex-shrink:0;color:var(--color-text-tertiary);font-size:18px;line-height:1}.help-item__answer{padding:0 16px 16px;color:var(--color-text-secondary);font-size:14px;line-height:1.55}.help-divider{margin-left:16px}.scan-edit-sheet{display:flex;flex-direction:column;gap:16px}.scan-edit-form{display:flex;flex-direction:column;gap:12px}.scan-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.scan-edit-field{display:flex;flex-direction:column;gap:8px;color:var(--color-text-secondary);font-size:13px;font-weight:700}.scan-edit-field input{width:100%;padding:14px 16px;border:1px solid var(--color-border);border-radius:var(--component-input-radius);font:inherit;color:var(--color-text-primary);background:var(--color-white)}.settings-picker{display:flex;align-items:center;gap:16px;min-height:72px;padding:16px}.settings-picker .settings-select{width:auto;min-width:132px;margin-left:auto}@media(hover:hover){.icon-btn:hover,.scan-header__back:hover,.scan-header__action:hover,.meal-card__chev:hover,.purchase-close:hover{background:var(--color-green-wash);color:var(--color-primary-green)}.meal-card__add:hover{transform:translateY(-1px);box-shadow:var(--shadow-action-green)}.filter-tag:hover,.type-chip:hover{border-color:var(--color-green-border-strong);color:var(--color-primary-green)}.recipe-card-h:hover{transform:translateY(-2px);box-shadow:var(--shadow-raised-xl)}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-raised-soft)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-primary-green)}.btn--ghost:hover:not(:disabled){background:var(--color-green-wash);box-shadow:none}.purchase-plan:hover,.onboarding-card:hover{border-color:var(--color-green-border-strong);box-shadow:var(--shadow-raised-soft)}.tab-item:hover .tab-item__chrome{background:var(--color-surface-tint);border-color:var(--glass-stroke)}.tabbar-fab:hover{box-shadow:var(--shadow-fab-hover)}}.scan-header__back:active,.scan-header__action:active,.meal-card__chev:active,.meal-card__add:active,.filter-tag:active,.type-chip:active,.btn:active:not(:disabled),.purchase-plan:active,.purchase-close:active,.onboarding-card:active{transform:scale(var(--component-press-scale))}.date-modal__input:focus-visible,.onboarding-input input:focus-visible,.settings-select:focus-visible{border-color:var(--color-primary-green)}@media(max-width:640px){.main{padding:14px 14px 8px}.layout{padding-bottom:calc(120px + env(safe-area-inset-bottom,0))}.screen-title-row{margin-bottom:var(--space-3)}.screen-title,.recipes-title-bar h1,.scan-title{font-size:20px}.page-shell{gap:var(--space-4)}.overview-card,.profile-summary,.chart-card,.purchase-hero,.purchase-card,.pwa-note{padding:var(--component-card-padding-compact)}.energy-card{padding:var(--component-card-padding-compact) var(--space-4)}.energy-card__head,.inbox-card__head{flex-direction:column}.energy-card__hint{max-width:none;width:100%}.energy-card__slots,.animal-grid{grid-template-columns:1fr}.animal-tile{min-height:188px}.meal-card__head,.meal-card__summary,.meal-card__body{padding-left:var(--component-card-padding-compact);padding-right:var(--component-card-padding-compact)}.meal-card__body,.recipe-list{gap:var(--space-5)}.filter-section{gap:var(--space-2);margin-bottom:var(--space-4)}.filter-section__label{width:44px;padding-left:4px}.recipe-card-h{min-height:120px}.recipe-card-h__img{width:120px;height:120px}.recipe-card-h__body{padding:14px;gap:10px}.recipe-card-h__name{font-size:20px}.recipe-card-h__tags{font-size:15px}.scan-body{padding:14px}.scan-screen{margin:-14px -14px -8px}.scan-camera-stage{padding:24px 16px 8px}.scan-camera-viewport,.scan-live-preview{min-height:min(48dvh,500px)}.scan-focus-frame{width:min(62vw,176px);height:min(62vw,176px)}.scan-camera-dock{grid-template-columns:72px 1fr 72px;padding:12px 16px calc(18px + env(safe-area-inset-bottom,0))}.scan-result-head,.scan-status-card,.scan-hero-card,.scan-micro-grid,.scan-stat-pills,.scan-section-card{margin-left:14px;margin-right:14px}.scan-result-title{font-size:22px}.scan-micro-grid{grid-template-columns:1fr}.scan-result-actions{width:100%;padding:14px 14px calc(18px + env(safe-area-inset-bottom,0))}.tabbar-row{left:10px;right:10px;bottom:calc(8px + env(safe-area-inset-bottom,0));height:86px}.tabbar-inner{padding:12px 14px;border-radius:30px}.tabbar-gap{width:74px}.tab-item{flex-basis:64px;font-size:10px}.tab-item__chrome{min-width:64px;padding:8px}.tab-cluster,.tab-cluster--right{gap:8px}.tabbar-fab{width:62px;height:62px;bottom:calc(32px + env(safe-area-inset-bottom,0))}.toast{bottom:132px}.modal-sheet{padding:12px 16px calc(22px + env(safe-area-inset-bottom,0))}.recipe-detail-hero{height:272px;padding:calc(52px + env(safe-area-inset-top,0)) 16px 0}.recipe-detail-head{padding:0 16px;gap:10px}.recipe-detail-topbar{padding-left:12px;padding-right:12px}.recipe-detail-title{font-size:26px}.recipe-detail-body{padding:0 14px calc(24px + env(safe-area-inset-bottom,0));gap:14px}.recipe-detail-section{padding:16px}.onboarding-hero h1,.onboarding-copy h1,.onboarding-story h1{font-size:30px}.onboarding-grid,.onboarding-hero__stats,.impact-preview,.summary-card__grid,.profile-goals-card{grid-template-columns:1fr}.onboarding-hero,.onboarding-story,.summary-card,.onboarding-input{padding:22px}.onboarding-hero__cover{margin:-22px -22px 18px;height:204px}.purchase-shell{gap:16px}.purchase-hero h1{font-size:30px}.purchase-hero__art{margin:-18px -18px 14px}.layout--onboarding .main{padding:18px 14px calc(128px + env(safe-area-inset-bottom,0))}.onboarding-shell{min-height:auto;gap:18px}.onboarding-actions{bottom:calc(10px + env(safe-area-inset-bottom,0));width:calc(100vw - 24px);padding:8px;border-radius:20px}.onboarding-actions .btn,.onboarding-actions__spacer{width:50%}.settings-page__body{padding:14px 14px calc(26px + env(safe-area-inset-bottom,0))}.settings-item{min-height:68px;gap:14px;padding:14px}.settings-inline-note{padding-left:52px;padding-right:14px}.settings-picker{align-items:flex-start;flex-wrap:wrap}.settings-picker .settings-select{width:100%;margin-left:0}}
