@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg: #f6f7fb;--surface: #ffffff;--surface-2: #f0f2f8;--border: rgba(0,0,0,.07);--border-md: rgba(0,0,0,.12);--text-primary: #0f1117;--text-secondary: #5c6478;--text-muted: #9aa0b4;--green: #16a34a;--green-light: #dcfce7;--green-2: #059669;--orange: #f97316;--orange-light:#fff0e4;--amber: #f59e0b;--amber-light: #fef9e7;--purple: #7c3aed;--purple-light:#f3eeff;--blue: #0891b2;--blue-light: #e0f2fe;--red: #ef4444;--green-dark: #15803d;--blue-dark: #0369a1;--amber-dark: #d97706;--violet: #8b5cf6;--indigo: #4f46e5;--indigo-light: #e0e7ff;--gradient-brand: linear-gradient(135deg, var(--green-dark) 0%, var(--blue) 100%);--gradient-login: linear-gradient(145deg, #052e16 0%, #14532d 40%, #0c4a6e 100%);--gradient-avatar: linear-gradient(135deg, var(--indigo-light), #dbeafe);--gradient-surface-soft: linear-gradient(135deg, #f0fdf4, #f0f9ff);--gradient-blue-soft: linear-gradient(135deg, var(--blue-light), #f0f9ff);--gradient-green: linear-gradient(135deg, var(--green), var(--green-2));--gradient-blue: linear-gradient(135deg, var(--blue), var(--blue-dark));--gradient-purple: linear-gradient(135deg, var(--violet), var(--purple));--gradient-ai: linear-gradient(135deg, #4f46e5, #0891b2);--gradient-ai-soft: linear-gradient(135deg, rgba(79,70,229,.08), rgba(8,145,178,.05));--gradient-amber: linear-gradient(135deg, var(--amber), var(--amber-dark));--gradient-meal-header: linear-gradient(135deg, rgba(22,163,74,.04) 0%, rgba(8,145,178,.03) 100%);--gradient-macro-kcal: linear-gradient(90deg, var(--orange), #fb923c);--gradient-macro-prot: linear-gradient(90deg, var(--green), #22c55e);--gradient-macro-carbs: linear-gradient(90deg, var(--amber), #fbbf24);--gradient-macro-fat: linear-gradient(90deg, var(--purple), #a78bfa);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 32px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06);--shadow-xl: 0 24px 64px rgba(0,0,0,.16), 0 8px 16px rgba(0,0,0,.08);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 22px;--radius-full: 9999px;--nav-h: 68px}[data-theme=dark]{--bg: #0f1117;--surface: #1a1d27;--surface-2: #252836;--border: rgba(255,255,255,.08);--border-md: rgba(255,255,255,.14);--text-primary: #f0f2f8;--text-secondary: #9aa0b4;--text-muted: #5c6478;--green: #22c55e;--green-light: rgba(34,197,94,.14);--green-2: #16a34a;--green-dark: #4ade80;--orange: #fb923c;--orange-light:rgba(251,146,60,.14);--amber: #fbbf24;--amber-light: rgba(251,191,36,.14);--amber-dark: #f59e0b;--purple: #a78bfa;--purple-light:rgba(167,139,250,.14);--violet: #c4b5fd;--blue: #22d3ee;--blue-light: rgba(34,211,238,.14);--blue-dark: #0891b2;--red: #f87171;--indigo: #818cf8;--indigo-light:rgba(129,140,248,.14);--gradient-avatar: linear-gradient(135deg, rgba(129,140,248,.2), rgba(96,165,250,.15));--gradient-surface-soft: linear-gradient(135deg, rgba(34,197,94,.07), rgba(34,211,238,.05));--gradient-blue-soft: linear-gradient(135deg, rgba(34,211,238,.1), rgba(34,211,238,.05));--gradient-meal-header: linear-gradient(135deg, rgba(34,197,94,.07) 0%, rgba(34,211,238,.04) 100%);--shadow-sm: 0 1px 3px rgba(0,0,0,.35), 0 1px 2px rgba(0,0,0,.25);--shadow-md: 0 4px 12px rgba(0,0,0,.45), 0 2px 4px rgba(0,0,0,.25);--shadow-lg: 0 12px 32px rgba(0,0,0,.55), 0 4px 8px rgba(0,0,0,.35);--shadow-xl: 0 24px 64px rgba(0,0,0,.65), 0 8px 16px rgba(0,0,0,.4)}[data-theme=dark] .app-header{background:#0f1117e0}[data-theme=dark] .bottom-nav{background:#1a1d27f0}[data-theme=dark] .user-avatar{box-shadow:0 0 0 2px var(--surface),0 0 0 3px #818cf84d}[data-theme=dark] .badge-gym{background:#6366f133;color:#a5b4fc}[data-theme=dark] .badge-deficit{background:#f8717126;color:#fca5a5}[data-theme=dark] .badge-super{background:#fbbf2426;color:var(--amber)}[data-theme=dark] .recipe-create-form{background:#a78bfa1a}[data-theme=dark] .icon-btn:hover,[data-theme=dark] .login-error{background:#f871711f}[data-theme=neon]{--bg: #050508;--surface: #1A1A22;--surface-2: #0E0E14;--border: rgba(255,255,255,.08);--border-md: rgba(255,255,255,.14);--text-primary: #F5F4EF;--text-secondary: #9B9BAA;--text-muted: #6B6B7A;--green: #C8FF57;--green-light: rgba(200,255,87,.12);--green-2: #A3E635;--green-dark: #D4FF6E;--on-green: #050508;--orange: #FF6B35;--orange-light:rgba(255,107,53,.14);--amber: #FFBD2E;--amber-light: rgba(255,189,46,.14);--amber-dark: #E5A815;--purple: #9B87F5;--purple-light:rgba(155,135,245,.14);--violet: #B8A4FC;--blue: #5B8BF5;--blue-light: rgba(91,139,245,.14);--blue-dark: #3B6FE0;--red: #FF5A5A;--indigo: #5B8BF5;--indigo-light:rgba(91,139,245,.14);--gradient-brand: linear-gradient(135deg, #A3E635 0%, #5B8BF5 100%);--gradient-avatar: linear-gradient(135deg, rgba(91,139,245,.25), rgba(155,135,245,.2));--gradient-surface-soft: linear-gradient(135deg, rgba(200,255,87,.07), rgba(91,139,245,.05));--gradient-blue-soft: linear-gradient(135deg, rgba(91,139,245,.12), rgba(91,139,245,.06));--gradient-meal-header: linear-gradient(135deg, rgba(200,255,87,.08) 0%, rgba(91,139,245,.05) 100%);--shadow-sm: 0 1px 3px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.35);--shadow-md: 0 4px 12px rgba(0,0,0,.6), 0 2px 4px rgba(0,0,0,.4);--shadow-lg: 0 12px 32px rgba(0,0,0,.7), 0 4px 8px rgba(0,0,0,.5);--shadow-xl: 0 24px 64px rgba(0,0,0,.8), 0 8px 16px rgba(0,0,0,.55)}[data-theme=neon] .btn{color:#050508;box-shadow:none}[data-theme=neon] .btn:hover{box-shadow:0 4px 16px #c8ff5759;opacity:1}[data-theme=neon] .btn-outline{color:var(--green);border-color:#c8ff574d;background:transparent}[data-theme=neon] .btn-outline:hover{background:#c8ff5712}[data-theme=neon] .btn-ai{color:#fff}[data-theme=neon] .btn-ghost{color:var(--text-secondary)}[data-theme=neon] .app-header{background:#050508e6;border-bottom-color:#c8ff571a}[data-theme=neon] .bottom-nav{background:#0e0e14f5;border-top-color:#ffffff0f}[data-theme=neon] .nav-item.active{color:var(--green)}[data-theme=neon] .nav-dot{background:var(--green);box-shadow:0 0 8px #c8ff5799}[data-theme=neon] .user-avatar{box-shadow:0 0 0 2px var(--surface),0 0 0 3px #c8ff574d}[data-theme=neon] .badge-gym{background:#5b8bf533;color:#93afff}[data-theme=neon] .badge-deficit{background:#ff5a5a26;color:#ff9090}[data-theme=neon] .badge-super{background:#ffbd2e26;color:var(--amber)}[data-theme=neon] .recipe-create-form{background:#9b87f514}[data-theme=neon] .icon-btn:hover{background:#ff5a5a1f;color:#ff9090}[data-theme=neon] .login-error{background:#ff5a5a1a;color:#ff9090}[data-theme=neon]{--gradient-login: linear-gradient(145deg, #050508 0%, #0E0E14 60%, #12121e 100%)}[data-theme=neon] .login-box{background:#1a1a22;border-color:#c8ff571f;box-shadow:0 24px 64px #000c,0 0 0 1px #c8ff570f}[data-theme=neon] .login-sub{color:var(--text-muted)}[data-theme=neon] .login-input-group input{background:#0e0e14;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=neon] .login-input-group input:focus{border-color:#c8ff5766;box-shadow:0 0 0 3px #c8ff5714}[data-theme=neon] .login-input-group input::-moz-placeholder{color:var(--text-muted)}[data-theme=neon] .login-input-group input::placeholder{color:var(--text-muted)}[data-theme=neon] .google-btn{background:#0e0e14!important;-webkit-text-fill-color:var(--text-primary)!important;color:var(--text-primary)!important;border-color:#ffffff1a!important}[data-theme=neon] .google-btn:hover{background:#1a1a22!important;border-color:#c8ff5733!important}[data-theme=neon] .login-success{background:#c8ff5714;border-color:#c8ff5733;color:var(--green)}[data-theme=neon] .login-forgot{color:var(--text-muted)}[data-theme=neon] .login-forgot:hover{color:var(--text-secondary)}[data-theme=neon] .app-loading{background:radial-gradient(ellipse at 50% 38%,rgba(200,255,87,.06) 0%,transparent 55%),linear-gradient(145deg,#050508,#0e0e14 60%,#12121e)}[data-theme=neon] .app-loading .msg{color:var(--text-secondary)}[data-theme=neon] .app-loading .dot-spin span{background:#c8ff57bf;box-shadow:0 0 8px #c8ff5766}[data-theme=neon] .recovery-overlay{background:var(--gradient-login)}[data-theme=neon] ::-webkit-scrollbar-track{background:var(--bg)}[data-theme=neon] ::-webkit-scrollbar-thumb{background:#c8ff5733;border-radius:4px}[data-theme=neon] ::-webkit-scrollbar-thumb:hover{background:#c8ff5759}[data-theme=blush]{--bg: #FDF6F0;--surface: #FFFFFF;--surface-2: #FFF0F4;--border: rgba(232,120,154,.12);--border-md: rgba(232,120,154,.22);--text-primary: #3D1A25;--text-secondary: #A0687A;--text-muted: #C4A0B0;--green: #E8789A;--green-light: rgba(232,120,154,.12);--green-2: #C4566F;--green-dark: #F0A0BC;--on-green: #ffffff;--orange: #D4956A;--orange-light:rgba(212,149,106,.14);--amber: #C9906A;--amber-light: rgba(201,144,106,.14);--amber-dark: #B07050;--purple: #C48AAA;--purple-light:rgba(196,138,170,.14);--violet: #D4A0C0;--blue: #9AAAD4;--blue-light: rgba(154,170,212,.14);--blue-dark: #7A8AB4;--red: #E07080;--indigo: #9AAAD4;--indigo-light:rgba(154,170,212,.14);--gradient-brand: linear-gradient(135deg, #E8789A 0%, #C48AAA 100%);--gradient-login: linear-gradient(145deg, #5A1020 0%, #8A2040 40%, #6A3060 100%);--gradient-avatar: linear-gradient(135deg, rgba(232,120,154,.25), rgba(196,138,170,.2));--gradient-surface-soft: linear-gradient(135deg, rgba(232,120,154,.07), rgba(196,138,170,.05));--gradient-blue-soft: linear-gradient(135deg, rgba(154,170,212,.12), rgba(154,170,212,.06));--gradient-meal-header: linear-gradient(135deg, rgba(232,120,154,.08) 0%, rgba(196,138,170,.05) 100%);--gradient-green: linear-gradient(135deg, #E8789A, #C4566F);--gradient-blue: linear-gradient(135deg, #9AAAD4, #7A8AB4);--gradient-purple: linear-gradient(135deg, #D4A0C0, #C48AAA);--gradient-ai: linear-gradient(135deg, #C48AAA, #9AAAD4);--gradient-amber: linear-gradient(135deg, #D4956A, #B07050);--shadow-sm: 0 1px 3px rgba(180,60,90,.08), 0 1px 2px rgba(180,60,90,.05);--shadow-md: 0 4px 12px rgba(180,60,90,.1), 0 2px 4px rgba(180,60,90,.06);--shadow-lg: 0 12px 32px rgba(180,60,90,.12), 0 4px 8px rgba(180,60,90,.08);--shadow-xl: 0 24px 64px rgba(180,60,90,.14), 0 8px 16px rgba(180,60,90,.1)}[data-theme=blush] .btn{color:#fff;box-shadow:none}[data-theme=blush] .btn:hover{box-shadow:0 4px 16px #e8789a59;opacity:1}[data-theme=blush] .btn-outline{color:var(--green);border-color:#e8789a4d;background:transparent}[data-theme=blush] .btn-outline:hover{background:#e8789a12}[data-theme=blush] .btn-ai{color:#fff}[data-theme=blush] .btn-ghost{color:var(--text-secondary)}[data-theme=blush] .app-header{background:#f9eae4f2;border-bottom-color:#e8789a2e}[data-theme=blush] .bottom-nav{background:#f9eae4f7;border-top-color:#e8789a26}[data-theme=blush] .nav-item.active{color:var(--green)}[data-theme=blush] .nav-dot{background:var(--green);box-shadow:0 0 6px #e8789a66}[data-theme=blush] .user-avatar{box-shadow:0 0 0 2px var(--surface),0 0 0 3px #e8789a4d}[data-theme=blush] .badge-gym{background:#9aaad42e;color:#7a8ab4}[data-theme=blush] .badge-deficit{background:#e070801f;color:#c04060}[data-theme=blush] .badge-surplus{background:#d4956a26;color:#8a5030}[data-theme=blush] ::-webkit-scrollbar-track{background:var(--bg)}[data-theme=blush] ::-webkit-scrollbar-thumb{background:#e8789a33;border-radius:4px}[data-theme=blush] ::-webkit-scrollbar-thumb:hover{background:#e8789a59}.theme-transitioning,.theme-transitioning *,.theme-transitioning *:before,.theme-transitioning *:after{transition:background-color .25s ease,border-color .25s ease,color .2s ease,box-shadow .25s ease!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app-shell{max-width:560px;margin:0 auto;padding:0 0 calc(var(--nav-h) + 16px) 0;min-height:100vh}.app-header{position:sticky;top:0;z-index:100;background:#f6f7fbd1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 16px;height:64px;display:flex;align-items:center;justify-content:space-between}.app-header h1{font-size:22px;font-weight:800;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}.header-right{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--gradient-avatar);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--indigo);flex-shrink:0;overflow:hidden;box-shadow:0 0 0 2px #fff,0 0 0 3px #4f46e533}.user-avatar img{width:32px;height:32px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-full)}.signout-btn{font-size:12px;padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--border-md);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-weight:500;transition:all .15s}.signout-btn:hover{background:var(--surface-2);color:var(--text-primary)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);height:var(--nav-h);display:flex;align-items:stretch;max-width:560px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom,0px)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:none;cursor:pointer;color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.2px;transition:color .15s;padding:0;font-family:Inter,system-ui,sans-serif}.nav-item svg{transition:transform .2s}.nav-item:hover,.nav-item.active{color:var(--green)}.nav-item.active svg{transform:scale(1.1)}.nav-item.active .nav-dot{width:4px;height:4px;border-radius:var(--radius-full);background:var(--green);position:absolute;bottom:10px}.view-content{padding:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.section-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;letter-spacing:.1px}.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}.metric-card{background:var(--surface);border-radius:var(--radius-lg);padding:14px;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.mc-kcal:before{background:var(--gradient-macro-kcal)}.mc-prot:before{background:var(--gradient-macro-prot)}.mc-carbs:before{background:var(--gradient-macro-carbs)}.mc-fat:before{background:var(--gradient-macro-fat)}.metric-icon{font-size:18px;line-height:1}.metric-label{font-size:11px;color:var(--text-muted);font-weight:500;letter-spacing:.2px}.metric-value{font-size:24px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary);line-height:1}.metric-sub{font-size:11px;color:var(--text-muted)}.progress-bar-wrap{height:4px;background:var(--surface-2);border-radius:var(--radius-full)}.progress-bar{height:4px;border-radius:var(--radius-full);transition:width .5s cubic-bezier(.4,0,.2,1)}.date-nav-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:12px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.nav-date{display:flex;align-items:center;gap:4px}.nav-btn{background:var(--surface-2);border:none;cursor:pointer;font-size:16px;width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .15s}.nav-btn:hover:not(:disabled){background:var(--border-md)}.nav-btn:disabled{opacity:.35;cursor:default}.nav-label{font-size:14px;font-weight:600;min-width:60px;text-align:center;color:var(--text-primary);display:flex;flex-direction:column;align-items:center;gap:1px}.nav-date-sub{font-size:11px;font-weight:400;color:var(--text-muted);letter-spacing:.2px}.go-today{background:var(--gradient-green);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;font-size:11px;font-weight:600;padding:3px 10px;margin-left:4px;font-family:inherit}.day-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.day-control-label{font-size:12px;color:var(--text-muted);font-weight:500}input,select{border:1px solid var(--border-md);border-radius:var(--radius-md);padding:8px 11px;font-size:14px;background:var(--surface);color:var(--text-primary);width:100%;font-family:inherit;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{outline:none;border-color:#16a34a80;box-shadow:0 0 0 3px #16a34a1a}input::-moz-placeholder{color:var(--text-muted)}input::placeholder{color:var(--text-muted)}.btn{background:var(--gradient-green);color:#fff;border:none;border-radius:var(--radius-md);padding:9px 18px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:opacity .15s,transform .15s,box-shadow .15s;font-family:inherit;letter-spacing:.1px}.btn:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-sm{padding:6px 13px;font-size:13px;border-radius:var(--radius-sm)}.btn-outline{background:none;color:var(--green);border:1px solid rgba(22,163,74,.3);box-shadow:none}.btn-outline:hover{background:#16a34a0f;box-shadow:none}.btn-ai{background:var(--gradient-ai);color:#fff;box-shadow:0 2px 8px #4f46e540}.btn-ai:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 14px #0891b259}.btn-ai:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.btn-ghost{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);box-shadow:none}.btn-ghost:hover{background:var(--border-md);box-shadow:none}.badge{display:inline-block;font-size:11px;padding:3px 9px;border-radius:var(--radius-full);font-weight:600;letter-spacing:.2px}.badge-gym{background:#e0e7ff;color:#3730a3}.badge-rest{background:var(--green-light);color:var(--green-dark)}.badge-deficit{background:#fee2e2;color:#991b1b}.badge-super{background:var(--amber-light);color:#92400e}.badge-ok{background:var(--green-light);color:var(--green-dark)}.food-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.food-item:last-child{border-bottom:none}.food-name{flex:1;font-weight:500;color:var(--text-primary)}.food-macros{color:var(--text-muted);font-size:11px}.food-kcal{font-weight:600;min-width:55px;text-align:right;font-size:13px;color:var(--text-secondary)}.icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:3px 4px;line-height:1;border-radius:var(--radius-sm);transition:color .15s,background .15s}.icon-btn:hover{color:var(--red);background:#fee2e2}.meal-block{border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;margin-bottom:12px;background:var(--surface);box-shadow:var(--shadow-sm);transition:box-shadow .2s;overflow:hidden}.meal-block:hover{box-shadow:var(--shadow-md)}.meal-header{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--border);background:var(--gradient-meal-header)}.meal-emoji{font-size:20px;flex-shrink:0}.meal-title-input{border:none;background:none;font-size:14px;font-weight:600;color:var(--text-primary);padding:0;flex:1;outline:none;width:auto;font-family:inherit;box-shadow:none}.meal-title-input::-moz-placeholder{color:var(--text-muted);font-weight:400}.meal-title-input::placeholder{color:var(--text-muted);font-weight:400}.meal-title-input:focus{box-shadow:none;border-color:transparent}.meal-title-select{border:none;background:none;font-size:14px;font-weight:600;color:var(--text-primary);padding:0;outline:none;font-family:inherit;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;flex:1;min-width:0}.meal-title-select:focus{outline:none;box-shadow:none}.meal-title-custom{flex:1;min-width:80px;font-weight:500}.meal-foods-section{padding:0 14px}.meal-add-toggle{display:flex;align-items:center;gap:5px;margin:6px 14px 10px;padding:0;background:none;border:none;color:var(--green);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;opacity:.85;transition:opacity .15s}.meal-add-toggle:hover{opacity:1}.meal-add-section{padding:12px 14px 14px;background:var(--surface-2);border-top:1px solid var(--border)}.meal-add-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.food-portion{font-weight:400;color:var(--text-muted);font-size:11px}.addfood-wrap{margin-top:8px}.wizard-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:14px}.wizard-dot{width:24px;height:24px;border-radius:50%;background:var(--border-light);color:var(--text-muted);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,color .2s}.wizard-dot.active{background:var(--purple);color:#fff}.wizard-dot.done{background:var(--green);color:#fff}.wizard-line{width:28px;height:2px;background:var(--border-light);transition:background .2s}.wizard-line.done{background:var(--green)}.wizard-back{margin-bottom:10px;font-size:12px;padding:4px 10px}.wizard-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px}.wizard-type-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 10px 14px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:center}.wizard-type-card:hover{border-color:var(--purple);box-shadow:0 0 0 3px #7c3aed1a}.wizard-type-icon{font-size:28px;line-height:1}.wizard-type-title{font-size:13px;font-weight:700;color:var(--text-primary)}.wizard-type-desc{font-size:11px;color:var(--text-muted)}.wizard-section-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px}.wizard-mode-list{display:flex;flex-direction:column;gap:6px}.wizard-mode-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color .15s}.wizard-mode-row:hover{border-color:var(--purple)}.wizard-mode-featured{border-color:#7c3aed59;background:var(--purple-light, #f3eeff)}.wizard-mode-icon{font-size:20px;flex-shrink:0}.wizard-mode-text{flex:1;min-width:0}.wizard-mode-title{font-size:13px;font-weight:600;color:var(--text-primary)}.wizard-mode-desc{font-size:11px;color:var(--text-muted);margin-top:1px}.wizard-mode-arrow{font-size:18px;color:var(--text-muted);flex-shrink:0}.qty-picker{display:flex;flex-direction:column;gap:12px}.qty-food-name{font-size:15px;font-weight:700;color:var(--text-primary);padding:10px 12px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md)}.qty-food-ref{font-size:12px;font-weight:400;color:var(--text-muted);margin-left:4px}.qty-grams-row{display:flex;align-items:center;gap:6px;justify-content:center}.qty-adj-btn{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 10px;cursor:pointer;flex-shrink:0;transition:border-color .15s}.qty-adj-btn:hover{border-color:var(--purple);color:var(--purple)}.qty-input-wrap{display:flex;align-items:center;gap:4px;background:var(--surface);border:1.5px solid var(--purple);border-radius:var(--radius-md);padding:0 10px}.qty-input{width:72px;font-size:20px;font-weight:700;text-align:center;background:transparent;border:none;outline:none;color:var(--text-primary);padding:6px 0}.qty-input::-webkit-inner-spin-button,.qty-input::-webkit-outer-spin-button{-webkit-appearance:none}.qty-unit{font-size:14px;font-weight:600;color:var(--text-muted)}.qty-macros-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:10px 12px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md)}.qty-macro{display:flex;flex-direction:column;align-items:center;gap:2px}.qty-macro-val{font-size:16px;font-weight:700;color:var(--text-primary)}.qty-macro-label{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.qty-macro-kcal .qty-macro-val{color:var(--purple)}.meal-totals{font-size:12px;color:var(--text-muted);padding:8px 0 10px;border-top:1px solid var(--border);display:flex;gap:12px;flex-wrap:wrap}.meal-totals b{color:var(--text-secondary)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:var(--radius-full);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-error{color:var(--red);font-size:12px;margin-bottom:6px;display:none}.ai-error.on{display:block}.target-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.target-chip{font-size:12px;color:var(--text-muted);background:var(--surface-2);border-radius:var(--radius-full);padding:4px 11px;border:1px solid var(--border);font-weight:500}.target-chip b{color:var(--text-secondary)}.empty{font-size:13px;color:var(--text-muted);text-align:center;padding:2rem 0;display:flex;flex-direction:column;align-items:center;gap:6px}.empty:before{content:"🍽️";font-size:28px}.empty--exercise:before{content:"🏃"}.hist-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;flex-wrap:wrap;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.hist-row:hover{background:var(--surface-2);padding-left:6px}.hist-row:last-child{border-bottom:none}.hist-date{color:var(--text-muted);min-width:50px;font-weight:500}.hist-kcal{font-weight:700;color:var(--text-primary)}.hist-expand{color:var(--text-muted);font-size:11px;margin-left:auto}.chart-wrap{position:relative;width:100%;height:200px}.chart-tabs{display:flex;gap:4px;margin-bottom:10px}.chart-tab{font-size:12px;padding:5px 13px;border:1px solid var(--border-md);border-radius:var(--radius-full);background:var(--surface);cursor:pointer;color:var(--text-muted);font-weight:500;font-family:inherit;transition:all .15s}.chart-tab.active{background:var(--gradient-green);color:#fff;border-color:transparent}.legend{display:flex;gap:14px;font-size:12px;color:var(--text-muted);margin-bottom:8px;flex-wrap:wrap}.legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block;margin-right:4px;vertical-align:middle}.profile-hero{display:flex;align-items:center;gap:14px;background:var(--gradient-surface-soft);border:1px solid rgba(22,163,74,.15);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.profile-hero-avatar{width:52px;height:52px;border-radius:var(--radius-full);background:var(--gradient-brand);display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #16a34a40}.profile-hero-name{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.profile-hero-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.profile-section-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.profile-section-icon{font-size:16px;line-height:1}.profile-section-desc{font-size:12px;color:var(--text-muted);margin-top:-8px;margin-bottom:12px;line-height:1.55}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}@media(max-width:500px){.profile-grid{grid-template-columns:1fr}}.profile-field{display:flex;flex-direction:column;gap:5px}.profile-field.full-col{grid-column:1 / -1}.profile-label{font-size:12px;color:var(--text-muted);font-weight:600;letter-spacing:.2px}.profile-label-opt,.profile-label-hint{font-weight:400;color:var(--text-muted);font-size:11px}.profile-targets-preview{margin-top:14px;background:var(--gradient-surface-soft);border:1px solid rgba(22,163,74,.15);border-radius:var(--radius-lg);padding:14px}.profile-targets-title{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:700;color:var(--green);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.profile-targets-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.profile-target-chip{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--chip-color, var(--green));border-radius:var(--radius-md);padding:10px 12px;box-shadow:var(--shadow-sm)}.profile-target-chip-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.profile-target-chip-value{font-size:15px;font-weight:700;color:var(--text-primary)}.how-found-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.how-found-btn{padding:9px 12px;border:1px solid var(--border-md);border-radius:var(--radius-md);background:var(--surface);color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left;font-family:inherit;font-weight:500;transition:all .15s;line-height:1.3}.how-found-btn:hover{background:var(--surface-2);border-color:#16a34a59;color:var(--text-primary)}.how-found-btn.selected{background:#16a34a14;border-color:#16a34a80;color:var(--green);font-weight:600}.autosave-toast{position:fixed;bottom:calc(var(--nav-height, 64px) + 12px);right:16px;z-index:999;display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:600;box-shadow:0 2px 12px #00000026;pointer-events:none;animation:toast-in .18s ease}.autosave-toast.saving{background:var(--surface-2);color:var(--text-secondary)}.autosave-toast.saved{background:#16a34a1f;color:var(--green)}.autosave-toast.error{background:#dc26261a;color:#dc2626}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.spinner-xs{display:inline-block;width:10px;height:10px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--text-secondary);border-radius:var(--radius-full);animation:spin .7s linear infinite}.donation-card{border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 60%,var(--green-2) 100%);box-shadow:var(--shadow-md);margin-bottom:12px}.donation-card-inner{padding:28px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.donation-emoji{font-size:48px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}.donation-title{font-size:19px;font-weight:700;color:#fff;line-height:1.3;font-family:Inter,system-ui,sans-serif}.donation-desc{font-size:14px;color:#ffffffe0;line-height:1.6;margin:0;max-width:340px;font-family:Inter,system-ui,sans-serif}.donation-perks{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.donation-perks span{font-size:12px;font-weight:600;color:#ffffffe6;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-full);padding:4px 10px;font-family:Inter,system-ui,sans-serif}.donation-btn{display:inline-flex;align-items:center;gap:8px;margin-top:4px;background:#fff;color:var(--green-dark);font-size:15px;font-weight:700;border-radius:var(--radius-md);padding:12px 28px;text-decoration:none;transition:transform .15s,box-shadow .15s;box-shadow:var(--shadow-md);font-family:Inter,system-ui,sans-serif}.donation-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.donation-btn:active{transform:translateY(0)}.donation-footer{font-size:11px;color:#ffffff8c;margin:0;font-family:Inter,system-ui,sans-serif}.profile-pending-banner{background:var(--amber-light);border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.profile-pending-banner.shake{animation:shake .5s ease;border-color:#f97316}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.profile-pending-title{font-size:14px;font-weight:700;color:#78350f;margin-bottom:6px}.profile-pending-body{font-size:13px;line-height:1.55;color:#92400e;margin:0 0 10px}.profile-pending-section{margin-top:4px}.profile-pending-label{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;padding:1px 6px;margin-bottom:6px;background:#f59e0b33;color:#78350f}.profile-pending-list{margin:0;padding-left:18px;display:flex;flex-wrap:wrap;gap:2px 24px}.profile-pending-list li{font-size:13px;color:#92400e;line-height:1.7}.profile-pending-hint{font-size:11px;opacity:.75;font-style:italic}.formula-link{font-size:11px;color:var(--blue);-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.formula-link:hover{color:#0369a1}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.modal-box{background:var(--surface);border-radius:var(--radius-xl);padding:1.75rem 1.5rem;max-width:440px;width:100%;box-shadow:var(--shadow-xl);position:relative;max-height:90vh;overflow-y:auto;border:1px solid var(--border)}.modal-close{position:absolute;top:14px;right:16px;background:var(--surface-2);border:none;width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;color:var(--text-muted);transition:all .15s}.modal-close:hover{background:var(--border-md);color:var(--text-primary)}.modal-title{font-size:18px;font-weight:700;margin-bottom:4px;color:var(--text-primary)}.modal-subtitle{font-size:12px;color:var(--text-muted);margin-bottom:1.4rem}.modal-section{margin-bottom:1.1rem}.modal-section-title{font-size:12px;font-weight:700;color:var(--green);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}.modal-text{font-size:13px;color:var(--text-secondary);line-height:1.65}.modal-formula{background:var(--surface-2);border-radius:var(--radius-md);padding:12px 14px;font-size:12px;font-family:SF Mono,Fira Code,monospace;color:var(--text-secondary);margin:8px 0;line-height:1.8;border:1px solid var(--border)}.modal-badge{display:inline-block;background:var(--green-light);color:var(--green-dark);border:1px solid rgba(22,163,74,.2);border-radius:var(--radius-sm);font-size:11px;font-weight:600;padding:2px 8px;margin-right:4px;margin-bottom:4px}.fav-search-wrap{position:relative;margin-bottom:8px}.fav-input{width:100%;border:1px solid rgba(22,163,74,.25);border-radius:var(--radius-md);padding:8px 11px 8px 32px;font-size:13px;background:#16a34a0a;color:var(--text-primary);font-family:inherit;transition:border-color .15s,box-shadow .15s}.fav-input:focus{outline:none;border-color:#16a34a80;box-shadow:0 0 0 3px #16a34a1a;background:var(--surface)}.fav-input-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;opacity:.45}.fav-list{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;max-height:220px;overflow-y:auto;display:none}.fav-list.open{display:block}.fav-item{display:flex;align-items:center;gap:8px;padding:9px 12px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background .1s}.fav-item:last-child{border-bottom:none}.fav-item:hover{background:#16a34a0d}.fav-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fav-item-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.fav-item-macros{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-item-del{background:none;border:none;color:var(--border-md);cursor:pointer;font-size:13px;padding:0 2px;flex-shrink:0}.fav-item-del:hover{color:var(--red)}.fav-empty{padding:14px 12px;font-size:12px;color:var(--text-muted);text-align:center}.fav-section-label{font-size:11px;color:var(--text-muted);font-weight:700;padding:7px 12px 3px;text-transform:uppercase;letter-spacing:.4px;background:var(--surface-2)}.manual-form{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--radius-lg);padding:14px;display:none;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm)}.manual-form.open{display:flex}.manual-label{font-size:11px;color:var(--text-muted);font-weight:600;margin-bottom:2px;letter-spacing:.2px}.manual-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.manual-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.manual-grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:6px}@media(max-width:480px){.manual-grid-4{grid-template-columns:1fr 1fr}}.manual-toggle{background:none;border:none;font-size:12px;color:var(--blue);cursor:pointer;padding:0;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;margin-left:auto;flex-shrink:0;font-family:inherit;font-weight:500}.manual-toggle:hover{color:#0369a1}.manual-field{display:flex;flex-direction:column}.manual-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:2px}.manual-actions .btn-full{grid-column:1 / -1}.recipe-panel{background:var(--surface);border:1px solid rgba(124,58,237,.2);border-radius:var(--radius-lg);padding:14px;display:none;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm)}.recipe-panel.open{display:flex}.recipe-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid rgba(124,58,237,.12);border-radius:var(--radius-md);font-size:13px;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.recipe-item-info{flex:1;min-width:0}.recipe-item-name{font-weight:700;font-size:13px;color:var(--text-primary)}.recipe-item-macros{font-size:11px;color:var(--text-muted);margin-top:2px}.recipe-ing-row{display:flex;flex-direction:column;gap:3px}.recipe-ing-row .rc-inputs{display:flex;align-items:center;gap:6px}.recipe-ing-row select{flex:2;min-width:0;font-size:12px}.recipe-ing-row .rc-grams{width:68px;flex-shrink:0;font-size:12px}.recipe-ing-row .rc-preview{font-size:11px;color:var(--purple);font-weight:600;padding-left:2px}.recipe-section-title{font-size:11px;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:.06em}.recipe-create-form{background:#ede9fe;border-radius:var(--radius-lg);padding:12px;flex-direction:column;gap:8px;display:flex}.day-summary-btn{width:100%;margin-top:14px;justify-content:center;font-size:13px;padding:10px 16px;border-radius:var(--radius-md)}.day-summary-panel{margin-top:12px;background:var(--gradient-surface-soft);border:1px solid rgba(8,145,178,.15);border-radius:var(--radius-lg);padding:16px;display:none;font-size:13px;line-height:1.75;color:var(--text-primary);position:relative}.day-summary-panel.open{display:block}.day-summary-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-muted)}.day-summary-close:hover{color:var(--text-primary)}.day-summary-loading{display:flex;align-items:center;gap:10px;color:var(--blue);font-size:13px;padding:4px 0}.day-summary-content{white-space:pre-wrap}.day-summary-donation{display:flex;align-items:center;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border-sm)}.day-summary-donation-icon{font-size:22px;flex-shrink:0;line-height:1}.day-summary-donation-text{display:flex;flex-direction:column;flex:1;gap:2px}.day-summary-donation-title{font-size:13px;font-weight:600;color:var(--text-primary)}.day-summary-donation-sub{font-size:12px;color:var(--text-secondary)}.day-summary-donation-btn{flex-shrink:0;background:var(--green-light);color:var(--green-dark);font-size:12px;font-weight:600;border-radius:var(--radius-sm);padding:6px 12px;text-decoration:none;border:1px solid rgba(22,163,74,.25);transition:opacity .15s,transform .15s}.day-summary-donation-btn:hover{opacity:.85;transform:translateY(-1px)}.login-overlay{position:fixed;inset:0;background:var(--gradient-login);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.login-overlay.hidden{display:none}.login-box{background:#fffffff7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:2.5rem 2.25rem 2rem;width:100%;max-width:360px;box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.8)}.login-logo{display:flex;justify-content:center;align-items:center;margin-bottom:0;animation:pop .4s cubic-bezier(.34,1.56,.64,1)}.login-logo img{display:block;background:transparent}@keyframes pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.login-title{font-size:22px;font-weight:800;text-align:center;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;margin-bottom:4px}.login-sub{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:1.75rem}.login-error{color:var(--red);font-size:13px;margin-bottom:10px;display:none;text-align:center;background:#fee2e2;border-radius:var(--radius-md);padding:8px 12px}.login-error.on{display:block}.login-btn{width:100%;padding:12px;font-size:15px;margin-top:6px;border-radius:var(--radius-md);letter-spacing:.2px;justify-content:center}.google-btn{background:var(--surface)!important;-webkit-text-fill-color:#3c4043!important;color:#3c4043!important;border:1px solid #dadce0!important;box-shadow:var(--shadow-sm)!important;font-weight:600!important}.google-btn:hover{background:#f8f9fa!important;box-shadow:var(--shadow-md)!important;transform:translateY(-1px)!important}.login-divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--text-muted);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-md)}.login-input-group{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.login-input-group input{padding:11px 13px;font-size:14px;border:1px solid var(--border-md);border-radius:var(--radius-md);width:100%;background:var(--surface);color:var(--text-primary);font-family:inherit;transition:border-color .15s,box-shadow .15s}.login-input-group input:focus{outline:none;border-color:#16a34a80;box-shadow:0 0 0 3px #16a34a1a}.login-pass-wrap{position:relative;display:flex;align-items:center}.login-pass-wrap input{padding-right:40px;width:100%}.login-pass-eye{position:absolute;right:11px;background:none;border:none;cursor:pointer;font-size:16px;padding:0;opacity:.4;transition:opacity .15s}.login-pass-eye:hover{opacity:.9}.login-toggle{font-size:13px;color:var(--text-muted);text-align:center;margin-top:14px}.login-toggle button{background:none;border:none;color:var(--green);font-size:13px;cursor:pointer;padding:0;font-weight:600;font-family:inherit}.login-success{background:var(--green-light);border:1px solid rgba(22,163,74,.2);border-radius:var(--radius-md);padding:10px 13px;font-size:13px;color:var(--green-dark);text-align:center;display:none;margin-top:8px;font-weight:500}.login-success.on{display:block}.login-forgot{background:none;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;padding:0;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;margin-top:10px;display:block;width:100%;text-align:center;font-family:inherit}.login-forgot:hover{color:var(--text-secondary)}.app-loading{position:fixed;inset:0;background:var(--gradient-login);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9998;gap:16px}.app-loading.hidden{display:none}.app-loading .logo{animation:pop .5s cubic-bezier(.34,1.56,.64,1);display:block}.app-loading .msg{font-size:14px;color:#ffffffa6;font-weight:500;letter-spacing:.2px}.app-loading .dot-spin{display:flex;gap:6px}.app-loading .dot-spin span{width:8px;height:8px;border-radius:var(--radius-full);background:#ffffff80;animation:dotBounce 1.2s ease-in-out infinite}.app-loading .dot-spin span:nth-child(2){animation-delay:.2s}.app-loading .dot-spin span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.recovery-overlay{position:fixed;inset:0;background:var(--gradient-login);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.recovery-overlay.hidden{display:none}.mode-tabs{display:flex;gap:0;margin-bottom:10px;background:#0000000f;border-radius:var(--radius-md);padding:3px}.mode-tabs .btn:not(.btn-outline){flex:1;justify-content:center;font-size:12px;padding:6px 8px;background:var(--surface);color:var(--green);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:calc(var(--radius-md) - 2px)}.mode-tabs .btn:not(.btn-outline):hover{opacity:1;transform:none;box-shadow:var(--shadow-sm)}.mode-tabs .btn-outline{flex:1;justify-content:center;font-size:12px;padding:6px 8px;background:transparent;color:var(--text-secondary);border:none;box-shadow:none;border-radius:calc(var(--radius-md) - 2px)}.mode-tabs .btn-outline:hover{background:#0000000a;color:var(--text-primary);box-shadow:none;transform:none}.export-btn{font-size:12px;padding:5px 13px;border:1px solid var(--border-md);border-radius:var(--radius-full);background:var(--surface);cursor:pointer;color:var(--text-muted);font-weight:500;font-family:inherit;transition:all .15s}.export-btn:hover{background:var(--surface-2);color:var(--text-primary)}.divider{height:1px;background:var(--border);margin:12px 0}.exercise-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--surface-2)}.exercise-item-name{font-size:13px;font-weight:500;margin-bottom:2px;color:var(--text-primary)}.exercise-item-meta{font-size:11px;color:var(--text-muted)}.exercise-kcal{color:var(--green);font-weight:600}.exercise-delete-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:0 4px;margin-left:8px;flex-shrink:0;line-height:1;transition:color .15s}.exercise-delete-btn:hover{color:var(--red)}.photo-panel{margin-top:10px;border:1.5px solid var(--indigo-light);border-radius:var(--radius-md);background:var(--gradient-ai-soft);padding:14px 14px 12px}.photo-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.photo-panel-title{font-size:13px;font-weight:600;color:var(--indigo);display:flex;align-items:center;gap:5px}.photo-panel-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:20px;line-height:1;padding:0;transition:color .15s}.photo-panel-close:hover{color:var(--text-secondary)}.photo-upload-zone{width:100%;padding:22px 12px;border:2px dashed var(--purple);border-radius:var(--radius-md);background:var(--purple-light);cursor:pointer;font-size:13px;color:var(--purple);font-weight:500;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:opacity .15s,border-color .15s;font-family:inherit}.photo-upload-zone:hover{opacity:.82}.photo-preview-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:14px}.photo-preview-img{width:80px;height:80px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-md);flex-shrink:0}.photo-preview-info{flex:1;min-width:0}.photo-ready-hint{font-size:12px;color:var(--text-muted);margin-bottom:8px}.photo-preview-actions{display:flex;gap:6px;width:100%;margin-bottom:8px}.photo-icon-btn{flex-shrink:0;width:36px;padding-left:0;padding-right:0;display:flex;align-items:center;justify-content:center;font-size:15px}.photo-analyzing{font-size:13px;color:var(--indigo);display:flex;align-items:center;gap:6px;padding-top:4px;font-weight:500}.photo-result-name{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.photo-result-meta{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.photo-result-notes{font-size:11px;color:var(--text-muted)}.photo-feedback{background:var(--green-light);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);padding:10px 12px;margin-bottom:10px;font-size:13px;color:var(--green-dark);line-height:1.5}.photo-error{font-size:12px;color:var(--red);background:#ef444414;border:1px solid rgba(239,68,68,.18);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:8px}.photo-actions{display:flex;gap:8px}.photo-actions+.photo-actions{margin-top:4px}.lbl-form{display:flex;flex-direction:column;gap:10px}.lbl-form-divider{height:1px;background:var(--border-md);margin:2px 0}.lbl-form-actions{display:flex;gap:8px;width:100%}.lbl-form-actions .btn{flex:1;min-width:0}.btn-toggle-photo{width:100%;padding:7px 12px;border:1.5px dashed var(--purple);border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:12px;color:var(--purple);font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s;font-family:inherit}.btn-toggle-photo:hover,.btn-toggle-photo.active{background:var(--purple-light)}.exercise-input{flex:1;padding:6px 10px;font-size:13px;border-radius:var(--radius-sm);border:1px solid var(--border-md);background:var(--surface);color:var(--text-primary);font-family:inherit;transition:border-color .15s}.exercise-input::-moz-placeholder{color:var(--text-muted)}.exercise-input::placeholder{color:var(--text-muted)}.exercise-input:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 2px var(--indigo-light)}
