@import url(https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=IBM+Plex+Sans:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap);*,:after,:before{--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:#3b82f680;--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:#3b82f680;--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: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}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,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height: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:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:0 0% 3.9%;--card:0 0% 100%;--card-foreground:0 0% 3.9%;--popover:0 0% 100%;--popover-foreground:0 0% 3.9%;--primary:0 0% 9%;--primary-foreground:0 0% 98%;--secondary:0 0% 96.1%;--secondary-foreground:0 0% 9%;--muted:0 0% 96.1%;--muted-foreground:0 0% 45.1%;--accent:0 0% 96.1%;--accent-foreground:0 0% 9%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:0 0% 89.8%;--input:0 0% 89.8%;--ring:0 0% 3.9%;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%;--radius:0.5rem}*{border-color:#e5e5e5;border-color:hsl(var(--border))}body{background-color:#fff;background-color:hsl(var(--background));color:#0a0a0a;color:hsl(var(--foreground))}[data-debug-wrapper=true]{display:contents!important}[data-debug-wrapper=true]>*{border:inherit;column-gap:inherit;gap:inherit;margin:inherit;padding:inherit;row-gap:inherit}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{bottom:0;top:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-1{top:.25rem}.top-1\/2{top:50%}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-bottom:.25rem;margin-top:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.ml-1{margin-left:.25rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-24{margin-top:6rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-\[--radix-context-menu-content-available-height\]{max-height:var(--radix-context-menu-content-available-height)}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-screen{max-height:100vh}.min-h-\[60px\]{min-height:60px}.w-10{width:2.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-full{width:100%}.w-max{width:-webkit-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-8{min-width:2rem}.min-w-9{min-width:2.25rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:-webkit-max-content;max-width:max-content}.flex-1{flex:1 1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.origin-\[--radix-context-menu-content-transform-origin\]{transform-origin:var(--radix-context-menu-content-transform-origin)}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-hover-card-content-transform-origin\]{transform-origin:var(--radix-hover-card-content-transform-origin)}.origin-\[--radix-menubar-content-transform-origin\]{transform-origin:var(--radix-menubar-content-transform-origin)}.origin-\[--radix-popover-content-transform-origin\]{transform-origin:var(--radix-popover-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.translate-y-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y:-50%}.rotate-45{--tw-rotate:45deg}.rotate-45,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.rounded-md{border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(.5rem - 4px);border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:calc(.5rem - 4px);border-top-left-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-y{border-top-width:1px}.border-b,.border-y{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-destructive{border-color:#ef4444;border-color:hsl(var(--destructive))}.border-destructive\/50{border-color:#ef444480;border-color:hsl(var(--destructive)/.5)}.border-input{border-color:#e5e5e5;border-color:hsl(var(--input))}.border-primary{border-color:#171717;border-color:hsl(var(--primary))}.border-primary\/50{border-color:#17171780;border-color:hsl(var(--primary)/.5)}.border-transparent{border-color:#0000}.border-l-transparent{border-left-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:#f5f5f5;background-color:hsl(var(--accent))}.bg-background{background-color:#fff;background-color:hsl(var(--background))}.bg-black\/80{background-color:#000c}.bg-border{background-color:#e5e5e5;background-color:hsl(var(--border))}.bg-card{background-color:#fff;background-color:hsl(var(--card))}.bg-destructive{background-color:#ef4444;background-color:hsl(var(--destructive))}.bg-foreground{background-color:#0a0a0a;background-color:hsl(var(--foreground))}.bg-muted{background-color:#f5f5f5;background-color:hsl(var(--muted))}.bg-muted\/50{background-color:#f5f5f580;background-color:hsl(var(--muted)/.5)}.bg-popover{background-color:#fff;background-color:hsl(var(--popover))}.bg-primary{background-color:#171717;background-color:hsl(var(--primary))}.bg-primary\/10{background-color:#1717171a;background-color:hsl(var(--primary)/.1)}.bg-primary\/20{background-color:#17171733;background-color:hsl(var(--primary)/.2)}.bg-secondary{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.bg-transparent{background-color:initial}.fill-current{fill:currentColor}.fill-primary{fill:#171717;fill:hsl(var(--primary))}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[1px\]{padding:1px}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-2\.5{padding-left:.625rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-6{padding-right:1.5rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:#171717;color:hsl(var(--accent-foreground))}.text-card-foreground{color:#0a0a0a;color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:#ef4444;color:hsl(var(--destructive))}.text-destructive-foreground{color:#fafafa;color:hsl(var(--destructive-foreground))}.text-foreground{color:#0a0a0a;color:hsl(var(--foreground))}.text-foreground\/50{color:#0a0a0a80;color:hsl(var(--foreground)/.5)}.text-muted-foreground{color:#737373;color:hsl(var(--muted-foreground))}.text-popover-foreground{color:#0a0a0a;color:hsl(var(--popover-foreground))}.text-primary{color:#171717;color:hsl(var(--primary))}.text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:#171717;color:hsl(var(--secondary-foreground))}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline-none{outline:2px solid #0000;outline-offset:2px}.outline{outline-style:solid}.ring-0{--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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-0,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-ring{--tw-ring-color:hsl(var(--ring))}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{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)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.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)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:1;opacity:var(--tw-enter-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:1;opacity:var(--tw-exit-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.running{animation-play-state:running}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.file\:border-0::-webkit-file-upload-button{border-width:0}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::-webkit-file-upload-button{background-color:initial}.file\:bg-transparent::file-selector-button{background-color:initial}.file\:text-sm::-webkit-file-upload-button{font-size:.875rem;line-height:1.25rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::-webkit-file-upload-button{font-weight:500}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::-webkit-file-upload-button{color:#0a0a0a;color:hsl(var(--foreground))}.file\:text-foreground::file-selector-button{color:#0a0a0a;color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:#737373;color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:inset-y-0:after{bottom:0;content:var(--tw-content);top:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:-translate-x-1\/2:after{--tw-translate-x:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.first\:rounded-l-md:first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{background-color:#f5f5f5;background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:#ef4444cc;background-color:hsl(var(--destructive)/.8)}.hover\:bg-destructive\/90:hover{background-color:#ef4444e6;background-color:hsl(var(--destructive)/.9)}.hover\:bg-muted:hover{background-color:#f5f5f5;background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:#f5f5f580;background-color:hsl(var(--muted)/.5)}.hover\:bg-primary:hover{background-color:#171717;background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:#171717cc;background-color:hsl(var(--primary)/.8)}.hover\:bg-primary\/90:hover{background-color:#171717e6;background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary:hover{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:#f5f5f5cc;background-color:hsl(var(--secondary)/.8)}.hover\:text-accent-foreground:hover{color:#171717;color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:#0a0a0a;color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:#737373;color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:#fafafa;color:hsl(var(--primary-foreground))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:#f5f5f5;background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:#171717;background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:#171717;color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:#fafafa;color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1:focus{--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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--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(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid #0000;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-2:focus-visible{--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(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--ring))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:#f5f5f566;border-color:hsl(var(--muted)/.4)}.group.toaster .group-\[\.toaster\]\:border-border{border-color:#e5e5e5;border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:#f5f5f5;background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:#171717;background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:#fff;background-color:hsl(var(--background))}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity:1;color:#fca5a5;color:rgb(252 165 165/var(--tw-text-opacity,1))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:#737373;color:hsl(var(--muted-foreground))}.group.toast .group-\[\.toast\]\:text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:#0a0a0a;color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:#ef44444d;border-color:hsl(var(--destructive)/.3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{background-color:#ef4444;background-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{color:#fafafa;color:hsl(var(--destructive-foreground))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity:1;color:#fef2f2;color:rgb(254 242 242/var(--tw-text-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 113 113/var(--tw-ring-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color:#dc2626}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:#171717;color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:#737373;color:hsl(var(--muted-foreground))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x:1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x:var(--radix-toast-swipe-end-x)}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end],.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x:var(--radix-toast-swipe-move-x)}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#fff;background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#171717;background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:#f5f5f5;background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#e5e5e5;background-color:hsl(var(--input))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#737373;color:hsl(var(--muted-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:#171717;color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#0a0a0a;color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:#fafafa;color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#171717;color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#737373;color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-duration:.15s;animation-name:exit}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity:0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity:0.8}.data-\[state\=hidden\]\:fade-out[data-state=hidden]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open],.data-\[state\=visible\]\:fade-in[data-state=visible]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-90[data-state=open]{--tw-enter-scale:.9}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion=from-end]{--tw-enter-translate-x:13rem}.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion=from-start]{--tw-enter-translate-x:-13rem}.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion=to-end]{--tw-exit-translate-x:13rem}.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion=to-start]{--tw-exit-translate-x:-13rem}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y:100%}.data-\[state\=closed\]\:slide-out-to-left[data-state=closed]{--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed],.data-\[state\=closed\]\:slide-out-to-right[data-state=closed]{--tw-exit-translate-x:100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y:-100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y:100%}.data-\[state\=open\]\:slide-in-from-left[data-state=open]{--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-right[data-state=open]{--tw-enter-translate-x:100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{--tw-translate-y:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{--tw-translate-x:0px;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:focus\:bg-accent:focus[data-state=open],.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.dark\:border-destructive:is(.dark *){border-color:#ef4444;border-color:hsl(var(--destructive))}@media (min-width:640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:mt-0{margin-top:0}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.sm\:text-left{text-align:left}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y:100%}}@media (min-width:768px){.md\:absolute{position:absolute}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&\+div\]\:text-xs+div{font-size:.75rem;line-height:1rem}.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md:has(>.day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md:has(>.day-range-start){border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md:has([aria-selected]){border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:#f5f5f5;background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>span\]\:line-clamp-1>span{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y:-3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{height:1rem;width:1rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:#ef4444;color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:#0a0a0a;color:hsl(var(--foreground))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate:90deg}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div,.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate:180deg}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-bottom:.375rem;padding-top:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:#737373;color:hsl(var(--muted-foreground))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-bottom:.75rem;padding-top:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{height:1rem;width:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}.language-selector{position:relative;z-index:1000}.language-selector-trigger{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.language-selector-trigger:hover{background:#ffffff26;border-color:#ffffff4d}.language-selector-trigger:disabled{cursor:not-allowed;opacity:.7}.language-flag{font-size:18px;line-height:1}.language-code{font-weight:600;letter-spacing:.5px}.chevron{opacity:.7;transition:transform .2s ease}.chevron.rotated{transform:rotate(180deg)}.language-dropdown{animation:dropdownSlide .2s ease;background:#1a1a2e;border:1px solid #ffffff26;border-radius:12px;box-shadow:0 10px 40px #0006;min-width:160px;padding:8px;position:absolute;right:0;top:calc(100% + 8px)}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-option{align-items:center;background:#0000;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 12px;text-align:left;transition:all .15s ease;width:100%}.language-option:hover{background:#00d4aa26}.language-option.selected{background:#00d4aa33}.language-name{flex:1 1}.language-check{color:#00d4aa;font-weight:700}.language-selector.light .language-selector-trigger{background:#ffffffe6;border-color:#0000001a;color:#1a1a2e}.language-selector.light .language-selector-trigger:hover{background:#fff;border-color:#0003}.language-selector.light .language-dropdown{background:#fff;border-color:#0000001a;box-shadow:0 10px 40px #00000026}.language-selector.light .language-option{color:#1a1a2e}.language-selector.light .language-option:hover{background:#00d4aa1a}.language-selector.light .language-option.selected{background:#00d4aa26}@media (max-width:480px){.language-selector-trigger{padding:6px 10px}.language-code{display:none}.language-dropdown{min-width:150px;right:-10px}}@media (max-width:360px){.language-selector-trigger{padding:5px 8px}.language-flag{font-size:16px}.chevron{height:14px;width:14px}}:root{--bg-page:#060a11;--bg-card:#0c1322;--bg-elevated:#121a2f;--bg-glass:#ffffff08;--bg-section:#00d9a50d;--text-primary:#fff;--text-secondary:#94a3b8;--text-muted:#475569;--border-light:#ffffff14;--border-medium:#ffffff1f;--border-strong:#fff3;--brand-primary:#00d9a5;--brand-secondary:#0080ff;--brand-hover:#33e2be;--brand-active:#00b388;--gradient-button:linear-gradient(135deg,#00d9a5,#0080ff);--gradient-hero:linear-gradient(135deg,#00d9a526,#0080ff26);--gradient-card:linear-gradient(180deg,#ffffff0d,#fff0);--glow-teal:0 0 20px #00d9a54d;--glow-blue:0 0 20px #0080ff4d;--success:#00d9a5;--warning:#ffb800;--error:#ff4757;--info:#0080ff}*,body{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#060a11;background:var(--bg-page);color:#fff;color:var(--text-primary);font-family:IBM Plex Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;overflow-x:hidden}*{box-sizing:border-box}.app{background:#060a11;background:var(--bg-page);display:flex;flex-direction:column;max-width:100vw;min-height:100vh;min-height:100dvh;overflow-x:hidden;padding-bottom:90px;width:100%}.app-content{flex:1 1;margin:0 auto;max-width:100%;padding:16px;width:100%}.heading-1{color:#fff;color:var(--text-primary);font-family:Manrope,sans-serif;font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0 0 4px}.heading-3{font-size:clamp(20px,3vw,28px);letter-spacing:-.01em;line-height:1.3}.heading-3,.heading-4{color:#fff;color:var(--text-primary);font-family:Satoshi;font-weight:600}.heading-4{font-size:clamp(18px,2.5vw,22px);line-height:1.4}.body-large{color:#fff;color:var(--text-primary);font-size:clamp(16px,2.5vw,18px);line-height:1.6}.body-large,.body-medium{font-family:Satoshi;font-weight:400}.body-medium{color:#94a3b8;color:var(--text-secondary);font-size:clamp(14px,2vw,16px);line-height:1.5}.body-small{color:#475569;color:var(--text-muted);font-family:Satoshi;font-size:14px;font-weight:400;line-height:1.4}.btn-primary{align-items:center;border-radius:100px;box-shadow:0 4px 16px #0000001f;cursor:pointer;display:inline-flex;font-family:Satoshi;font-size:16px;font-weight:600;justify-content:center;line-height:1.3;min-height:48px;padding:14px 24px;text-decoration:none;transition:all .2s ease}.btn-primary:hover{box-shadow:0 6px 20px #00000026;transform:scale(1.04)}.btn-primary:active{transform:scale(.96)}.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-secondary{align-items:center;background:#fff3;border:1px solid #18181833;border-radius:100px;box-shadow:0 2px 8px #00000014;color:#fff;color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:Satoshi;font-size:16px;font-weight:600;justify-content:center;line-height:1.3;min-height:48px;padding:14px 24px;text-decoration:none;transition:all .2s ease}.btn-secondary:hover{background:#ffffff4d;border-color:#1818184d;transform:scale(1.02)}.btn-secondary:active{transform:scale(.98)}.btn-back{background:#0000;border:none;color:#00d9a5;color:var(--brand-primary);cursor:pointer;font-family:Satoshi;font-size:16px;font-weight:500;margin-bottom:16px;padding:8px 0;transition:all .2s ease}.btn-back:hover{opacity:.7}.btn-delete{align-items:center;background:#ff3b301a;border:1px solid #ff3b3033;border-radius:50%;color:#ff3b30;cursor:pointer;display:flex;font-size:18px;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-delete:hover{background:#ff3b3033;transform:scale(1.1)}.btn-delete.deleting{cursor:not-allowed;opacity:.7}.btn-delete .delete-spinner{animation:spin .6s linear infinite;border:2px solid #ff3b304d;border-radius:50%;border-top-color:#ff3b30;height:14px;width:14px}.btn-full{width:100%}.btn-capture{font-size:18px}.view-container{animation:fadeIn .3s ease}.header-section{margin-bottom:32px}.header-title-row{align-items:flex-start;gap:16px;margin-bottom:8px}.header-title-row,.header-with-back{display:flex;justify-content:space-between}.header-with-back{align-items:center;margin-bottom:12px}.upgrade-button{background:linear-gradient(135deg,gold,orange);box-shadow:0 2px 8px #ffa5004d;color:#1a1a1a;padding:8px 16px;white-space:nowrap}.upgrade-button:hover{box-shadow:0 4px 12px #ffa50066;transform:translateY(-1px)}.upgrade-button svg{height:14px;width:14px}.section-header{flex-wrap:wrap;gap:16px;margin:32px 0 16px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px}.stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.stat-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;padding:24px;transition:all .2s ease}.stat-card:hover{border-color:#ffffff1f;border-color:var(--border-medium);box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.stat-label{font-size:14px;font-weight:500;margin-bottom:8px}.stat-value{font-size:36px}.stat-target{color:#475569;color:var(--text-muted);font-size:14px;margin-bottom:12px;margin-top:4px}.progress-bar{background:#00d9a50d;background:var(--bg-section);border-radius:100px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:100px;height:100%;transition:width .3s ease}.meals-list{display:flex;flex-direction:column;gap:16px}.meal-card{border-radius:12px}.meal-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.meal-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.meal-name{color:var(--text-primary);font-size:18px}.meal-time{color:#475569;color:var(--text-muted);font-size:14px;margin-top:4px}.meal-nutrition{color:#94a3b8;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:14px;gap:16px}.meal-nutrition span{background:#00d9a50d;background:var(--bg-section);border-radius:100px;padding:4px 12px}.empty-state{padding:48px 24px}.camera-container,.empty-state{background:#00d9a50d;background:var(--bg-section);border-radius:12px}.camera-container{margin:0 auto;max-width:600px;overflow:hidden;position:relative;width:100%}.camera-video{border-radius:12px;display:block;height:auto;width:100%}.camera-video.active{min-height:400px;object-fit:cover}.camera-placeholder{gap:24px;padding:80px 24px}.camera-controls{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:24px}.captured-image{border-radius:12px;display:block;height:auto;width:100%}.analysis-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a14eb;border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.analysis-loading-container{align-items:center;display:flex;flex-direction:column;padding:20px;text-align:center}.analysis-spinner{align-items:center;display:flex;height:100px;justify-content:center;margin-bottom:24px;position:relative;width:100px}.spinner-ring{animation:spinRing 1.5s linear infinite;border:3px solid #0000;border-radius:50%;height:100%;position:absolute;width:100%}.spinner-ring:first-child{animation-delay:0s;border-top-color:#00d4aa}.spinner-ring:nth-child(2){animation-delay:.15s;animation-direction:reverse;border-right-color:#3b82f6;height:80%;width:80%}.spinner-ring:nth-child(3){animation-delay:.3s;border-bottom-color:#f59e0b;height:60%;width:60%}@keyframes spinRing{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spinner-icon{animation:pulse 1s ease-in-out infinite;color:#00d4aa}.analysis-title{color:#fff;font-size:18px;font-weight:700;margin:0 0 8px}.analysis-subtitle{color:#888;font-size:14px;margin:0 0 20px}.analysis-progress-dots{display:flex;gap:8px}.analysis-progress-dots .dot{animation:dotBounce 1.4s ease-in-out infinite both;background:#00d4aa;border-radius:50%;height:10px;width:10px}.analysis-progress-dots .dot:first-child{animation-delay:0s}.analysis-progress-dots .dot:nth-child(2){animation-delay:.16s}.analysis-progress-dots .dot:nth-child(3){animation-delay:.32s}@keyframes dotBounce{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.divider{color:#475569;color:var(--text-muted);font-size:14px}.search-section{margin:0 auto;max-width:600px}.search-input{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:100px;font-family:Satoshi;padding:16px 20px;transition:all .2s ease}.search-input:focus{box-shadow:0 0 0 3px #0080ff1a}.search-results{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;margin-top:16px;max-height:400px;overflow-y:auto}.search-result-item{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-light);cursor:pointer;padding:16px;transition:all .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#00d9a50d;background:var(--bg-section)}.result-name{color:#fff;color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:4px}.result-nutrition{color:#94a3b8;color:var(--text-secondary);font-size:14px}.food-details{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;margin-top:24px;padding:24px}.meal-type-selector,.quantity-selector{margin:24px 0}.meal-type-selector label,.quantity-selector label{display:block;font-weight:500;margin-bottom:8px}.meal-type-select,.quantity-input{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:8px;font-family:Satoshi;font-size:16px;padding:12px 16px;width:100%}.meal-type-select:focus,.quantity-input:focus{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 0 0 3px #0080ff1a;outline:none}.nutrition-info{background:#00d9a50d;background:var(--bg-section);border-radius:8px;margin:24px 0;padding:16px}.nutrition-row{display:flex;font-size:16px;justify-content:space-between;padding:8px 0}.muscle-groups{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:24px}.muscle-group-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;cursor:pointer;padding:24px;text-align:center;transition:all .2s ease}.muscle-group-card:hover{border-color:#ffffff1f;border-color:var(--border-medium);box-shadow:0 8px 24px #00000014;transform:translateY(-4px)}.muscle-icon{font-size:48px;margin-bottom:12px}.muscle-name{color:#fff;color:var(--text-primary);font-size:16px;font-weight:600}.exercises-list{display:flex;flex-direction:column;gap:16px;margin-top:24px}.exercise-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;padding:20px;transition:all .2s ease}.exercise-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.exercise-name{color:#fff;color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:8px}.exercise-details{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:14px;gap:12px;margin-bottom:8px}.exercise-description{color:#475569;color:var(--text-muted);font-size:14px;margin-top:8px}.profile-form{margin:0 auto;max-width:600px}.form-group{margin-bottom:24px}.form-group label{margin-bottom:8px}.form-input,.form-select{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:8px;font-family:Satoshi;font-size:16px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus,.form-select:focus{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 0 0 3px #0080ff1a;outline:none}.subscription-info{background:linear-gradient(135deg,#00d9a526,#0080ff26);background:var(--gradient-hero);border-radius:12px;margin-top:32px;padding:24px;text-align:center}.subscription-badge{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:100px;color:#fff;display:inline-block;font-weight:600;margin-bottom:12px;padding:8px 24px}.bottom-nav{background:#0c1322;background:var(--bg-card);box-shadow:0 -4px 16px #00000014;padding:8px 0}.nav-item{background:#0000;flex:1 1;max-width:120px;padding:8px 16px}.nav-item:hover{opacity:.7}.nav-icon{font-size:24px;margin-bottom:4px}.nav-label{color:#94a3b8;color:var(--text-secondary);font-size:12px}.nav-item.active .nav-label{color:#00d9a5;color:var(--brand-primary);font-weight:600}@media (max-width:809px){.app-content{padding:16px}.stats-grid{gap:16px;grid-template-columns:1fr}.action-buttons{width:100%}.action-buttons button{flex:1 1}.muscle-groups{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.section-header{align-items:flex-start;flex-direction:column}}@media (min-width:810px) and (max-width:1199px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1200px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.login-container{align-items:center;background:#060a11;background:var(--bg-page);display:flex;justify-content:center;min-height:100vh;min-height:100dvh;padding:20px}.login-box{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:20px;box-shadow:0 24px 64px #0006;max-width:100%;padding:32px 24px;position:relative;width:100%}.back-to-landing-btn{align-items:center;background:#0000;border:none;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:16px;padding:8px 0;transition:color .2s ease}.back-to-landing-btn:hover{color:#00d9a5;color:var(--brand-primary)}.back-to-landing-btn svg{transition:transform .2s ease}.back-to-landing-btn:hover svg{transform:translateX(-4px)}.login-header{margin-bottom:24px;text-align:center}.login-logo{border-radius:16px;display:block;height:80px;margin:0 auto 12px;object-fit:contain;width:80px}.brand-display{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);-webkit-background-clip:text;background-clip:text;font-family:Manrope,sans-serif;font-size:28px;font-weight:800;margin-bottom:4px}.login-subtitle{color:#94a3b8;color:var(--text-secondary);font-size:14px}.login-tabs{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:100px;display:flex;gap:4px;margin-bottom:24px;padding:4px}.tab-button{background:#0000;border:none;border-radius:100px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;flex:1 1;font-family:IBM Plex Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.tab-button.active{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);box-shadow:0 0 20px #00d9a54d;box-shadow:var(--glow-teal);color:#fff}.login-form{margin-bottom:24px}.remember-me-container{margin:16px 0}.remember-me-label{align-items:center;cursor:pointer;display:flex;gap:10px;position:relative;-webkit-user-select:none;user-select:none}.remember-me-checkbox{accent-color:var(--primary);cursor:pointer;height:18px;min-width:18px;position:relative;width:18px}.remember-me-text{color:#94a3b8;color:var(--text-secondary);font-size:14px}.error-message{background:#ff3b301a;border:1px solid #ff3b3033;border-radius:8px;color:#ff3b30;font-size:14px;margin-bottom:16px;padding:12px 16px}.btn-link{background:#0000;border:none;color:var(--primary);cursor:pointer;font-size:14px;padding:8px 0;transition:color .2s}.btn-link:hover{color:#00e5cc;text-decoration:underline}.divider-line{align-items:center;color:#475569;color:var(--text-muted);display:flex;font-size:14px;margin:24px 0}.divider-line:after,.divider-line:before{background:#ffffff14;background:var(--border-light);content:"";flex:1 1;height:1px}.divider-line span{padding:0 16px}.btn-google{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:100px;color:#fff;color:var(--text-primary);cursor:pointer;display:flex;font-family:IBM Plex Sans,sans-serif;font-size:16px;font-weight:600;gap:12px;justify-content:center;padding:14px 24px;transition:all .2s ease;width:100%}.btn-google:hover{background:#0c1322;background:var(--bg-card);border-color:#00d9a5;border-color:var(--brand-primary);transform:scale(1.02)}.btn-google:disabled{cursor:not-allowed;opacity:.5}.login-footer{margin-top:24px;text-align:center}.loading-container{align-items:center;display:flex;flex-direction:column;gap:24px;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #00d9a50d;border-top-color:#00d9a5;border:4px solid var(--bg-section);border-radius:50%;border-top-color:var(--brand-primary);height:48px;width:48px}.profile-header-info{align-items:center;background:#00d9a50d;background:var(--bg-section);border-radius:12px;display:flex;gap:24px;margin-bottom:32px;padding:24px}.profile-avatar{align-items:center;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:50%;display:flex;height:80px;justify-content:center;overflow:hidden;width:80px}.profile-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{color:#fff;font-size:32px;font-weight:700}.btn-logout{background:#ff3b301a;border:1px solid #ff3b3033;border-radius:100px;color:#ff3b30;cursor:pointer;font-family:Satoshi;font-size:16px;font-weight:600;margin-top:24px;padding:14px 24px;transition:all .2s ease;width:100%}.btn-logout:hover{background:#ff3b3026;transform:scale(1.02)}.support-section{align-items:flex-start;background:linear-gradient(135deg,#00d9a514,#00968814);border:1px solid #00d9a533;border-radius:16px;display:flex;gap:16px;margin-top:24px;padding:20px}.support-icon{align-items:center;background:#00d9a526;border-radius:12px;color:#00d9a5;color:var(--brand-primary);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.support-content{flex:1 1}.support-title{color:#fff;color:var(--text-primary);font-size:16px;font-weight:700;margin:0 0 4px}.support-text{color:#475569;color:var(--text-muted);font-size:14px;margin:0 0 8px}.support-email{align-items:center;background:#00d9a51a;border-radius:8px;color:#00d9a5;color:var(--brand-primary);display:inline-flex;font-size:15px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:all .2s ease}.support-email:hover{background:#00d9a533;transform:translateY(-1px)}.profile-social-section{background:linear-gradient(135deg,#ffffff08,#ffffff03);border:1px solid #ffffff14;border-radius:16px;margin-top:24px;padding:20px}.social-section-title{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 16px;text-align:center}.profile-social-links{display:flex;gap:16px;justify-content:center}.profile-social-link{align-items:center;border-radius:12px;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;text-decoration:none;transition:all .3s ease}.profile-social-link.whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}.profile-social-link.whatsapp:hover{box-shadow:0 4px 20px #25d36666;transform:translateY(-2px)}.profile-social-link.instagram{background:linear-gradient(135deg,#833ab4,#fd1d1d 50%,#fcaf45);color:#fff}.profile-social-link.instagram:hover{box-shadow:0 4px 20px #833ab466;transform:translateY(-2px)}.profile-social-link svg{flex-shrink:0}@media (max-width:809px){.login-box{padding:32px 24px}.profile-header-info{flex-direction:column;text-align:center}}.gamification-card{background:linear-gradient(135deg,#00d9a526,#0080ff26);background:var(--gradient-hero);box-shadow:0 8px 24px #00000014;margin-bottom:32px;padding:24px}.gamification-header{margin-bottom:24px}.level-badge{gap:8px;padding:8px 20px}.level-icon{font-size:20px}.level-text{font-size:16px;font-weight:600}.points-display{color:#fff;color:var(--text-primary);font-size:24px;font-weight:700}.gamification-stats{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:24px}.stat-item{background:#fff9;gap:12px;padding:16px}.stat-icon{font-size:32px}.stat-value{font-size:24px;line-height:1}.stat-label{color:#94a3b8;color:var(--text-secondary);font-size:12px;margin-top:4px}.level-progress{margin-top:16px}.progress-info{display:flex;justify-content:space-between;margin-bottom:8px}.achievements-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:32px}.achievement-stat{gap:12px}.achievement-icon{font-size:36px}.achievement-value{color:#fff;color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.achievement-label{color:#94a3b8;color:var(--text-secondary);font-size:14px;margin-top:4px}.badges-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.badge-card{border:2px solid #ffffff14;border:2px solid var(--border-light);border-radius:16px;padding:24px;position:relative;text-align:center;transition:all .3s ease}.badge-card.earned{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 4px 16px #0080ff33}.badge-card.earned:hover{box-shadow:0 8px 24px #0080ff4d;transform:translateY(-4px)}.badge-card.locked{filter:grayscale(100%);opacity:.5}.badge-icon{font-size:64px;margin-bottom:16px}.badge-name{font-weight:700;margin-bottom:8px}.badge-description{margin-bottom:12px}.badge-points{background:#00d9a50d;background:var(--bg-section);border-radius:100px;color:#00d9a5;color:var(--brand-primary);display:inline-block;font-size:14px;font-weight:600;padding:6px 16px}.badge-earned-date{color:#475569;color:var(--text-muted);font-size:12px;margin-top:12px}.badge-locked{font-size:24px;position:absolute;right:16px;top:16px}.modal-overlay{align-items:flex-start;animation:fadeIn .3s ease;background:#000000b3;overflow-y:auto;padding:20px 20px 100px}.badge-modal{animation:slideUp .4s ease;box-shadow:0 24px 64px #0000004d;padding:48px;text-align:center;width:90%}.modal-celebration{animation:bounce .6s ease infinite;font-size:72px;margin-bottom:16px}.modal-badge-icon{font-size:96px;margin:24px 0}.modal-badge-name{color:#fff;color:var(--text-primary);font-size:28px;font-weight:700;margin-bottom:12px}.modal-badge-description{color:#94a3b8;color:var(--text-secondary);font-size:16px;line-height:1.5;margin-bottom:16px}.modal-badge-points{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:100px;color:#fff;display:inline-block;font-size:18px;font-weight:600;margin-bottom:32px;padding:8px 24px}@media (max-width:809px){.badges-grid,.gamification-stats{grid-template-columns:1fr}.badge-modal{padding:32px 24px}}.analysis-modal{animation:slideUp .4s ease;background:#0c1322;background:var(--bg-card);border-radius:20px;box-shadow:0 24px 64px #0000004d;margin-bottom:70px;max-height:calc(100vh - 100px);max-height:calc(100dvh - 100px);max-width:450px;overflow-y:auto;padding:16px 16px 90px;width:92%}.analysis-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.confidence-badge{align-items:center;border-radius:100px;display:flex;font-size:12px;font-weight:600;padding:6px 14px}.confidence-verified{background:linear-gradient(135deg,#00d4aa33,#00a08533);border:1px solid #00d4aa4d;color:#00d4aa}.confidence-high{background:#22c55e26;color:#16a34a}.confidence-medium{background:#fbbf2426;color:#d97706}.confidence-low{background:#ef444426;color:#dc2626}.analysis-food-name{color:#fff;color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2;margin-bottom:6px;text-transform:capitalize}.analysis-description{color:#94a3b8;color:var(--text-secondary);font-size:13px;line-height:1.4;margin-bottom:12px}.analysis-nutrition-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-bottom:12px}.nutrition-item{background:#00d9a50d;background:var(--bg-section);border-radius:12px;flex-direction:column;gap:2px;padding:10px 8px;text-align:center}.nutrition-item.calories{background:#ef44441a}.nutrition-item.protein{background:#3b82f61a}.nutrition-item.carbs{background:#fbbf241a}.nutrition-item.fat{background:#a855f71a}.nutrition-value{font-size:18px;font-weight:700}.nutrition-label{font-size:10px;font-weight:500}.analysis-meal-type-section{background:#00d9a50d;background:var(--bg-section);border-radius:10px;margin-bottom:12px;padding:10px}.analysis-meal-type-section label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:8px}.meal-type-selector-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr)}.meal-type-option{align-items:center;background:#0c1322;background:var(--bg-card);border:2px solid #ffffff1f;border:2px solid var(--border-medium);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:8px 4px;transition:all .2s ease}.meal-type-option:hover{background:#00d9a51a}.meal-type-option.active,.meal-type-option:hover{border-color:#00d9a5;border-color:var(--brand-primary)}.meal-type-option.active{background:#00d9a526}.meal-type-icon{font-size:16px;margin-bottom:2px}.meal-type-label{color:#94a3b8;color:var(--text-secondary);font-size:9px;font-weight:600;line-height:1.1;text-align:center}.meal-type-option.active .meal-type-label{color:#00d9a5;color:var(--brand-primary)}@media (max-width:400px){.meal-type-selector-grid{gap:6px;grid-template-columns:repeat(4,1fr)}.meal-type-option{padding:8px 4px}.meal-type-icon{font-size:18px}.meal-type-label{font-size:9px}}@media (max-width:350px){.meal-type-selector-grid{grid-template-columns:repeat(4,1fr)}}.analysis-quantity-section{align-items:center;background:#00d9a50d;background:var(--bg-section);border-radius:10px;display:flex;gap:12px;margin-bottom:12px;padding:10px 12px}.analysis-quantity-section .quantity-input{border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:8px;flex:1 1;font-size:16px;font-weight:600;padding:10px 14px;text-align:center}.analysis-modal-actions{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:8px}.analysis-modal-actions .btn-correction,.analysis-modal-actions .btn-primary,.analysis-modal-actions .btn-secondary{flex:1 1;font-size:14px;min-width:100px;padding:12px 16px}.btn-correction{background:#0000;border:2px solid #f59e0b;border-radius:12px;color:#f59e0b;cursor:pointer;font-weight:600;transition:all .2s ease}.btn-correction:hover{background:#f59e0b1a}.analysis-source{align-items:center;background:linear-gradient(135deg,#00d4aa14,#667eea14);border:1px solid #00d4aa26;border-radius:10px;display:flex;font-size:14px;gap:8px;margin-bottom:16px;padding:10px 14px}.source-label{color:#94a3b8;color:var(--text-secondary)}.source-value{align-items:center;display:flex;font-weight:600}.source-ai_estimated,.source-database_verified,.source-verified{color:#00d4aa}.correction-mode{background:#f59e0b0d;border:1px solid #f59e0b33;border-radius:12px;margin:16px 0;padding:16px}.name-correction-section{background:#00d4aa1a;border:1px solid #00d4aa33;border-radius:12px;margin-bottom:20px;padding:16px}.name-correction-section input{background:#0000004d;border:1px solid #fff3;border-radius:8px;color:#fff;flex:1 1;font-size:14px;min-width:0;padding:12px 16px}.btn-recalculate{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:12px 16px;white-space:nowrap}.btn-recalculate:disabled{cursor:not-allowed;opacity:.6}.name-correction-input-row{align-items:center;display:flex;gap:10px}.correction-name-input{background:#0000004d;border:1px solid #fff3;border-radius:8px;color:#fff;flex:1 1;font-size:14px;min-width:0;padding:12px 14px}.correction-name-input:focus{border-color:#00d4aa;outline:none}.correction-name-input::placeholder{color:#fff6}.spinner-small{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.correction-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:16px}.correction-item{display:flex;flex-direction:column;gap:4px}.correction-item label{color:#94a3b8;color:var(--text-secondary);font-size:12px;font-weight:500}.correction-item input{background:var(--bg-input);border:1px solid #ffffff1f;border:1px solid var(--border-medium);border-radius:8px;box-sizing:border-box;color:#fff;color:var(--text-primary);font-size:16px;font-weight:600;padding:10px 12px;width:100%}.correction-item input:focus{border-color:#f59e0b;outline:none}.correction-actions{display:flex;flex-wrap:wrap;gap:12px}.correction-actions .btn-primary,.correction-actions .btn-secondary{flex:1 1;min-width:120px;padding:12px 16px}@media (max-width:480px){.correction-grid{gap:8px;grid-template-columns:1fr 1fr}.correction-item input{font-size:14px;padding:8px 10px}.correction-item label{font-size:11px}.correction-mode{margin:12px 0;padding:12px}.correction-actions{flex-direction:column}.correction-actions .btn-primary,.correction-actions .btn-secondary{width:100%}.name-correction-section{padding:12px}.name-correction-input-row{flex-direction:column;gap:10px}.correction-name-input{font-size:15px;padding:12px 14px;width:100%}.btn-recalculate{justify-content:center;padding:14px 20px;width:100%}.analysis-nutrition-grid{grid-template-columns:repeat(2,1fr)}.analysis-modal{margin-bottom:70px;max-height:calc(100vh - 100px);padding:20px 20px 100px}.analysis-food-name{font-size:22px}.analysis-description{font-size:13px;margin-bottom:16px}.analysis-modal-actions{flex-direction:column}.analysis-modal-actions .btn-correction,.analysis-modal-actions .btn-primary,.analysis-modal-actions .btn-secondary{min-width:auto;width:100%}}.period-selector{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px}.period-btn{background:#0c1322;background:var(--bg-card);border:2px solid #ffffff1f;border:2px solid var(--border-medium);border-radius:100px;color:#fff;color:var(--text-primary);cursor:pointer;flex:1 1;font-family:Satoshi;font-size:16px;font-weight:600;min-width:100px;padding:12px 24px;transition:all .2s ease}.period-btn:hover{border-color:#00d9a5;border-color:var(--brand-primary);transform:scale(1.02)}.period-btn.active{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-color:#0000;color:#fff}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.summary-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;padding:24px;transition:all .2s ease}.summary-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.summary-label{font-weight:500;margin-bottom:8px}.summary-value{font-size:42px;font-weight:700;line-height:1;margin-bottom:4px}.summary-subtitle{color:#475569;color:var(--text-muted);font-size:14px;margin-bottom:12px}.summary-change{border-radius:100px;display:inline-block;font-size:14px;font-weight:600;padding:6px 12px}.summary-change.positive{background:#00c49f1a;color:#00c49f}.summary-change.negative{background:#ff3b301a;color:#ff3b30}.summary-info{color:#94a3b8;color:var(--text-secondary);font-size:14px;margin-top:8px}.chart-container{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:32px;padding:24px}.chart-header{margin-bottom:24px}.empty-chart{background:#0c1322;background:var(--bg-card);border:2px dashed #ffffff1f;border:2px dashed var(--border-medium);border-radius:16px;margin-bottom:32px;padding:64px 24px;text-align:center}.empty-chart .btn-primary{margin-top:16px}.macros-grid{grid-gap:32px;align-items:center;display:grid;gap:32px;grid-template-columns:1fr 1fr}.macros-stats{display:flex;flex-direction:column;gap:24px}.macro-stat{align-items:center;display:flex;gap:16px}.macro-color{border-radius:50%;height:24px;width:24px}.macro-name{color:#fff;color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:4px}.macro-value{font-size:24px;line-height:1}.macro-calories{color:#94a3b8;color:var(--text-secondary);font-size:14px}.modal-actions{display:flex;gap:12px;margin-top:24px}.modal-actions button{flex:1 1}@media (max-width:809px){.macros-grid{grid-template-columns:1fr}.period-selector{flex-direction:column}.period-btn{width:100%}.summary-cards{grid-template-columns:1fr}.chart-container{padding:16px}}.search-header-actions{margin-bottom:24px}.btn-barcode{align-items:center;background:linear-gradient(135deg,#00d9a526,#0080ff26);background:var(--gradient-hero);border:2px solid #ffffff1f;border:2px solid var(--border-medium);border-radius:12px;cursor:pointer;display:flex;font-family:Satoshi;font-size:16px;font-weight:600;gap:12px;justify-content:center;padding:16px 24px;transition:all .2s ease;width:100%}.btn-barcode:hover{box-shadow:0 8px 24px #0000001f;transform:scale(1.02)}.barcode-icon{font-size:24px}.camera-quick-actions{margin-bottom:24px}.btn-barcode-quick{background:linear-gradient(135deg,#0080ff,#00c49f);border:none;box-shadow:0 4px 16px #0080ff4d;color:#fff;font-family:Satoshi;font-size:16px;font-weight:600;gap:12px;padding:16px 24px}.btn-barcode-quick:hover{box-shadow:0 6px 20px #0080ff66;transform:scale(1.02)}.btn-barcode-quick:active{transform:scale(.98)}.scanner-modal{animation:slideUp .4s ease;background:#0c1322;background:var(--bg-card);border-radius:24px;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.barcode-scanner-container{padding:24px 24px 32px}.scanner-header{justify-content:space-between;margin-bottom:24px}.btn-close,.scanner-header{align-items:center;display:flex}.btn-close{background:#0000001a;border:none;border-radius:50%;cursor:pointer;font-size:24px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.btn-close:hover{background:#0003;transform:scale(1.1)}.scanner-instructions{background:#00d9a50d;background:var(--bg-section);border-radius:12px;margin-bottom:24px;padding:16px;text-align:center}.scanner-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:64px 24px}.scanner-error{background:#ff3b301a;border:1px solid #ff3b3033;border-radius:12px;margin-bottom:24px;padding:32px 24px;text-align:center}.scanner-error.limit-error{background:linear-gradient(135deg,#ff980026,#ffc10726);border:1px solid #ff98004d}.scanner-error.limit-error p{color:#e65100}.limit-error-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.limit-error-actions .btn-primary{background:linear-gradient(135deg,#ff9800,#f57c00)}.scanner-error p{color:#ff3b30;margin-bottom:16px}.scanner-error-actions{display:flex;flex-direction:column;gap:12px;margin-top:16px}.scanner-error-actions .btn-primary{background:linear-gradient(135deg,#00bfa6,#00897b);font-size:16px;padding:14px 24px}.scanner-error-actions .btn-secondary{background:#0000;color:#94a3b8;color:var(--text-secondary)}.manual-entry-form{background:#00d9a50d;background:var(--bg-section);border-radius:16px;margin:16px 0;padding:20px}.manual-entry-form h3{margin-bottom:8px}.barcode-display{background:#0000000d;border-radius:4px;color:#94a3b8;color:var(--text-secondary);display:inline-block;font-family:monospace;margin-bottom:16px;padding:4px 8px}.ai-photo-option{background:linear-gradient(135deg,#00d9a51a,#00b4d81a);border:1px dashed #00d9a5;border:1px dashed var(--brand-primary);border-radius:12px;margin-bottom:20px;padding:16px;text-align:center}.ai-option-label{color:#94a3b8;color:var(--text-secondary);margin-bottom:10px}.btn-ai-photo{align-items:center;background:linear-gradient(135deg,#00d9a5,#00b4d8);background:linear-gradient(135deg,var(--brand-primary),#00b4d8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-ai-photo:hover{box-shadow:0 4px 15px #00d9a54d;transform:translateY(-2px)}.ai-option-desc{color:#475569;color:var(--text-muted);font-size:12px;margin-top:8px}.ai-success-badge{background:#00d9a526;border-radius:8px;margin-bottom:16px;padding:10px 16px;text-align:center}.ai-badge{color:#00d9a5;color:var(--brand-primary);font-size:14px;font-weight:600}.quantity-highlight{background:linear-gradient(135deg,#00d9a514,#00b4d814);border:1px solid #00d9a54d;border-radius:12px;margin-bottom:20px;padding:16px}.quantity-highlight .form-input{font-size:20px;font-weight:600;text-align:center}.quantity-hint{color:#00d9a5;color:var(--brand-primary);font-size:12px;margin-top:8px;text-align:center}.photo-capture-container{background:#00d9a50d;background:var(--bg-section);border-radius:16px;margin:16px 0;padding:20px;text-align:center}.photo-capture-container h3{margin-bottom:8px}.photo-instruction{color:#94a3b8;color:var(--text-secondary);margin-bottom:20px}.photo-actions-initial{display:flex;flex-direction:column;gap:12px;margin:20px 0}.btn-photo-take{align-items:center;display:flex;font-size:16px;gap:8px;justify-content:center;padding:16px 24px}.photo-preview{margin:20px 0}.captured-photo-img{border:2px solid #ffffff14;border:2px solid var(--border-light);border-radius:12px;max-height:300px;max-width:100%;object-fit:contain}.photo-preview-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.photo-preview-actions button{flex:1 1;max-width:180px}.photo-analyzing{align-items:center;display:flex;flex-direction:column;gap:16px;padding:40px 20px}.photo-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;margin:16px 0;padding:12px 16px}.photo-error .error-text{color:#ef4444;margin-bottom:12px}.photo-footer-actions{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-top:20px}.btn-text{background:none;border:none;color:#94a3b8;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:8px;text-decoration:underline}.btn-text:hover{color:#fff;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-input{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;color:#fff;color:var(--text-primary);font-size:16px;padding:14px 16px;width:100%}.form-input::placeholder{color:#475569;color:var(--text-muted)}.form-input:focus{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 0 0 3px #00d9a51a;outline:none}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{padding-right:48px}.password-toggle-btn{align-items:center;background:#0000;border:none;color:#475569;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .2s ease}.password-toggle-btn:hover{color:#00d9a5;color:var(--brand-primary)}.form-row{grid-gap:12px;gap:12px;grid-template-columns:1fr 1fr}.hint-text{color:#475569;color:var(--text-muted);font-style:italic;margin:12px 0}.button-group{display:flex;gap:12px;margin-top:16px;padding-bottom:16px}.button-group .btn-primary,.button-group .btn-secondary{flex:1 1}.scanner-wrapper{margin:24px 0;position:relative;width:100%}.camera-loading-overlay{align-items:center;background:#0d1117f2;border-radius:12px;bottom:0;display:flex;flex-direction:column;gap:16px;justify-content:center;left:0;min-height:300px;position:absolute;right:0;top:0;z-index:99}.camera-loading-overlay p{color:#fff;font-size:14px;font-weight:500}.barcode-reader{background:#000;border-radius:12px;height:350px;margin:0 auto;max-width:500px;overflow:hidden;position:relative;width:100%}.scan-frame-overlay{align-items:center;display:flex;height:350px;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:100}.scan-frame,.scan-frame-overlay{background:#0000;pointer-events:none}.scan-frame{aspect-ratio:1.6/1;max-height:160px;max-width:260px;position:relative;width:65%}.scan-corner{animation:cornerPulse 1.5s ease-in-out infinite;background:#0000;border:4px solid #00d4aa!important;height:28px;position:absolute;width:28px;z-index:101}@keyframes cornerPulse{0%,to{border-color:#00d4aa;box-shadow:0 0 5px #00d4aa80;opacity:1}50%{border-color:#0fc;box-shadow:0 0 15px #00ffccb3;opacity:.7}}.scan-corner.top-left{animation-delay:0s;border-bottom:none!important;border-radius:8px 0 0 0;border-right:none!important;left:0;top:0}.scan-corner.top-right{animation-delay:.1s;border-bottom:none!important;border-left:none!important;border-radius:0 8px 0 0;right:0;top:0}.scan-corner.bottom-left{animation-delay:.2s;border-radius:0 0 0 8px;border-right:none!important;border-top:none!important;bottom:0;left:0}.scan-corner.bottom-right{animation-delay:.3s;border-left:none!important;border-radius:0 0 8px 0;border-top:none!important;bottom:0;right:0}.scan-line{animation:scanLineMove 2s ease-in-out infinite;background:linear-gradient(90deg,#0000,#00d4aa66 15%,#00d4aa 35%,#0fc 50%,#00d4aa 65%,#00d4aa66 85%,#0000)!important;border-radius:2px;box-shadow:0 0 8px #00d4aa,0 0 16px #00d4aa99,0 0 32px #00d4aa4d;height:4px;left:8px;position:absolute;right:8px;top:0;z-index:102}.scan-line:before{background:linear-gradient(180deg,#0000,#00d4aa1a 40%,#00d4aa33 50%,#00d4aa1a 60%,#0000);content:"";height:30px;left:0;pointer-events:none;position:absolute;right:0;top:-15px}@keyframes scanLineMove{0%{top:0}50%{top:calc(100% - 4px)}to{top:0}}#barcode-reader{background:#000!important;border:none!important;max-height:350px!important;overflow:hidden!important;position:relative!important}#barcode-reader,#barcode-reader video{border-radius:12px!important;height:350px!important;width:100%!important}#barcode-reader video{display:block!important;left:0!important;object-fit:cover!important;position:absolute!important;top:0!important;z-index:1!important}#barcode-reader__scan_region{border-radius:12px!important;height:350px!important;overflow:hidden!important;position:relative!important}#barcode-reader__dashboard_section,#barcode-reader__dashboard_section_csr,#barcode-reader__header_message,#barcode-reader__scan_region img{display:none!important}#barcode-reader__camera_permission_button{background:linear-gradient(135deg,#00d9a5,#0080ff)!important;background:var(--gradient-button)!important;border:none!important;border-radius:100px!important;color:#fff!important;cursor:pointer!important;font-family:Satoshi!important;font-size:16px!important;font-weight:600!important;padding:14px 24px!important}#qr-shaded-region{display:none!important}.scanner-footer{margin-top:24px}.confirmation-actions,.scanner-footer{padding-bottom:16px}.product-confirmation{padding:24px 0}.product-image{background:#00d9a50d;background:var(--bg-section);border-radius:12px;display:block;height:200px;margin:0 auto 24px;object-fit:contain;padding:16px;width:200px}.product-confirmation h3{margin-bottom:8px;text-align:center}.product-confirmation .body-small{color:#94a3b8;color:var(--text-secondary);margin-bottom:24px;text-align:center}.product-confirmation .product-brand{color:var(--accent-primary);font-weight:500;margin-bottom:16px;text-align:center}.nutrition-preview{background:#00d9a50d;background:var(--bg-section);border-radius:12px;margin-bottom:24px;padding:20px}.nutrition-item{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:12px 0}.nutrition-item:last-child{border-bottom:none}.nutrition-label{color:#94a3b8;color:var(--text-secondary);font-size:16px}.nutrition-value{color:#fff;color:var(--text-primary);font-size:16px;font-weight:600}.confirmation-actions{display:flex;gap:12px;margin-top:24px}.confirmation-actions button{flex:1 1}@media (max-width:809px){.scanner-modal{border-radius:24px 24px 0 0;max-height:95vh;max-width:100%;width:100%}.barcode-scanner-container{padding:16px}.scan-frame{height:140px;width:220px}.scan-corner{border-width:3px;height:24px;width:24px}.scan-line{height:3px;left:6px;right:6px}.barcode-scanner-container .button-group,.confirmation-actions{flex-direction:column;padding-bottom:24px}.scanner-footer{padding-bottom:24px}}.achievements-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.achievement-stat{align-items:center;background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;display:flex;gap:16px;padding:20px}.badges-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.badge-card{align-items:center;background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;display:flex;gap:16px;padding:20px;transition:all .2s ease}.badge-card:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.badge-icon{align-items:center;background:#00d9a50d;background:var(--bg-section);border-radius:50%;display:flex;flex-shrink:0;font-size:48px;height:64px;justify-content:center;width:64px}.badge-info{flex:1 1}.badge-name{color:#fff;color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:4px}.badge-description{color:#94a3b8;color:var(--text-secondary);font-size:14px;line-height:1.4;margin-bottom:8px}.badge-date{color:#475569;color:var(--text-muted);font-size:12px;font-weight:500}.modal-overlay{padding:24px;z-index:2000}.badge-modal{animation:modalSlideIn .3s ease-out;background:#0c1322;background:var(--bg-card);border-radius:24px;box-shadow:0 24px 64px #0003;max-width:400px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.badge-modal-content{padding:40px 32px 32px;text-align:center}.badge-celebration{animation:bounce .6s ease-in-out;font-size:64px;margin-bottom:16px}.new-badge-display{background:linear-gradient(135deg,#00d9a526,#0080ff26);background:var(--gradient-hero);border-radius:16px;margin:24px 0 32px;padding:24px}.new-badge-icon{font-size:72px;margin-bottom:16px}.new-badge-name{color:#fff;color:var(--text-primary);font-size:20px;font-weight:700;margin-bottom:8px}.new-badge-description{color:#94a3b8;color:var(--text-secondary);font-size:14px;line-height:1.4}@media (max-width:809px){.achievements-stats,.badges-grid{grid-template-columns:1fr}.badge-card{flex-direction:column;text-align:center}.badge-modal-content{padding:32px 24px 24px}}.subscription-page{background:var(--background);margin:0 auto;max-width:1200px;min-height:100vh;padding:24px 24px 100px}.subscription-header{align-items:center;display:flex;gap:16px;margin-bottom:32px;padding-top:8px}.subscription-header .back-button{align-items:center;background:#e8f4ff;border:1px solid #b8dbff;border-radius:12px;color:#0080ff;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.subscription-header .back-button:hover{background:#d0e8ff;border-color:#0080ff}.subscription-header .page-title{color:#fff;color:var(--text-primary);font-size:24px;font-weight:700}.current-plan-card{background:linear-gradient(135deg,#0080ff,#00c853);border-radius:16px;color:#fff;margin-bottom:32px;overflow:hidden;padding:24px;position:relative}.current-plan-card:before{background:radial-gradient(circle,#ffffff1a 0,#0000 60%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:100%}.current-plan-badge{background:#fff3;border-radius:100px;display:inline-block;font-size:12px;font-weight:600;margin-bottom:12px;padding:4px 12px}.current-plan-card h3{font-size:28px;font-weight:700;margin-bottom:8px}.current-plan-price{font-size:18px;margin-bottom:8px;opacity:.9}.next-billing{font-size:14px;opacity:.8}.current-plan-card.cancelled{background:linear-gradient(135deg,#ff9800,#f57c00)}.cancellation-notice{align-items:flex-start;background:#fff3;border-radius:12px;display:flex;gap:12px;margin-top:16px;padding:16px}.cancellation-notice svg{flex-shrink:0;margin-top:2px}.cancellation-notice strong{display:block;font-size:14px;margin-bottom:4px}.cancellation-notice p{font-size:13px;margin:0;opacity:.95}.plans-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.plan-card{background:#fff;border:2px solid #e5e5e5;border-radius:16px;box-shadow:0 4px 16px #00000014;padding:24px;position:relative;transition:all .3s ease}.plan-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-4px)}.plan-card.popular{border-color:#0080ff;box-shadow:0 4px 20px #0080ff33}.plan-card.current{background:linear-gradient(135deg,#00c8531a,#00c8530d);border-color:#00c853;position:relative}.plan-card.current:before{display:none}.active-badge-translated{background:#00c853;border-radius:4px;font-size:10px;padding:4px 10px;right:12px;top:12px;z-index:1}.active-badge-translated,.popular-badge{color:#fff;font-weight:700;letter-spacing:.5px;position:absolute}.popular-badge{background:linear-gradient(135deg,#0080ff,#00c853);border-radius:100px;font-size:12px;left:50%;padding:6px 20px;text-transform:uppercase;top:-12px;transform:translateX(-50%)}.plan-name{color:#1a1a1a;font-size:24px;font-weight:700;margin-bottom:16px;text-align:center}.plan-price{background:#f8f9fa;border-radius:12px;margin-bottom:24px;padding:16px;text-align:center}.price-value{color:#0080ff;font-size:40px;font-weight:800}.price-period{color:#666;font-size:16px;font-weight:500}.plan-features{list-style:none;margin:0 0 24px;padding:0}.plan-features li{align-items:flex-start;border-bottom:1px solid #f0f0f0;color:#333;display:flex;font-size:14px;gap:12px;padding:10px 0}.plan-features li:last-child{border-bottom:none}.plan-features li svg{flex-shrink:0;margin-top:2px}.plan-features li.feature-unavailable{opacity:.7}.plan-features li .text-unavailable{color:#999;text-decoration:line-through;-webkit-text-decoration-color:#ff475766;text-decoration-color:#ff475766}.plan-features li .feature-icon-x{flex-shrink:0}.plan-button{background:linear-gradient(135deg,#0080ff,#06c);border:none;border-radius:100px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;letter-spacing:.5px;padding:16px 24px;text-transform:uppercase;transition:all .3s ease;width:100%}.plan-button:hover:not(:disabled){box-shadow:0 6px 20px #0080ff66;transform:translateY(-2px)}.plan-button:disabled{cursor:not-allowed;opacity:.6}.plan-button.disabled-downgrade{background:linear-gradient(135deg,#6c757d,#5a6268);opacity:.7}.plan-button.current{background:linear-gradient(135deg,#00c853,#00a844)}.payment-form-container{background:#fff;border:2px solid #e5e5e5;border-radius:16px;box-shadow:0 4px 16px #00000014;margin:0 auto;max-width:500px;padding:32px}.payment-form-header{margin-bottom:32px;text-align:center}.payment-form-header h2{color:#1a1a1a;font-size:24px;font-weight:700;margin-bottom:8px}.payment-amount{color:#0080ff;font-size:32px;font-weight:700}.payment-form .form-group{margin-bottom:20px}.payment-form label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.payment-form input{background:#fff;border:2px solid #e5e5e5;border-radius:12px;color:#1a1a1a;font-size:16px;padding:14px 16px;transition:border-color .3s ease;width:100%}.payment-form input:focus{border-color:#0080ff;outline:none}.payment-form input::placeholder{color:#999}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.payment-secure-note{align-items:center;background:#0080ff0d;border-radius:8px;color:var(--text-tertiary);display:flex;font-size:12px;gap:8px;justify-content:center;margin:24px 0;padding:12px}.payment-actions{display:flex;gap:16px;margin-top:24px}.payment-actions button{align-items:center;border-radius:100px;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .3s ease}.btn-secondary{background:#0000;border:2px solid var(--border-color);color:#94a3b8;color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){border-color:#94a3b8;border-color:var(--text-secondary)}.btn-primary{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #0080ff4d;transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.loading-spinner-small{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.cancel-subscription-section{border-top:1px solid var(--border-color);margin-top:32px;padding-top:32px;text-align:center}.btn-cancel-subscription{background:#0000;border:2px solid #f44;border-radius:100px;color:#f44;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-cancel-subscription:hover:not(:disabled){background:#f44;color:#fff}.btn-cancel-subscription:disabled{cursor:not-allowed;opacity:.6}.alert{align-items:center;border-radius:12px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}.alert-error{background:#fff0f0;border:2px solid #fcc;color:#c00}.alert-success{background:#f0fff4;border:2px solid #b3ffd1;color:#00802b}@media (max-width:809px){.subscription-page{background:#fff;padding:16px}.plans-grid{grid-template-columns:1fr}.plan-card{margin-bottom:16px}.form-row{grid-template-columns:1fr 1fr}.form-row .form-group:last-child{grid-column:span 2}.payment-form-container{padding:24px}.payment-actions{flex-direction:column}}.btn-subscription{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;border-radius:100px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:16px;padding:14px 24px;transition:all .3s ease;width:100%}.btn-subscription:hover{box-shadow:0 4px 12px #0080ff4d;transform:translateY(-2px)}.modal-container.full-screen{background:#fff;border-radius:0;height:100%;max-height:100%;max-width:100%;overflow-y:auto;position:relative;width:100%;z-index:2001}@media (min-width:810px){.modal-container.full-screen{border-radius:24px;height:90%;max-height:90vh;max-width:900px;width:90%}}.payment-info-card{align-items:center;background:#f0f7ff;border-radius:12px;color:#06c;display:flex;gap:12px;margin-top:24px;padding:16px 20px}.payment-info-card p{font-size:14px;margin:0}.payment-info-card strong{color:#049}.sync-subscription-section{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:1px solid #ffb74d;border-radius:12px;margin-top:24px;padding:20px;text-align:center}.sync-hint{color:#e65100;font-size:14px;font-weight:500;margin:0 0 12px}.btn-sync-subscription{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn-sync-subscription:hover{box-shadow:0 4px 12px #ff980066;transform:translateY(-2px)}.btn-sync-subscription:disabled{cursor:not-allowed;opacity:.7;transform:none}.pending-payment-note{color:#ff9800;font-size:14px;margin-top:8px}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.payment-method-modal{animation:slideUp .3s ease-out}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.modal-title{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;padding:4px 8px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:24px}.modal-subtitle{color:#6b7280;font-size:1rem;margin-bottom:24px;text-align:center}.modal-subtitle strong{color:#1f2937;font-weight:600}.payment-methods{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.payment-method-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:16px;text-align:left;transition:all .2s}.payment-method-btn.active,.payment-method-btn:hover{background:#eff6ff;border-color:#3b82f6}.payment-method-btn.active{box-shadow:0 0 0 3px #3b82f61a}.payment-method-icon{align-items:center;background:#f9fafb;border-radius:12px;color:#3b82f6;display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.payment-method-btn.active .payment-method-icon{background:#dbeafe}.payment-method-info{flex:1 1}.payment-method-info h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 4px}.payment-method-info p{color:#6b7280;font-size:.875rem;margin:0}.payment-method-pending{background:#fef3c7;border-radius:4px;color:#f59e0b;display:inline-block;font-size:.75rem;margin-top:4px;padding:2px 8px}.payment-method-check{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}@media (max-width:640px){.modal-content{border-radius:16px 16px 0 0;margin:0;max-height:95vh}.payment-method-btn{padding:12px}.payment-method-icon{height:50px;width:50px}.payment-method-icon svg{height:30px;width:30px}}.upgrade-prompt-modal{animation:slideUp .3s ease;background:linear-gradient(145deg,#1a1f2e,#0d1117);border:1px solid #ffd7004d;border-radius:24px;box-shadow:0 20px 60px #00000080,0 0 40px #ffd7001a;max-width:420px;padding:32px 28px;text-align:center;width:92%}.upgrade-prompt-icon{margin-bottom:20px}.upgrade-prompt-title{color:#fff;font-size:22px;font-weight:700;line-height:1.3;margin-bottom:12px}.upgrade-prompt-message{color:#ffffffb3;font-size:15px;line-height:1.6;margin-bottom:20px;padding:0 8px}.upgrade-prompt-benefits{background:#ffd70014;border:1px solid #ffd70033;border-radius:16px;margin-bottom:24px;padding:16px 20px;text-align:left}.upgrade-benefits-title{color:gold;font-size:14px;font-weight:600;margin-bottom:12px}.upgrade-prompt-benefits ul{list-style:none;margin:0;padding:0}.upgrade-prompt-benefits ul li{color:#ffffffd9;font-size:14px;padding:6px 0 6px 24px;position:relative}.upgrade-prompt-benefits ul li:before{color:#4caf50;content:"✓";font-weight:700;left:0;position:absolute}.upgrade-prompt-actions{display:flex;flex-direction:column;gap:12px}.upgrade-prompt-actions .btn-upgrade{background:linear-gradient(135deg,gold,#ffa000);border:none;border-radius:14px;box-shadow:0 4px 20px #ffd7004d;color:#1a1a1a;cursor:pointer;font-size:16px;font-weight:700;padding:16px 24px;transition:all .3s ease}.upgrade-prompt-actions .btn-upgrade:hover{box-shadow:0 6px 25px #ffd70066;transform:translateY(-2px)}.upgrade-prompt-actions .btn-secondary{background:#0000;border:none;color:#ffffff80;cursor:pointer;font-size:14px;padding:12px}.upgrade-prompt-actions .btn-secondary:hover{color:#fffc}.meal-group{margin-bottom:24px}.meal-group-header{align-items:center;background:linear-gradient(135deg,#2e7d321a,#4caf501a);border-radius:12px;display:flex;gap:10px;margin-bottom:12px;padding:12px 16px}.meal-group-icon{font-size:20px}.meal-group-title{color:#2e7d32;flex:1 1;font-size:16px;font-weight:600}.meal-group-count{background:#0000000d;border-radius:20px;color:#666;font-size:13px;padding:4px 10px}.meal-group .meal-card{border-left:3px solid #2e7d324d;margin-bottom:8px;margin-left:16px}.meal-group .meal-card:last-child{margin-bottom:0}.header-actions{gap:12px}.notification-bell{background:#0000000d;border:none}.notification-bell:hover{background:#0000001a}.notification-bell svg{color:#333}.notification-badge{background:#f44336;border:2px solid #fff;border-radius:9px;font-size:10px;font-weight:600;height:18px;min-width:18px;right:-2px;top:-2px}.notifications-dropdown{background:#fff;box-shadow:0 10px 40px #00000026;max-height:450px;position:absolute;right:20px;top:60px;width:340px}.notifications-header{border-bottom:1px solid #eee;padding:16px 20px}.notifications-header h3{font-size:16px;font-weight:600}.mark-all-read{color:#0080ff;font-size:13px}.notifications-list{max-height:350px}.no-notifications{color:#999;padding:40px 20px;text-align:center}.no-notifications span{display:block;font-size:40px;margin-bottom:10px}.notification-item{border-bottom:1px solid #f5f5f5;gap:12px;padding:14px 20px;position:relative}.notification-item:hover{background:#f9f9f9}.notification-item.unread{background:#f0f7ff}.notif-icon{flex-shrink:0;font-size:24px}.notif-content{flex:1 1;min-width:0}.notif-content strong{color:#333;font-size:14px;margin-bottom:4px}.notif-content p{color:#666;font-size:13px;margin:0 0 6px}.notif-time{color:#999;font-size:11px}.unread-dot{background:#0080ff;border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.exercises-view{padding-bottom:100px}.btn-history{align-items:center;background:#0000000d;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-history:hover{background:#0000001a}.current-plan-banner{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px;transition:transform .2s,box-shadow .2s}.current-plan-banner:hover{box-shadow:0 8px 25px #667eea66;transform:translateY(-2px)}.current-plan-info .current-label{color:#ffffffb3;font-size:11px;letter-spacing:1px;text-transform:uppercase}.current-plan-info h3{color:#fff;font-size:20px;margin:4px 0}.current-plan-info p{color:#fffc;font-size:13px;margin:0}.current-plan-banner .arrow{color:#fff;font-size:24px}.section-title{color:#333;font-weight:600;margin-bottom:16px}.plans-showcase{display:flex;flex-direction:column;gap:16px}.plan-showcase-card{background:#fff;border:2px solid #eee;border-radius:16px;cursor:pointer;overflow:hidden;transition:all .2s ease}.plan-showcase-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-3px)}.plan-card-header{padding:16px 20px;position:relative}.plan-level-badge{align-items:center;border-radius:20px;color:#fff;display:inline-flex;font-size:11px;font-weight:600;gap:4px;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.plan-card-header h3{color:#333;font-size:20px;margin:10px 0 0}.plan-card-body{padding:0 20px 16px}.plan-description{color:#666;font-size:14px;line-height:1.5;margin:0 0 12px}.plan-goal{background:#00b8941a;border-radius:8px;color:#00b894;font-size:13px;margin-bottom:12px;padding:8px 12px}.plan-goal strong{color:#333}.plan-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.plan-stats span{color:#555;font-size:13px}.plan-workouts-preview{display:flex;gap:8px}.workout-day-badge{align-items:center;background:#f0f0f0;border-radius:50%;color:#666;display:flex;font-size:12px;font-weight:600;height:28px;justify-content:center;width:28px}.plan-card-footer{background:#f9f9f9;border-top:1px solid #eee;padding:12px 20px}.view-plan-btn{color:#0080ff;font-size:14px;font-weight:600}.plan-detail-view{padding-bottom:100px}.plan-detail-header{border-radius:0 0 24px 24px;margin:-20px -20px 20px;padding:20px}.plan-detail-title{margin-top:16px}.level-badge{border-radius:20px;display:inline-flex;font-size:12px;padding:6px 14px}.plan-detail-title h1{color:#333;font-size:28px;margin:10px 0}.plan-detail-title p{color:#666;font-size:14px;line-height:1.5}.plan-meta-row{display:flex;flex-wrap:wrap;gap:20px;margin-top:16px}.plan-meta-item{align-items:center;color:#555;display:flex;font-size:13px;gap:6px}.meta-icon{font-size:16px}.btn-subscribe-plan{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:24px;padding:16px;transition:all .2s;width:100%}.btn-subscribe-plan:hover{box-shadow:0 8px 25px #667eea66;transform:translateY(-2px)}.subscribed-badge{background:linear-gradient(135deg,#4caf5022,#4caf5033);border-radius:12px;color:#2e7d32;font-weight:500;margin-bottom:24px;padding:14px 20px;text-align:center}.workouts-grid{display:flex;flex-direction:column;gap:16px}.workout-day-card{background:#fff;border:1px solid #eee;border-radius:16px;box-shadow:0 2px 10px #0000000d;padding:20px}.workout-day-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.day-letter{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.workout-day-header h3{color:#333;flex:1 1;font-size:18px;margin:0}.workout-duration{background:#f0f0f0;border-radius:12px;color:#666;font-size:12px;padding:4px 8px}.workout-day-exercises{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.mini-exercise{background:#f9f9f9;border-radius:8px;display:flex;justify-content:space-between;padding:8px 12px}.mini-exercise-card{align-items:center;background:#f9f9f9;border-radius:10px;display:flex;gap:10px;padding:8px}.mini-exercise-gif{border-radius:8px;flex-shrink:0;height:50px;object-fit:cover;width:50px}.mini-exercise-info{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow:hidden}.mini-ex-name{color:#333;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-ex-info{color:#666;font-size:12px}.more-exercises{background:#00d4aa1a;border-radius:8px;color:#00d4aa;font-size:12px;font-weight:500;padding:8px;text-align:center}.btn-start-workout{background:#4caf50;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px;transition:all .2s;width:100%}.btn-start-workout:hover{background:#43a047}.workout-active-view{padding:0}.workout-header-banner{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;gap:16px;margin:-20px -20px 20px;padding:20px}.btn-back-light{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.workout-header-info{flex:1 1}.workout-header-info h2{color:#fff;font-size:20px;margin:0 0 4px}.workout-header-info p{color:#fffc;font-size:13px;margin:0}.workout-progress-ring{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:50px;justify-content:center;width:50px}.workout-exercises-list{display:flex;flex-direction:column;gap:12px;padding:0 20px}.workout-exercise-item{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-wrap:wrap;gap:12px;padding:16px;transition:all .2s}.workout-exercise-item.completed{background:#f5f5f5;opacity:.6}.exercise-gif-container{background:#f8f8f8;border-radius:10px;flex-shrink:0;height:80px;overflow:hidden;width:80px}.exercise-gif{height:100%;object-fit:cover;width:100%}.exercise-number{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.exercise-info{flex:1 1}.exercise-info h4{color:#333;font-size:16px;margin:0 0 4px}.exercise-info p{color:#666;font-size:13px;margin:0}.exercise-tip{color:#999;display:block;font-size:12px;margin-top:4px}.btn-complete-exercise{background:#4caf50;border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;font-size:20px;height:44px;transition:all .2s;width:44px}.btn-complete-exercise:hover{background:#43a047;transform:scale(1.1)}.exercise-done-badge{align-items:center;background:#e8f5e9;border-radius:50%;color:#4caf50;display:flex;flex-shrink:0;font-size:20px;height:44px;justify-content:center;width:44px}.btn-finish-workout{animation:pulse 2s infinite;background:linear-gradient(135deg,gold,#ffa000);border:none;border-radius:14px;color:#333;cursor:pointer;font-size:18px;font-weight:700;margin:24px 20px;padding:18px;width:calc(100% - 40px)}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;padding:16px}.history-date{color:#666;min-width:50px;text-align:center}.history-info{flex:1 1}.history-info h4{color:#333;font-size:15px;margin:0 0 4px}.history-info p{color:#666;font-size:13px;margin:0}.history-status{align-items:center;border-radius:50%;display:flex;font-size:16px;height:36px;justify-content:center;width:36px}.history-status.completed{background:#e8f5e9;color:#4caf50}.history-status.in_progress{background:#fff3e0;color:#ff9800}.empty-state{color:#999;padding:60px 20px;text-align:center}.empty-state .empty-icon{display:block;font-size:60px;margin-bottom:16px}.empty-state p{font-size:16px}.plan-button.upgrade{background:linear-gradient(135deg,gold,#ffa000);color:#333}.plan-button.upgrade:hover{background:linear-gradient(135deg,#ffdf00,#ffb300)}.app-header{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding-bottom:16px}.header-top-row{flex-wrap:nowrap;justify-content:space-between;width:100%}.header-brand,.header-top-row{align-items:center;display:flex;gap:8px}.header-brand{flex-shrink:0;min-width:0}.header-logo{border-radius:8px;flex-shrink:0;height:32px;width:32px}.header-brand-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);-webkit-background-clip:text;background-clip:text;font-family:Manrope,sans-serif;font-size:18px;font-weight:800;white-space:nowrap}.header-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}@media (max-width:400px){.header-brand-name{font-size:16px}.header-actions{gap:4px}.header-actions .upgrade-button{font-size:12px;padding:6px 10px}}@media (max-width:360px){.header-brand-name{font-size:14px}.header-logo{height:28px;width:28px}}.header-title-section{width:100%}.header-title-section h1{margin:0}.header-title-section p{color:#94a3b8;color:var(--text-secondary);font-size:14px;margin:0}.bottom-nav{background:#060a11fa;max-width:100vw;padding:8px 8px 20px;width:100%}.nav-item{border-radius:12px;color:#475569;color:var(--text-muted);gap:2px;min-width:56px;position:relative}.nav-item:hover{color:#94a3b8;color:var(--text-secondary)}.nav-label{font-weight:600;white-space:nowrap}.view-container{background:#060a11;background:var(--bg-page);min-height:calc(100vh - 90px);min-height:calc(100dvh - 90px);width:100%}.gamification-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:16px;padding:16px}.gamification-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.level-badge{align-items:center;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:100px;box-shadow:0 0 20px #00d9a54d;box-shadow:var(--glow-teal);color:#fff;display:flex;font-size:13px;font-weight:600;gap:6px;padding:6px 12px}.points-display{color:#00d9a5;color:var(--brand-primary);font-family:JetBrains Mono,monospace;font-size:16px;font-weight:600}.gamification-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.stat-item{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:12px 8px;text-align:center}.stat-icon{font-size:20px}.stat-value{color:#fff;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700}.stat-label{color:#475569;color:var(--text-muted);font-size:9px;letter-spacing:.3px;text-transform:uppercase}.progress-ring-container{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:16px;padding:16px}.progress-ring{height:140px;margin:0 auto 16px;position:relative;width:140px}.progress-ring svg{transform:rotate(-90deg)}.progress-ring circle{fill:none;stroke-width:10;stroke-linecap:round}.progress-ring .bg{stroke:#121a2f;stroke:var(--bg-elevated)}.progress-ring .progress{stroke:url(#gradient);filter:drop-shadow(0 0 8px rgba(0,217,165,.4));transition:stroke-dashoffset .5s ease}.calories-display{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.calories-value{color:#fff;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:28px;font-weight:700;line-height:1}.calories-label{color:#475569;color:var(--text-muted);font-size:11px;margin-top:4px}.macro-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.macro-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;padding:12px;text-align:center}.macro-value{font-family:JetBrains Mono,monospace;font-size:20px}.macro-card.protein .macro-value{color:#00d9a5}.macro-card.carbs .macro-value{color:#0080ff}.macro-card.fat .macro-value{color:#ffb800}.macro-label{color:#475569;color:var(--text-muted);font-size:11px;margin-top:2px}.premium-input{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;color:#fff;color:var(--text-primary);font-size:16px;padding:16px 20px;transition:all .2s ease;width:100%}.premium-input:focus{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 0 0 3px #00d9a51a;outline:none}.premium-input::placeholder{color:#475569;color:var(--text-muted)}.btn-premium{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;border-radius:100px;box-shadow:0 0 20px #00d9a54d;box-shadow:var(--glow-teal);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px 32px;transition:all .2s ease}.btn-premium:hover{box-shadow:0 8px 25px #00d9a566;transform:translateY(-2px)}.btn-premium:active{transform:scale(.98)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-title{color:var(--text-primary);font-family:Manrope,sans-serif;font-size:18px}.section-action{background:none;border:none;color:#00d9a5;color:var(--brand-primary);cursor:pointer;font-size:14px;font-weight:600}.meal-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:12px;padding:16px;transition:all .2s ease}.meal-card:hover{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 4px 20px #00d9a51a}.food-search-container{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:20px;margin-bottom:20px;padding:20px}.search-input-wrapper{position:relative}.search-input-wrapper svg{color:#475569;color:var(--text-muted);left:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;color:#fff;color:var(--text-primary);font-size:16px;padding:14px 14px 14px 48px;width:100%}.search-input:focus{border-color:#00d9a5;border-color:var(--brand-primary);outline:none}.notification-bell{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:50%;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;position:relative;transition:all .2s ease;width:40px}.notification-bell:hover{border-color:#00d9a5;border-color:var(--brand-primary);color:#00d9a5;color:var(--brand-primary)}.notification-badge{align-items:center;background:#ff4757;background:var(--error);border:2px solid #060a11;border:2px solid var(--bg-page);border-radius:8px;color:#fff;display:flex;font-size:9px;font-weight:700;height:16px;justify-content:center;min-width:16px;position:absolute;right:-4px;top:-4px}.notifications-dropdown{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;box-shadow:0 20px 50px #00000080;left:16px;max-height:400px;opacity:0;overflow:hidden;position:fixed;right:16px;top:70px;transform:translateY(-10px);transition:all .2s ease;visibility:hidden;z-index:1000}.notifications-dropdown.show{opacity:1;transform:translateY(0);visibility:visible}.notifications-header{align-items:center;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:14px 16px}.notifications-header h3{color:#fff;color:var(--text-primary);font-family:Manrope,sans-serif;font-size:15px;font-weight:700;margin:0}.mark-all-read{background:none;border:none;color:#00d9a5;color:var(--brand-primary);cursor:pointer;font-size:12px;font-weight:600}.notifications-list{max-height:300px;overflow-y:auto}.notification-item{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:background .2s}.notification-item:hover{background:#121a2f;background:var(--bg-elevated)}.notification-item.unread{background:#00d9a50d}.notif-content strong{color:#fff;color:var(--text-primary);display:block;font-size:13px;margin-bottom:2px}.notif-content p{color:#94a3b8;color:var(--text-secondary);font-size:12px;line-height:1.4;margin:0}.notif-time{color:#475569;color:var(--text-muted);display:block;font-size:10px;margin-top:4px}.upgrade-button{align-items:center;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;border-radius:100px;box-shadow:0 0 20px #00d9a54d;box-shadow:var(--glow-teal);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:13px;font-weight:600;gap:6px;padding:8px 14px;transition:all .2s ease}.upgrade-button:hover{box-shadow:0 8px 25px #00d9a566;transform:translateY(-2px)}.login-page{background:#060a11;background:var(--bg-page);min-height:100vh}.login-card{background:#0c1322;background:var(--bg-card)}.login-card,.login-card input{border:1px solid #ffffff14;border:1px solid var(--border-light)}.login-card input{background:#121a2f;background:var(--bg-elevated);color:#fff;color:var(--text-primary)}.login-card input:focus{border-color:#00d9a5;border-color:var(--brand-primary)}.goals-explanation-card{background:linear-gradient(135deg,#00d9a51a,#0080ff1a);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin:20px 0;padding:20px;text-align:center}.goals-explanation-card .goals-icon{font-size:40px;margin-bottom:12px}.goals-explanation-card h4{color:#fff;color:var(--text-primary);font-family:Manrope,sans-serif;font-size:18px;font-weight:700;margin:0 0 12px}.goals-explanation-card p{color:#94a3b8;color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0 0 12px}.goals-explanation-card p strong{color:#00d9a5;color:var(--brand-primary)}.goals-explanation-card .goals-tip{background:#121a2f;background:var(--bg-elevated);border-radius:10px;color:#94a3b8;color:var(--text-secondary);font-size:13px;margin:16px 0 0;padding:12px}.goals-setup-section{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin:20px 0;padding:20px}.goals-setup-header{align-items:center;display:flex;gap:14px;margin-bottom:16px}.goals-setup-icon{color:#00d9a5;color:var(--brand-primary);flex-shrink:0}.goals-setup-header h4{color:#fff;color:var(--text-primary);font-family:Manrope,sans-serif;font-size:16px;font-weight:600;margin:0}.goals-setup-header .body-small{color:#94a3b8;color:var(--text-secondary);font-size:13px}.goals-summary{background:#121a2f;background:var(--bg-elevated);border-radius:12px;padding:16px}.goals-summary-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:14px}.goals-summary-item{background:#0c1322;background:var(--bg-card);border-radius:10px;padding:10px 8px;text-align:center}.goals-summary-label{color:#475569;color:var(--text-muted);display:block;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.goals-summary-value{color:#00d9a5;color:var(--brand-primary);display:block;font-size:14px;font-weight:600}.goals-macros-preview{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.macro-badge{border-radius:20px;font-size:12px;font-weight:600;padding:6px 12px}.macro-badge.protein{background:#ef444426;border:1px solid #ef44444d;color:#ef4444}.macro-badge.carbs{background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b}.macro-badge.fat{background:#3b82f626;border:1px solid #3b82f64d;color:#3b82f6}.goals-prediction{background:#a855f71a;border:1px solid #a855f733;border-radius:8px;font-size:13px;margin:12px 0;padding:10px;text-align:center}.btn-goals-reconfigure,.goals-prediction{color:#94a3b8;color:var(--text-secondary)}.btn-goals-reconfigure{background:#0000;border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;margin-top:12px;padding:12px 20px;transition:all .2s ease;width:100%}.btn-goals-reconfigure:hover{background:#ffffff08;background:var(--bg-glass);border-color:#00d9a5;border-color:var(--brand-primary);color:#00d9a5;color:var(--brand-primary)}.goals-not-setup{text-align:center}.goals-explanation{color:#94a3b8;color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:16px}.goals-explanation strong{color:#00d9a5;color:var(--brand-primary)}.btn-setup-goals{align-items:center;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 28px;transition:all .2s ease}.btn-setup-goals:hover{box-shadow:0 0 20px #00d9a54d;box-shadow:var(--glow-teal);transform:translateY(-2px)}.btn-type-barcode{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin-top:16px;padding:14px 20px;transition:all .2s ease;width:100%}.btn-type-barcode:hover{border-color:#00d9a5;border-color:var(--brand-primary);color:#00d9a5;color:var(--brand-primary)}.barcode-input-form{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;padding:24px;text-align:center}.barcode-input-form h3{color:#fff;color:var(--text-primary);font-family:Manrope,sans-serif;font-size:18px;font-weight:700;margin:0 0 20px}.barcode-input-form .form-group{margin-bottom:20px}.barcode-input{font-family:JetBrains Mono,monospace;font-size:20px;letter-spacing:2px;text-align:center}.barcode-input-actions{display:flex;flex-direction:column;gap:12px}.barcode-input-actions .btn-primary{background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s}.barcode-input-actions .btn-primary:disabled{cursor:not-allowed;opacity:.5}.barcode-input-actions .btn-secondary{background:#0000;border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:12px 20px}.inapp-browser-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#060a11f2;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.inapp-browser-modal{animation:slideUp .3s ease;background:linear-gradient(145deg,#1a1f2e,#0d1117);border:1px solid #ffd70033;border-radius:24px;box-shadow:0 20px 60px #00000080;max-width:420px;padding:32px 24px;text-align:center;width:100%}.inapp-browser-icon{margin-bottom:20px}.inapp-browser-title{color:#fff;font-size:24px;font-weight:700;margin-bottom:16px}.inapp-browser-message{color:#fffc;font-size:15px;line-height:1.6;margin-bottom:12px}.inapp-browser-message strong{color:#00bfa6}.inapp-browser-instruction{color:#fff9;font-size:14px;margin-bottom:24px}.inapp-browser-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.inapp-btn-copy{background:linear-gradient(135deg,#00bfa6,#00897b);border:none;border-radius:14px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px 24px;transition:all .3s ease}.inapp-btn-copy:hover{box-shadow:0 6px 25px #00bfa64d;transform:translateY(-2px)}.inapp-btn-open{background:#ffffff1a;border:1px solid #fff3;border-radius:14px;color:#fff;cursor:pointer;font-size:15px;padding:14px 24px;transition:all .3s ease}.inapp-btn-open:hover{background:#ffffff26}.inapp-browser-steps{background:#ffffff0d;border-radius:12px;margin-bottom:20px;padding:16px;text-align:left}.inapp-browser-steps p{color:#ffffffb3;font-size:13px;margin-bottom:8px}.inapp-browser-steps ol{margin:0;padding-left:20px}.inapp-browser-steps li{color:#fff9;font-size:13px;line-height:1.5;margin-bottom:6px}.inapp-browser-steps strong{color:#00bfa6}.inapp-browser-dismiss{background:#0000;border:none;color:#fff6;cursor:pointer;font-size:12px;padding:8px;transition:color .2s}.inapp-browser-dismiss:hover{color:#fff9}.push-notifications-section{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea4d;border-radius:16px;display:flex;flex-direction:column;gap:16px;margin-bottom:20px;padding:20px}.push-section-header{align-items:center;display:flex;gap:14px}.push-section-header .push-icon{color:#667eea;flex-shrink:0}.push-section-header h4{color:#fff;font-size:1rem;font-weight:600;margin:0}.push-section-header .body-small{color:#fff9;margin:4px 0 0}.btn-push-settings{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:14px 20px;transition:all .3s ease}.btn-push-settings:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.push-settings-modal{align-items:center;display:flex;justify-content:center;padding:20px}@media (max-width:480px){.push-notifications-section{padding:16px}.email-notifications-section{background:linear-gradient(135deg,#00d4aa1a,#00a0801a);border-color:#00d4aa4d}.btn-email-settings{background:linear-gradient(135deg,#00d4aa,#00a080)!important}.btn-email-settings:hover{box-shadow:0 8px 20px #00d4aa66!important}.btn-push-settings{font-size:.9rem;padding:12px 16px}}.bottom-nav{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0c1322f2;border-top:1px solid #ffffff14;border-top:1px solid var(--border-light);bottom:0;justify-content:space-around;left:0;padding:8px 0 calc(8px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:1000}.bottom-nav,.nav-item{align-items:center;display:flex}.nav-item{background:none;border:none;color:#94a3b8;color:var(--text-secondary);cursor:pointer;flex-direction:column;justify-content:center;min-width:60px;padding:8px 12px;transition:all .2s ease}.nav-item.active{color:#00d9a5;color:var(--brand-primary)}.nav-item:hover{color:#fff;color:var(--text-primary)}.nav-label{font-size:10px;font-weight:500;margin-top:4px}.nav-item-add{padding:0;position:relative}.nav-add-button{align-items:center;background:linear-gradient(135deg,#00d9a5,#0080ff);background:var(--gradient-button);border-radius:50%;box-shadow:0 4px 20px #00d9a566;color:#fff;display:flex;height:56px;justify-content:center;margin-top:-20px;transition:all .3s ease;width:56px}.nav-item-add:hover .nav-add-button{box-shadow:0 6px 25px #00d9a580;transform:scale(1.1)}.nav-item-add:active .nav-add-button{transform:scale(.95)}.add-menu-overlay{align-items:flex-end;animation:fadeIn .2s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.add-menu-modal{animation:slideUp .3s ease;background:#0c1322;background:var(--bg-card);border-radius:24px 24px 0 0;max-width:500px;padding:24px 24px calc(24px + env(safe-area-inset-bottom));width:100%}.add-menu-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.add-menu-header h2{color:#fff;color:var(--text-primary);font-size:1.25rem;font-weight:700}.add-menu-close{align-items:center;background:#121a2f;background:var(--bg-elevated);border:none;border-radius:50%;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.add-menu-close:hover{background:#ffffff08;background:var(--bg-glass);color:#fff;color:var(--text-primary)}.add-menu-options{display:flex;flex-direction:column;gap:12px}.add-menu-option{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;cursor:pointer;display:flex;gap:16px;padding:16px;text-align:left;transition:all .2s ease}.add-menu-option:hover{background:#ffffff08;background:var(--bg-glass);border-color:#00d9a5;border-color:var(--brand-primary);transform:translateX(4px)}.add-menu-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.add-menu-icon.search-icon{background:linear-gradient(135deg,#00d9a533,#00d9a51a);color:#00d9a5;color:var(--brand-primary)}.add-menu-icon.camera-icon{background:linear-gradient(135deg,#0080ff33,#0080ff1a);color:#0080ff;color:var(--brand-secondary)}.add-menu-icon.barcode-icon{background:linear-gradient(135deg,#ffb80033,#ffb8001a);color:#ffb800;color:var(--warning)}.add-menu-text{display:flex;flex-direction:column;gap:4px}.add-menu-title{color:#fff;color:var(--text-primary);font-size:1rem;font-weight:600}.add-menu-subtitle{color:#94a3b8;color:var(--text-secondary);font-size:.85rem}.diary-view .header-section{padding-bottom:16px;text-align:center}.diary-diet-section{border-top:1px solid #333;border-top:1px solid var(--border-color,#333);margin-top:24px;padding-top:20px}.diary-progress-section{margin-top:24px}.daily-progress-card{background:#1a1a1a;background:var(--bg-secondary,#1a1a1a);border-radius:16px;margin-bottom:16px;padding:20px}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.progress-header h3{color:#fff;color:var(--text-primary,#fff);font-size:1.1rem;margin:0}.goal-badge{background:#10b98126;border-radius:20px;color:#10b981;font-size:.8rem;font-weight:600;padding:6px 12px}.macro-progress-grid{display:flex;flex-direction:column;gap:14px}.macro-label{color:#94a3b8;color:var(--text-secondary,#888);font-size:.85rem}.macro-bar{background:#252525;background:var(--bg-tertiary,#252525);border-radius:4px;height:8px;overflow:hidden}.macro-fill{border-radius:4px;height:100%;transition:width .3s ease}.macro-fill.calories{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.macro-fill.protein{background:linear-gradient(90deg,#ef4444,#f87171)}.macro-fill.carbs{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.macro-fill.fat{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.macro-values{display:flex;font-size:.8rem;justify-content:space-between}.macro-values span:first-child{color:#fff;color:var(--text-primary,#fff);font-weight:600}.macro-values span:last-child{color:#94a3b8;color:var(--text-secondary,#888)}.diet-plan-toggle{align-items:center;background:linear-gradient(135deg,#10b9811a,#0596691a);border:1px solid #10b9814d;border-radius:12px;color:#10b981;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:10px;justify-content:center;margin-bottom:16px;padding:14px 20px;transition:all .2s ease;width:100%}.diet-plan-toggle:hover{background:linear-gradient(135deg,#10b98133,#05966933)}.diet-plan-toggle.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.toggle-arrow{font-size:.8rem;margin-left:auto}.diet-plan-content{animation:slideDown .3s ease;background:#1a1a1a;background:var(--bg-secondary,#1a1a1a);border-radius:16px;padding:20px}.diet-plan-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.diet-plan-header h4{color:#fff;color:var(--text-primary,#fff);font-size:1rem;margin:0}.diet-header-actions{display:flex;gap:8px}.regenerate-btn-small{background:#0000;border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:8px;color:#94a3b8;color:var(--text-secondary,#aaa);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .2s}.regenerate-btn-small:hover:not(:disabled){border-color:#10b981;color:#10b981}.regenerate-btn-small:disabled{cursor:not-allowed;opacity:.5}.delete-diet-btn-small{background:#0000;border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:8px;color:#94a3b8;color:var(--text-secondary,#aaa);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .2s}.delete-diet-btn-small:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.btn-go-to-diet{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 4px 15px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:10px;justify-content:center;margin-top:16px;padding:14px 20px;transition:all .3s ease;width:100%}.btn-go-to-diet:hover{box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.btn-go-to-diet:active{transform:translateY(0)}.diet-meals-compact{display:flex;flex-direction:column;gap:12px}.diet-meal-compact{background:#252525;background:var(--bg-tertiary,#252525);border-left:3px solid #10b981;border-radius:10px;padding:12px}.meal-compact-header{align-items:center;display:flex;gap:10px;margin-bottom:8px}.meal-time{color:#10b981;font-size:.75rem;font-weight:600;min-width:45px}.meal-name{color:#fff;color:var(--text-primary,#fff);flex:1 1;font-size:.9rem;font-weight:600}.meal-cals{color:#94a3b8;color:var(--text-secondary,#888);font-size:.8rem}.meal-foods-compact{display:flex;flex-wrap:wrap;gap:6px}.food-tag{background:#ffffff0d;border-radius:6px;font-size:.75rem;padding:4px 8px}.diet-tips-compact,.food-tag{color:#94a3b8;color:var(--text-secondary,#ccc)}.diet-tips-compact{background:#10b9811a;border-radius:10px;font-size:.85rem;margin-top:16px;padding:12px}.diet-tips-compact strong{color:#10b981}.diet-title-section{flex:1 1}.diet-title-section h4{color:#fff;color:var(--text-primary,#fff);font-size:1rem;margin:0 0 8px}.diet-daily-summary{display:flex;flex-wrap:wrap;gap:8px}.diet-total-item{background:#252525;background:var(--bg-tertiary,#252525);border-radius:6px;color:#94a3b8;color:var(--text-secondary,#aaa);font-size:.75rem;padding:4px 8px}.diet-total-item strong{color:#fff;color:var(--text-primary,#fff)}.diet-total-item.protein strong{color:#ef4444}.diet-total-item.carbs strong{color:#3b82f6}.diet-total-item.fat strong{color:#f59e0b}.diet-meals-detailed{display:flex;flex-direction:column;gap:12px}.diet-meal-card{background:#252525;background:var(--bg-tertiary,#252525);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:12px;overflow:hidden;transition:all .3s ease}.diet-meal-card.expanded{border-color:#10b981;box-shadow:0 4px 20px #10b98126}.meal-card-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;transition:background .2s}.meal-card-header:hover{background:#ffffff08}.meal-header-left{align-items:center;display:flex;gap:12px}.btn-add-meal-to-diary{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;padding:6px 12px;transition:all .2s;white-space:nowrap}.btn-add-meal-to-diary:hover{box-shadow:0 4px 12px #10b98166;transform:scale(1.05)}.meal-time-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:6px;color:#fff;font-size:.7rem;font-weight:700;min-width:50px;padding:4px 8px;text-align:center}.meal-title{color:#fff;color:var(--text-primary,#fff);font-size:.95rem;font-weight:600}.meal-header-right{align-items:center;display:flex;gap:12px}.meal-macros-mini{display:none;gap:6px}@media (min-width:640px){.meal-macros-mini{display:flex}}.macro-pill{border-radius:4px;font-size:.65rem;font-weight:600;padding:3px 6px}.macro-pill.calories{background:#10b98133;color:#10b981}.macro-pill.protein{background:#ef444426;color:#ef4444}.macro-pill.carbs{background:#3b82f626;color:#3b82f6}.macro-pill.fat{background:#f59e0b26;color:#f59e0b}.expand-indicator{color:#94a3b8;color:var(--text-secondary,#888);font-size:.7rem}.meal-foods-detailed{background:#0003;border-top:1px solid #333;border-top:1px solid var(--border-color,#333);display:flex;flex-direction:column;gap:10px;padding:12px}.food-item-detailed{align-items:center;background:#1a1a1a;background:var(--bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:10px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:10px 12px}.food-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:120px}.food-name{color:#fff;color:var(--text-primary,#fff);font-size:.9rem;font-weight:500}.food-quantity{color:#10b981;font-size:.75rem;font-weight:600}.food-macros{display:flex;flex:1 1;flex-wrap:wrap;gap:6px;justify-content:center}.food-macro{background:#ffffff0d;border-radius:4px;font-size:.7rem;padding:3px 6px}.food-macro.cal{background:#10b9811a;color:#10b981}.food-macro.prot{color:#ef4444}.food-macro.carb{color:#3b82f6}.food-macro.fat{color:#f59e0b}.food-actions{display:flex;gap:6px}.food-action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.85rem;height:32px;justify-content:center;transition:all .2s;width:32px}.food-action-btn.edit{background:#3b82f626;color:#3b82f6}.food-action-btn.edit:hover{background:#3b82f64d}.food-action-btn.swap{background:#10b98126;color:#10b981}.food-action-btn.swap:hover:not(:disabled){background:#10b9814d}.food-action-btn.swap:disabled{cursor:wait;opacity:.6}.food-action-btn.remove{background:#ef444426;color:#ef4444}.food-action-btn.remove:hover{background:#ef44444d}.food-edit-form{display:flex;flex-direction:column;gap:10px;width:100%}.food-edit-name{background:#252525;background:var(--bg-tertiary,#252525);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:8px;color:#fff;color:var(--text-primary,#fff);font-size:.9rem;padding:10px 12px;width:100%}.food-edit-name:focus{border-color:#10b981;outline:none}.food-edit-row{display:flex;flex-wrap:wrap;gap:8px}.food-edit-field{flex:1 1;min-width:60px}.food-edit-field label{color:#94a3b8;color:var(--text-secondary,#888);display:block;font-size:.65rem;margin-bottom:4px;text-transform:uppercase}.food-edit-field input{background:#252525;background:var(--bg-tertiary,#252525);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:6px;color:#fff;color:var(--text-primary,#fff);font-size:.85rem;padding:8px;text-align:center;width:100%}.food-edit-field input:focus{border-color:#10b981;outline:none}.food-edit-actions{display:flex;gap:8px;justify-content:flex-end}.btn-save-food{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .2s}.btn-save-food:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.btn-cancel-edit{background:#0000;border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:8px;color:#94a3b8;color:var(--text-secondary,#888);cursor:pointer;font-size:.85rem;padding:8px 16px;transition:all .2s}.btn-cancel-edit:hover{border-color:#ef4444;color:#ef4444}.food-edit-header{margin-bottom:12px}.food-edit-title{color:#fff;color:var(--text-primary,#fff);font-size:1rem;font-weight:600}.food-qty-editor{align-items:center;display:flex;gap:12px;margin-bottom:12px}.food-qty-editor label{color:#94a3b8;color:var(--text-secondary,#aaa);font-size:.85rem;min-width:80px}.qty-input-group{align-items:center;background:#252525;background:var(--bg-tertiary,#252525);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:10px;display:flex;gap:0;overflow:hidden}.qty-btn{background:#0000;border:none;color:#fff;color:var(--text-primary,#fff);cursor:pointer;font-size:1.3rem;font-weight:600;height:44px;transition:all .2s;width:40px}.qty-btn:hover{background:#10b98133;color:#10b981}.qty-btn.minus:hover{background:#ef444433;color:#ef4444}.qty-input-group input{background:#0000;border:none;border-left:1px solid #444;border-left:1px solid var(--border-color,#444);border-right:1px solid #444;border-right:1px solid var(--border-color,#444);color:#fff;color:var(--text-primary,#fff);font-size:1.1rem;font-weight:600;height:44px;text-align:center;width:80px}.qty-input-group input:focus{background:#10b9811a;outline:none}.qty-unit{color:#94a3b8;color:var(--text-secondary,#888);font-size:.9rem;padding:0 12px}.food-preview-macros{background:#10b9811a;border-radius:8px;color:#94a3b8;color:var(--text-secondary,#ccc);font-size:.85rem;margin-bottom:12px;padding:10px 14px;text-align:center}.food-preview-macros .preview-cal{color:#10b981;font-weight:600}.no-diet-compact{padding:20px;text-align:center}.no-diet-compact p{color:#94a3b8;color:var(--text-secondary,#888);margin-bottom:16px}.generate-diet-btn-compact{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s}.generate-diet-btn-compact:hover:not(:disabled){box-shadow:0 4px 15px #10b98166;transform:translateY(-2px)}.generate-diet-btn-compact:disabled{cursor:wait;opacity:.7}.setup-profile-card{background:linear-gradient(135deg,#10b9811a,#3b82f61a);border:1px dashed #10b98166;border-radius:16px;padding:30px 20px;text-align:center}.setup-icon{font-size:3rem;margin-bottom:12px}.setup-profile-card h3{color:#fff;color:var(--text-primary,#fff);font-size:1.2rem;margin:0 0 8px}.setup-profile-card p{color:#94a3b8;color:var(--text-secondary,#888);font-size:.9rem;margin:0 0 20px}.setup-profile-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 28px;transition:all .2s}.setup-profile-btn:hover{box-shadow:0 4px 20px #10b98166;transform:translateY(-2px)}.diary-search-container{align-items:center;display:flex;gap:8px;margin-bottom:20px}.diary-search-box{align-items:center;display:flex;flex:1 1;position:relative}.search-icon-inside{color:#94a3b8;color:var(--text-secondary);left:12px;pointer-events:none;position:absolute}.diary-search-input{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:10px;color:#fff;color:var(--text-primary);font-size:.95rem;padding:12px 12px 12px 40px;transition:all .2s ease;width:100%}.diary-search-input:focus{border-color:#00d9a5;border-color:var(--brand-primary);box-shadow:0 0 0 3px #00d9a51a;outline:none}.diary-search-input::placeholder{color:#475569;color:var(--text-muted)}.diary-quick-actions{display:flex;flex-shrink:0;gap:6px}.diary-quick-btn{align-items:center;background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:10px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;height:42px;justify-content:center;min-width:42px;transition:all .2s ease;width:42px}.diary-quick-btn:hover{background:#ffffff08;background:var(--bg-glass);border-color:#00d9a5;border-color:var(--brand-primary);color:#00d9a5;color:var(--brand-primary)}.camera-info-card{align-items:flex-start;background:linear-gradient(135deg,#0080ff1a,#00d9a51a);border:1px solid #00d9a533;border-radius:16px;display:flex;gap:14px;margin-bottom:20px;padding:16px}.camera-info-icon{flex-shrink:0;font-size:28px}.camera-info-text{flex:1 1}.camera-info-text strong{color:#fff;color:var(--text-primary);display:block;font-size:.95rem;margin-bottom:6px}.camera-info-text p{color:#94a3b8;color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0}.camera-placeholder{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.camera-placeholder-icon{font-size:64px;margin-bottom:20px;opacity:.8}.camera-placeholder-title{color:#fff;color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:8px}.camera-placeholder-subtitle{color:#94a3b8;color:var(--text-secondary);font-size:.9rem;margin-bottom:24px}.camera-main-btn{align-items:center;cursor:pointer;display:flex!important;font-size:1.1rem!important;gap:8px;justify-content:center;padding:16px 32px!important}.camera-divider{align-items:center;color:#475569;color:var(--text-muted);display:flex;font-size:.85rem;margin:20px 0;width:100%}.camera-divider:after,.camera-divider:before{background:#ffffff14;background:var(--border-light);content:"";flex:1 1;height:1px}.camera-divider span{padding:0 16px}.camera-secondary-btn{display:flex!important;max-width:280px}.btn-barcode-quick,.camera-secondary-btn{align-items:center;cursor:pointer;gap:8px;justify-content:center;width:100%}.btn-barcode-quick{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:12px;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.95rem;margin-bottom:20px;padding:12px 16px;transition:all .2s ease}.btn-barcode-quick:hover{background:#ffffff08;background:var(--bg-glass);border-color:#ffb800;border-color:var(--warning);color:#ffb800;color:var(--warning)}.add-menu-icon.ai-icon{background:linear-gradient(135deg,#a855f733,#a855f71a);color:#a855f7}.nav-item-ai{padding:0;position:relative}.nav-ai-button{align-items:center;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:50%;box-shadow:0 4px 20px #a855f766;color:#fff;display:flex;height:56px;justify-content:center;margin-top:-20px;transition:all .3s ease;width:56px}.nav-item-ai:hover .nav-ai-button{box-shadow:0 6px 25px #a855f780;transform:scale(1.1)}.nav-item-ai:active .nav-ai-button{transform:scale(.95)}.nav-item-ai.active .nav-ai-button{box-shadow:0 6px 30px #a855f799}.nav-item-ai .nav-label{color:#a855f7;font-weight:600;margin-top:6px}.nav-item-diet{padding:0;position:relative}.nav-diet-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;box-shadow:0 4px 20px #10b98166;color:#fff;display:flex;height:56px;justify-content:center;margin-top:-20px;transition:all .3s ease;width:56px}.nav-item-diet:hover .nav-diet-button{box-shadow:0 6px 25px #10b98180;transform:scale(1.1)}.nav-item-diet:active .nav-diet-button{transform:scale(.95)}.nav-item-diet.active .nav-diet-button{box-shadow:0 6px 30px #10b98199}.nav-item-diet .nav-label{color:#10b981;font-weight:600;margin-top:6px}.goals-loading-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:20px;padding:40px 24px;text-align:center}.goals-loading-spinner{animation:goalsSpinner .8s linear infinite;border:3px solid #00d4aa33;border-radius:50%;border-top-color:#00d4aa;height:40px;margin:0 auto 16px;width:40px}@keyframes goalsSpinner{to{transform:rotate(1turn)}}.goals-loading-card p{color:#94a3b8;color:var(--text-secondary);font-size:14px;margin:0}.goals-prompt-card{background:linear-gradient(135deg,#00d4aa1a,#00b8940d);border:1px dashed #00d4aa;border-radius:16px;margin-bottom:20px;padding:24px;text-align:center}.goals-prompt-icon{font-size:48px;margin-bottom:12px}.goals-prompt-card h3{color:#fff;color:var(--text-primary);font-size:18px;margin:0 0 8px}.goals-prompt-card p{color:#94a3b8;color:var(--text-secondary);font-size:14px;margin:0 0 16px}.goals-diet-hint{background:#10b9811a;border-left:3px solid #10b981;border-radius:10px;color:#10b981!important;font-size:13px;margin:12px 0 16px!important;padding:10px 14px}.goals-diet-hint strong{color:#10b981}.daily-progress-card{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:20px;margin-bottom:20px;padding:24px}.daily-progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.daily-progress-title h3{color:#fff;color:var(--text-primary);font-size:18px;margin:0 0 4px}.progress-status{border-radius:20px;font-size:12px;padding:4px 10px}.progress-status.on-track{background:#00d4aa26;color:#00d4aa}.progress-status.over{background:#ef444426;color:#ef4444}.progress-status.under{background:#3b82f626;color:#3b82f6}.btn-icon-small{background:#0000;border:none;border-radius:8px;cursor:pointer;font-size:18px;padding:8px;transition:background .2s}.btn-icon-small:hover{background:#121a2f;background:var(--bg-elevated)}.calorie-ring-container{align-items:center;display:flex;flex-direction:column;margin-bottom:24px}.calorie-ring{height:140px;position:relative;width:140px}.calorie-ring svg{transform:rotate(0deg)}.calorie-ring-content{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.calorie-consumed{color:#fff;color:var(--text-primary);display:block;font-size:28px;font-weight:700}.calorie-label{font-size:12px}.calorie-label,.calorie-remaining{color:#94a3b8;color:var(--text-secondary)}.calorie-remaining{font-size:13px;margin-top:8px}.macros-progress-row{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.macro-progress-item{display:flex;flex-direction:column;gap:6px}.macro-progress-header{align-items:center;display:flex;justify-content:space-between}.macro-label{font-size:13px;font-weight:600}.macro-label.protein{color:#ef4444}.macro-label.carbs{color:#3b82f6}.macro-label.fat{color:#f59e0b}.macro-value{color:#94a3b8;color:var(--text-secondary);font-size:12px}.progress-bar-thin{background:#121a2f;background:var(--bg-elevated);border-radius:3px;height:6px;overflow:hidden}.progress-bar-thin .progress-fill{border-radius:3px;height:100%;transition:width .3s ease}.progress-fill.protein{background:linear-gradient(90deg,#ef4444,#f87171)}.progress-fill.carbs{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.progress-fill.fat{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.progress-fill.water{background:linear-gradient(90deg,#06b6d4,#22d3ee)}.water-tracker-section{background:#06b6d40d;border-radius:12px;margin-bottom:16px;padding:16px}.water-tracker-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.water-label{color:#fff;color:var(--text-primary);font-size:14px;font-weight:600}.water-value{color:#06b6d4;font-size:13px;font-weight:600}.water-buttons{display:flex;gap:8px;margin-top:12px}.btn-water{background:#06b6d41a;border:1px solid #06b6d44d;border-radius:8px;color:#06b6d4;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px 12px;transition:all .2s}.btn-water:hover{background:#06b6d433}.btn-water:active{transform:scale(.95)}.goal-prediction-mini{background:#121a2f;background:var(--bg-elevated);border-radius:10px;color:#94a3b8;color:var(--text-secondary);font-size:13px;padding:12px;text-align:center}.progress-tracking-section{background:#0c1322;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border-light);border-radius:16px;margin-bottom:20px;padding:20px}.progress-section-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.progress-section-header h4{color:#fff;color:var(--text-primary);font-size:16px;margin:0}.progress-current-stats{background:#121a2f;background:var(--bg-elevated);border-radius:12px;display:flex;justify-content:space-around;margin-bottom:16px;padding:16px}.current-stat-item{text-align:center}.current-stat-label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:11px;margin-bottom:4px}.current-stat-value{color:#00d4aa;font-size:18px;font-weight:700}.weight-history-mini{margin-bottom:16px}.weight-history-mini h5{color:#94a3b8;color:var(--text-secondary);font-size:13px;margin:0 0 12px}.weight-history-entry{align-items:center;background:#121a2f;background:var(--bg-elevated);border-radius:8px;display:flex;gap:12px;margin-bottom:8px;padding:10px 12px}.history-date{color:#94a3b8;color:var(--text-secondary);font-size:12px;min-width:60px}.history-values{display:flex;flex:1 1;flex-direction:column;gap:2px}.history-weight{color:#fff;color:var(--text-primary);font-size:14px;font-weight:600}.history-measure{color:#94a3b8;color:var(--text-secondary);font-size:11px}.weight-change{font-size:16px;font-weight:700}.weight-change.down{color:#00d4aa}.weight-change.up{color:#ef4444}.body-measurements-summary h5{color:#94a3b8;color:var(--text-secondary);font-size:13px;margin:0 0 12px}.measurements-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.measurement-item{background:#121a2f;background:var(--bg-elevated);border-radius:10px;padding:12px 8px;text-align:center}.measurement-label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:11px;margin-bottom:4px}.measurement-value{color:#fff;color:var(--text-primary);font-size:14px;font-weight:600}.no-progress-data{padding:20px}.no-progress-data p{margin:0 0 8px}.progress-charts-container{display:flex;flex-direction:column;gap:20px}.progress-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.progress-stat-card{align-items:center;background:linear-gradient(135deg,#121a2f,#00d4aa0d);background:linear-gradient(135deg,var(--bg-elevated) 0,#00d4aa0d 100%);border:1px solid #ffffff0f;border-radius:16px;display:flex;flex-direction:column;gap:8px;overflow:hidden;padding:16px;position:relative}.progress-stat-card.highlight{background:linear-gradient(135deg,#00d4aa26,#00d4aa0d);border-color:#00d4aa4d}.progress-stat-card:before{background:linear-gradient(90deg,#0000,#00d4aa,#0000);content:"";height:3px;left:0;opacity:.5;position:absolute;right:0;top:0}.stat-card-icon{align-items:center;background:#00d4aa26;border-radius:12px;color:#00d4aa;display:flex;height:40px;justify-content:center;width:40px}.stat-card-icon.goal{background:#ef444426;color:#ef4444}.stat-card-icon.remaining{background:#fbbf2426;color:#fbbf24}.stat-card-icon.down{background:#00d4aa26;color:#00d4aa}.stat-card-icon.up{background:#ef444426;color:#ef4444}.stat-card-content{align-items:baseline;display:flex;gap:4px}.stat-card-value{font-feature-settings:"tnum";color:#fff;color:var(--text-primary);font-size:24px;font-variant-numeric:tabular-nums;font-weight:700}.stat-card-unit{font-size:14px;font-weight:500}.stat-card-label,.stat-card-unit{color:#94a3b8;color:var(--text-secondary)}.stat-card-label{font-size:12px;text-align:center}.progress-chart-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.chart-header h5{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600;margin:0}.chart-period{background:#00d4aa1a;border-radius:20px;color:#94a3b8;color:var(--text-secondary);font-size:11px;padding:4px 10px}.weight-chart-container{margin:0 -10px}.chart-legend{border-top:1px solid #ffffff0f;display:flex;gap:24px;justify-content:center;margin-top:12px;padding-top:12px}.legend-item{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:12px;gap:8px}.legend-dot{border-radius:50%;height:10px;width:10px}.legend-dot.dashed{background:#0000!important;border:2px dashed #ff6b6b}.weekly-progress-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.weekly-progress-card h5{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 16px}.weekly-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.weekly-stat{background:#00d4aa0d;border-radius:12px;padding:12px 8px;text-align:center}.weekly-stat-label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:11px;margin-bottom:6px}.weekly-stat-value{color:#fff;color:var(--text-primary);font-size:16px;font-weight:700}.weekly-stat-value.loss{color:#00d4aa}.weekly-stat-value.gain{color:#ef4444}.weekly-calories-card{background:linear-gradient(145deg,#00d4aa14,#00d4aa05);border:1px solid #00d4aa33;border-radius:20px;margin-top:16px;padding:24px}.weekly-calories-header{align-items:center;display:flex;gap:10px;margin-bottom:20px}.weekly-calories-header svg{color:#00d4aa}.weekly-calories-header h5{color:#fff;color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.weekly-calories-progress{align-items:center;display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.calories-ring{align-items:center;background:conic-gradient(#00d4aa 0,#ffffff1a 0);background:conic-gradient(var(--ring-color,#00d4aa) var(--progress,0),#ffffff1a var(--progress,0));border-radius:50%;display:flex;height:140px;justify-content:center;position:relative;width:140px}.calories-ring:before{background:#121a2f;background:var(--bg-elevated);border-radius:50%;content:"";inset:8px;position:absolute}.ring-inner{align-items:center;display:flex;flex-direction:column;gap:2px;position:relative;z-index:1}.ring-percent{color:#fff;color:var(--text-primary);font-size:28px;font-weight:700}.ring-label{color:#94a3b8;color:var(--text-secondary);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.status-badge{align-items:center;border-radius:20px;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px}.status-badge.on-track{background:#00d4aa26;color:#00d4aa}.status-badge.off-track{background:#ff6b6b26;color:#ff6b6b}.weekly-calories-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.cal-stat{background:#ffffff08;border-radius:12px;padding:14px 10px;text-align:center}.cal-stat-value{color:#fff;color:var(--text-primary);display:block;font-size:18px;font-weight:700;margin-bottom:4px}.cal-stat-value.positive{color:#00d4aa}.cal-stat-value.negative{color:#ff6b6b}.cal-stat-label{color:#94a3b8;color:var(--text-secondary);font-size:11px;letter-spacing:.3px;text-transform:uppercase}.weekly-calories-info{border-bottom:1px solid #ffffff0f;border-top:1px solid #ffffff0f;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:16px 0}.info-item{display:flex;flex-direction:column;gap:2px}.info-label{color:#94a3b8;color:var(--text-secondary);font-size:11px}.info-value{color:#fff;color:var(--text-primary);font-size:14px;font-weight:600}.info-value.positive{color:#00d4aa}.info-value.negative{color:#ff6b6b}.daily-breakdown-mini{display:flex;flex-direction:column;gap:12px}.breakdown-title{color:#94a3b8;color:var(--text-secondary);font-size:12px;letter-spacing:.5px;text-transform:uppercase}.breakdown-bars{align-items:flex-end;display:flex;gap:6px;height:100px;justify-content:space-between;padding-top:25px}.breakdown-day{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;height:100%;position:relative}.breakdown-calories{color:#fff;color:var(--text-primary);font-size:10px;font-weight:600;position:absolute;top:-22px;white-space:nowrap}.breakdown-calories.over{color:#ff6b6b}.breakdown-day.future .breakdown-calories{color:#94a3b8;color:var(--text-secondary);opacity:.5}.breakdown-day.future{opacity:.4}.breakdown-bar{background:linear-gradient(180deg,#00d4aa,#00d4aa80);border-radius:4px 4px 0 0;min-height:4px;transition:height .3s ease;width:100%}.breakdown-bar.over{background:linear-gradient(180deg,#ff6b6b,#ff6b6b80)}.breakdown-bar.on-target{background:linear-gradient(180deg,#00d4aa,#00d4aab3);box-shadow:0 0 8px #00d4aa4d}.breakdown-label{color:#94a3b8;color:var(--text-secondary);font-size:10px;text-transform:uppercase}.progress-history-list{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.progress-history-list h5{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 16px}.history-entries{display:flex;flex-direction:column;gap:10px;max-height:350px;overflow-y:auto}.history-entry-card{align-items:center;background:#00d4aa08;border:1px solid #ffffff0a;border-radius:12px;display:flex;gap:12px;padding:12px 14px;transition:all .2s ease}.history-entry-card:hover{background:#00d4aa14;border-color:#00d4aa33}.entry-date{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:12px;gap:6px;min-width:100px}.entry-date svg{color:#00d4aa}.entry-weight{align-items:center;display:flex;flex:1 1;gap:10px}.weight-value{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600}.weight-change-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 8px}.weight-change-badge.loss{background:#00d4aa26;color:#00d4aa}.weight-change-badge.gain{background:#ef444426;color:#ef4444}.entry-measurements{color:#94a3b8;color:var(--text-secondary);display:flex;font-size:11px;gap:8px}.entry-measurements span{background:#ffffff0d;border-radius:10px;padding:2px 8px}.body-measurements-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.body-measurements-card h5{color:#fff;color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 20px}.measurements-visual-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.measurement-visual-item{align-items:center;display:flex;flex-direction:column;gap:10px}.measurement-ring{align-items:center;background:conic-gradient(#00d4aa 0,#00d4aa 0,#ffffff1a 0,#ffffff1a 100%);background:conic-gradient(#00d4aa 0,#00d4aa var(--progress,0),#ffffff1a var(--progress,0),#ffffff1a 100%);border-radius:50%;display:flex;height:70px;justify-content:center;position:relative;width:70px}.measurement-ring:before{background:#121a2f;background:var(--bg-elevated);border-radius:50%;content:"";inset:6px;position:absolute}.measurement-number{color:#fff;color:var(--text-primary);font-size:18px;font-weight:700;position:relative;z-index:1}.measurement-name{color:#94a3b8;color:var(--text-secondary);font-size:11px;text-align:center}.macros-distribution-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.macros-distribution-card h5{font-size:15px;font-weight:600;.btn-register-weight{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:20px;color:#0a0a14;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;margin-left:auto;padding:8px 14px;transition:all .2s ease;white-space:nowrap}.btn-register-weight:hover{box-shadow:0 4px 12px #00d4aa4d;transform:translateY(-1px)}.btn-register-weight:active{transform:translateY(0)}.progress-section-header{align-items:flex-start;display:flex;gap:12px}.weight-modal{animation:modalSlideUp .3s ease;background:#0f172a;border:1px solid #00d4aa33;border-radius:20px;box-shadow:0 20px 50px #00000080;max-width:400px;overflow:hidden;padding:0;width:90%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.weight-modal-header{align-items:center;border-bottom:1px solid #ffffff0f;display:flex;justify-content:space-between;padding:20px 24px}.weight-modal-header h3{color:#fff;color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.weight-modal-close{background:none;border:none;border-radius:8px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;padding:4px;transition:all .2s ease}.weight-modal-close:hover{background:#ffffff1a;color:#fff;color:var(--text-primary)}.weight-modal-body{padding:24px}.weight-input-container{align-items:center;background:#121a2f;background:var(--bg-elevated);border:2px solid #00d4aa4d;border-radius:16px;display:flex;gap:12px;padding:16px 20px;transition:all .2s ease}.weight-input-container:focus-within{border-color:#00d4aa;box-shadow:0 0 0 4px #00d4aa1a}.weight-input{background:#0000;border:none;color:#fff;color:var(--text-primary);flex:1 1;font-size:32px;font-weight:700;outline:none;text-align:center;width:100%}.weight-input::placeholder{color:#94a3b8;color:var(--text-secondary);opacity:.5}.weight-input::-webkit-inner-spin-button,.weight-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.weight-input[type=number]{-moz-appearance:textfield}.weight-unit{color:#94a3b8;color:var(--text-secondary);font-size:18px;font-weight:600}.weight-change-preview{display:flex;justify-content:center;margin-top:16px}.preview-badge{align-items:center;background:#ffffff0d;border-radius:20px;color:#94a3b8;color:var(--text-secondary);display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px}.preview-badge.loss{background:#00d4aa26;color:#00d4aa}.preview-badge.gain{background:#ef444426;color:#ef4444}.weight-modal-hint{color:#94a3b8;color:var(--text-secondary);font-size:13px;line-height:1.5;margin:20px 0 0;text-align:center}.weight-modal-actions{border-top:1px solid #ffffff0f;display:flex;gap:12px;padding:20px 24px}.btn-cancel{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff1a;border-radius:12px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:14px 20px;transition:all .2s ease}.btn-cancel:hover{background:#ffffff1a;color:#fff;color:var(--text-primary)}.btn-save-weight{background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:12px;color:#0a0a14;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:14px 20px;transition:all .2s ease}.btn-save-weight:hover:not(:disabled){box-shadow:0 4px 12px #00d4aa4d;transform:translateY(-1px)}.btn-save-weight:disabled{cursor:not-allowed;opacity:.5}@media (max-width:480px){.btn-register-weight{font-size:11px;padding:6px 12px}.btn-register-weight span{display:none}.weight-modal{margin:0 10px;width:95%}.weight-input{font-size:28px}}color:#fff;color:var(--text-primary);margin:0 0 16px}.macros-chart-container{align-items:center;display:flex;flex-direction:column}.macros-legend{display:flex;gap:20px;justify-content:center;margin-top:12px}.macro-legend-item{align-items:center;display:flex;font-size:12px;gap:8px}.macro-legend-item,.no-progress-data{color:#94a3b8;color:var(--text-secondary)}.no-progress-data{padding:40px 20px;text-align:center}.empty-state-icon{margin-bottom:16px;opacity:.4}.empty-state-icon svg{color:#00d4aa}@media (max-width:480px){.progress-stats-grid{gap:10px;grid-template-columns:repeat(2,1fr)}.progress-stat-card{padding:14px 12px}.stat-card-value{font-size:20px}.weekly-stats{gap:8px;grid-template-columns:1fr}.measurements-visual-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.measurement-ring{height:60px;width:60px}.measurement-number{font-size:15px}.entry-measurements{display:none}.chart-legend{gap:16px}}.profile-simplified{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.profile-edit-section{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:16px;padding:20px}.profile-edit-section .form-group{margin-bottom:16px}.profile-edit-section .form-group:last-child{margin-bottom:0}.form-input.readonly{background:#ffffff08;color:#94a3b8;color:var(--text-secondary);cursor:not-allowed}.goals-summary-card{background:linear-gradient(135deg,#121a2f,#00d4aa0d);background:linear-gradient(135deg,var(--bg-elevated) 0,#00d4aa0d 100%);border:1px solid #00d4aa26;border-radius:20px;overflow:hidden;padding:24px;position:relative}.goals-summary-card:before{background:linear-gradient(90deg,#00d4aa,#00b894);content:"";height:4px;left:0;position:absolute;right:0;top:0}.goals-summary-header{align-items:center;display:flex;gap:12px;margin-bottom:20px}.goals-summary-icon{color:#00d4aa}.goals-summary-header h4{color:#fff;color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.goals-summary-content{display:flex;flex-direction:column;gap:14px}.goals-summary-item{align-items:center;display:flex;justify-content:space-between}.summary-label{color:#94a3b8;color:var(--text-secondary);font-size:14px}.summary-value{align-items:center;color:#fff;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:8px}.summary-arrow{color:#00d4aa;font-weight:400}.goals-summary-divider{background:#ffffff14;height:1px;margin:8px 0}.goals-summary-macros{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.macro-summary-item{align-items:center;background:#0003;border-radius:12px;display:flex;gap:8px;padding:10px 12px}.macro-icon,.macro-icon.calories{color:#f59e0b}.macro-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.macro-dot.protein{background:#00d4aa}.macro-dot.carbs{background:#3b82f6}.macro-dot.fat{background:#f59e0b}.macro-value{color:#fff;color:var(--text-primary);font-size:15px;font-weight:700}.macro-unit{color:#94a3b8;color:var(--text-secondary);font-size:11px}.btn-edit-goals{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:12px;color:#0a0a14;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-top:20px;padding:14px 20px;transition:all .2s ease;width:100%}.btn-edit-goals:hover{box-shadow:0 6px 20px #00d4aa4d;transform:translateY(-2px)}.btn-edit-goals svg{stroke:#0a0a14}.goals-setup-prompt-card{background:#121a2f;background:var(--bg-elevated);border:1px solid #ffffff0f;border-radius:20px;padding:32px 24px;text-align:center}.goals-setup-prompt-card .prompt-icon{align-items:center;background:#00d4aa1a;border-radius:50%;color:#00d4aa;display:flex;height:64px;justify-content:center;margin:0 auto 16px;width:64px}.goals-setup-prompt-card h4{color:#fff;color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 8px}.goals-setup-prompt-card p{color:#94a3b8;color:var(--text-secondary);line-height:1.5;margin:0 0 20px}@media (max-width:480px){.goals-summary-macros{gap:8px;grid-template-columns:1fr 1fr}.macro-summary-item{padding:8px 10px}.macro-value{font-size:14px}}.toast-notification{align-items:center;animation:toastSlideUp .4s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;bottom:100px;box-shadow:0 10px 40px #0006,0 0 0 1px #ffffff1a;display:flex;gap:12px;left:50%;max-width:90%;min-width:280px;padding:14px 20px;position:fixed;transform:translateX(-50%);z-index:10000}@keyframes toastSlideUp{0%{opacity:0;transform:translateX(-50%) translateY(20px) scale(.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.toast-notification.success{border-left:4px solid #00d4aa}.toast-notification.success .toast-icon{background:#00d4aa26;color:#00d4aa}.toast-notification.error{border-left:4px solid #ef4444}.toast-notification.error .toast-icon{background:#ef444426;color:#ef4444}.toast-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.toast-message{color:#fff;flex:1 1;font-size:14px;font-weight:500;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:8px;color:#666;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .2s ease}.toast-close:hover{background:#ffffff1a;color:#fff}@media (max-width:480px){.toast-notification{bottom:90px;left:16px;max-width:none;min-width:auto;right:16px;transform:none}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}}.quick-actions-section{margin-bottom:24px}.quick-actions-section .heading-3{font-size:18px;font-weight:600;margin-bottom:16px}.quick-actions-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.quick-action-btn{align-items:center;background:linear-gradient(145deg,#00d4aa1a,#00b4940d);border:1px solid #00d4aa33;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:16px 12px;transition:all .3s ease}.quick-action-btn:hover{background:linear-gradient(145deg,#00d4aa33,#00b4941a);border-color:#00d4aa66;box-shadow:0 4px 12px #00d4aa33;transform:translateY(-2px)}.quick-action-btn:active{transform:translateY(0)}.quick-action-icon{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.quick-action-btn span{color:#fff;font-size:13px;font-weight:600;text-align:center}.meals-section{background:#0003;border-radius:16px;padding:16px}.meals-section-title{color:#ffffffe6;font-size:16px;font-weight:600;margin-bottom:12px}@media (max-width:360px){.quick-actions-grid{gap:8px}.quick-action-btn{padding:12px 8px}.quick-action-icon{height:40px;width:40px}.quick-action-btn span{font-size:11px}}.auth-callback-container{align-items:center;background:#0a0a1a;display:flex;justify-content:center;min-height:100vh}.auth-callback-content{text-align:center}.auth-spinner{animation:authSpin .6s linear infinite;border:3px solid #00d4aa33;border-radius:50%;border-top-color:#00d4aa;height:48px;margin:0 auto 16px;width:48px}@keyframes authSpin{to{transform:rotate(1turn)}}.auth-callback-content p{color:#a0a0b0;font-size:16px;margin:0}.notification-settings{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 20px 40px #0006;max-width:400px;padding:24px;width:100%}.notification-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.notification-header h3{color:#fff;font-size:1.25rem;font-weight:600;margin:0}.close-btn{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-btn:hover{background:#fff3;transform:scale(1.05)}.notification-content{display:flex;flex-direction:column;gap:20px}.notification-status{background:#ffffff0d;border-radius:12px;padding:16px}.status-indicator{align-items:center;display:flex;gap:12px}.status-dot{border-radius:50%;height:12px;transition:all .3s ease;width:12px}.status-dot.active{animation:pulse 2s infinite;background:#10b981;box-shadow:0 0 12px #10b98180}.status-dot.inactive{background:#6b7280}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.status-text{color:#fff;font-size:.95rem;font-weight:500}.permission-warning{background:#ef44441a;border-radius:8px;color:#fca5a5;font-size:.85rem;line-height:1.5;margin-top:12px;padding:12px}.notification-info{padding:0 4px}.notification-info p{color:#ffffffb3;font-size:.9rem;margin-bottom:12px}.notification-info ul{grid-gap:8px;display:grid;gap:8px;list-style:none;margin:0;padding:0}.notification-info li{color:#ffffffd9;font-size:.9rem;padding-left:24px;position:relative}.notification-info li:before{color:#10b981;content:"✓";font-weight:700;left:0;position:absolute}.notification-actions{display:flex;flex-direction:column;gap:12px}.toggle-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .3s ease;width:100%}.toggle-btn:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.toggle-btn.active{background:linear-gradient(135deg,#374151,#1f2937)}.toggle-btn.active:hover:not(:disabled){box-shadow:0 8px 20px #37415166}.toggle-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.test-btn{background:#0000;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .3s ease;width:100%}.test-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d}.test-btn:disabled{cursor:not-allowed;opacity:.5}.notification-message{animation:fadeIn .3s ease;border-radius:8px;font-size:.9rem;padding:12px 16px;text-align:center}.notification-message.success{background:#10b98126;border:1px solid #10b9814d;color:#34d399}.notification-message.error{background:#ef444426;border:1px solid #ef44444d;color:#fca5a5}.notification-unsupported{padding:24px;text-align:center}.notification-unsupported p{color:#ffffffb3;font-size:.95rem;margin:0 0 8px}.notification-unsupported .hint{color:#ffffff80;font-size:.85rem}@media (max-width:480px){.notification-settings{border-radius:12px;padding:20px}.notification-header h3{font-size:1.1rem}.test-btn,.toggle-btn{padding:12px 20px}}.email-settings{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 20px 40px #0006;max-width:450px;padding:24px;width:100%}.email-settings-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.email-settings-header h3{color:#fff;font-size:1.25rem;font-weight:600;margin:0}.email-settings-header .close-btn{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.email-settings-header .close-btn:hover{background:#fff3}.email-settings-loading{color:#fff9;padding:40px;text-align:center}.email-settings-intro{color:#ffffffb3;font-size:.9rem;margin-bottom:20px}.email-options{display:flex;flex-direction:column;gap:12px}.email-option{align-items:center;background:#ffffff0d;border-radius:12px;display:flex;justify-content:space-between;padding:16px;transition:background .2s ease}.email-option:hover{background:#ffffff14}.email-option-info{align-items:flex-start;display:flex;flex:1 1;gap:12px}.email-option-icon{flex-shrink:0;font-size:1.5rem}.email-option-text{display:flex;flex-direction:column;gap:4px}.email-option-title{color:#fff;font-size:.95rem;font-weight:500}.email-option-description{color:#ffffff80;font-size:.8rem;line-height:1.4}.toggle-switch{display:inline-block;flex-shrink:0;height:26px;position:relative;width:48px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#fff3;border-radius:26px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:20px;left:3px;position:absolute;transition:.3s;width:20px}input:checked+.toggle-slider{background:linear-gradient(135deg,#00d4aa,#00a080)}input:checked+.toggle-slider:before{transform:translateX(22px)}input:disabled+.toggle-slider{cursor:not-allowed;opacity:.5}.email-settings-actions{border-top:1px solid #ffffff1a;margin-top:24px;padding-top:20px}.test-email-btn{background:#0000;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:14px 24px;transition:all .3s ease;width:100%}.test-email-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d}.test-email-btn:disabled{cursor:not-allowed;opacity:.5}.email-settings-message{animation:fadeIn .3s ease;border-radius:8px;font-size:.9rem;margin-top:16px;padding:12px 16px;text-align:center}.email-settings-message.success{background:#10b98126;border:1px solid #10b9814d;color:#34d399}.email-settings-message.error{background:#ef444426;border:1px solid #ef44444d;color:#fca5a5}@media (max-width:480px){.email-settings{border-radius:12px;padding:20px}.email-option{padding:14px}.email-option-icon{font-size:1.3rem}.email-option-title{font-size:.9rem}.email-option-description{font-size:.75rem}.toggle-switch{height:24px;width:44px}.toggle-slider:before{height:18px;width:18px}input:checked+.toggle-slider:before{transform:translateX(20px)}}.ai-chat-container{background:linear-gradient(180deg,#0a0a1a,#1a1a2e);bottom:0;display:flex;flex-direction:column;height:100%;height:100dvh;left:0;position:fixed;right:0;top:0;z-index:1000}.ai-chat-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2ef2;border-bottom:1px solid #ffffff1a;display:flex;gap:12px;padding:16px 20px}.ai-chat-header .back-button{background:none;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px;transition:background .2s}.ai-chat-header .back-button:hover{background:#ffffff1a}.ai-chat-title{flex:1 1}.ai-chat-title h1{color:#fff;font-size:18px;font-weight:600;margin:0}.ai-chat-subtitle{color:#00d4aa;font-size:12px}.new-chat-button{background:#00d4aa26;border:1px solid #00d4aa4d;border-radius:8px;color:#00d4aa;cursor:pointer;padding:8px;transition:all .2s}.new-chat-button:hover{background:#00d4aa40}.ai-chat-usage{align-items:center;background:#0000004d;color:#888;display:flex;font-size:12px;gap:12px;justify-content:center;padding:8px 16px}.usage-warning{color:#ffd93d;font-weight:500}.ai-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-x:hidden;overflow-y:auto;padding:16px}.chat-message{animation:fadeIn .3s ease;display:flex;gap:10px;max-width:85%}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message.assistant{align-self:flex-start}.message-avatar{align-items:center;background:linear-gradient(135deg,#00d4aa,#00a085);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.message-content{display:flex;flex-direction:column;gap:4px;max-width:100%;overflow:hidden}.message-image{border-radius:12px;margin-bottom:8px;max-width:200px;overflow:hidden}.message-image img{display:block;height:auto;width:100%}.message-text{word-wrap:break-word;border-radius:18px;font-size:14px;line-height:1.5;max-width:100%;overflow-wrap:break-word;padding:12px 16px;white-space:pre-wrap;word-break:break-word}.chat-message.assistant .message-text{background:#ffffff1a;border-bottom-left-radius:4px;color:#fff}.chat-message.user .message-text{background:linear-gradient(135deg,#00d4aa,#00a085);border-bottom-right-radius:4px;color:#fff}.message-text li{list-style-type:disc;margin-left:16px}.message-time{color:#666;font-size:10px;padding:0 8px}.chat-message.user .message-time{text-align:right}.typing-indicator{display:flex;gap:4px;padding:12px 16px}.typing-indicator span{animation:bounce 1.4s ease-in-out infinite;background:#00d4aa;border-radius:50%;height:8px;width:8px}.typing-indicator span:first-child{animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.ai-chat-error{align-items:center;background:#ff6b6b26;border:1px solid #ff6b6b4d;border-radius:8px;color:#ff6b6b;display:flex;font-size:13px;justify-content:space-between;margin:0 16px;padding:10px 16px}.ai-chat-error button{background:none;border:none;color:#ff6b6b;cursor:pointer;padding:4px}.image-preview-bar{align-items:center;background:#0000004d;display:flex;gap:8px;padding:8px 16px}.image-preview-bar img{border-radius:8px;height:60px;object-fit:cover;width:60px}.remove-image-btn{align-items:center;background:#ff6b6b33;border:none;border-radius:50%;color:#ff6b6b;cursor:pointer;display:flex;height:28px;justify-content:center;width:28px}.ai-chat-input-area{align-items:flex-end;background:#1a1a2efa;border-top:1px solid #ffffff1a;bottom:0;display:flex;gap:8px;padding:12px 16px calc(16px + env(safe-area-inset-bottom, 16px));position:-webkit-sticky;position:sticky;z-index:100}.attach-image-btn{background:none;border:none;border-radius:8px;color:#888;cursor:pointer;padding:10px;transition:all .2s}.attach-image-btn:hover{background:#00d4aa1a;color:#00d4aa}.ai-chat-input-area textarea{background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;color:#fff;flex:1 1;font-family:inherit;font-size:14px;max-height:120px;padding:12px 16px;resize:none}.ai-chat-input-area textarea::placeholder{color:#666}.ai-chat-input-area textarea:focus{border-color:#00d4aa;outline:none}.send-message-btn{align-items:center;background:linear-gradient(135deg,#00d4aa,#00a085);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.send-message-btn:hover:not(:disabled){box-shadow:0 4px 15px #00d4aa66;transform:scale(1.05)}.send-message-btn:disabled{cursor:not-allowed;opacity:.5}.limit-modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.limit-modal{background:linear-gradient(180deg,#1a1a2e,#16213e);border:1px solid #ffffff1a;border-radius:20px;max-width:340px;padding:32px 24px;text-align:center;width:100%}.limit-modal-icon{color:#ffd93d;margin-bottom:16px}.limit-modal h3{color:#fff;font-size:20px;margin:0 0 12px}.limit-modal p{color:#888;font-size:14px;margin:0 0 8px}.limit-info{background:#ffffff0d;border-radius:8px;margin:16px 0;padding:12px}.limit-info strong{color:#00d4aa}.limit-modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.limit-modal .upgrade-btn{background:linear-gradient(135deg,#00d4aa,#00a085);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px 24px;transition:all .2s}.limit-modal .upgrade-btn:hover{box-shadow:0 4px 15px #00d4aa66;transform:scale(1.02)}.limit-modal .close-btn{background:#0000;border:1px solid #fff3;border-radius:12px;color:#888;cursor:pointer;font-size:14px;padding:12px 24px;transition:all .2s}.limit-modal .close-btn:hover{border-color:#fff6;color:#fff}@media (max-width:480px){.ai-chat-header{padding:12px 16px}.ai-chat-title h1{font-size:16px}.chat-message{max-width:90%}.message-text{font-size:13px;padding:10px 14px}.ai-chat-input-area{padding-bottom:calc(20px + env(safe-area-inset-bottom, 20px))}.ai-chat-input-area textarea{font-size:16px}}.voice-record-btn{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);background:linear-gradient(135deg,var(--primary,#00d4aa) 0,#00b894 100%);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;min-width:40px;position:relative;transition:all .3s ease;width:40px}.voice-record-btn:hover:not(:disabled){box-shadow:0 4px 12px #00d4aa4d;transform:scale(1.05)}.voice-record-btn:disabled{cursor:not-allowed;opacity:.5}.voice-record-btn.recording{animation:pulse-record 1.5s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a5a)}.voice-record-btn.processing{background:linear-gradient(135deg,#667eea,#764ba2)}@keyframes pulse-record{0%,to{box-shadow:0 0 0 0 #ff6b6b66}50%{box-shadow:0 0 0 10px #ff6b6b00}}.voice-record-btn .voice-spinner{animation:spin 1s linear infinite}.add-food-from-chat,.add-foods-from-chat{border-top:1px solid #ffffff1a;margin-top:12px;padding-top:12px}.foods-detected-header{align-items:center;color:#00d4aa;display:flex;font-size:13px;font-weight:600;gap:8px;margin-bottom:12px}.foods-list{display:flex;flex-direction:column;gap:10px}.food-item-row{align-items:center;background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;display:flex;gap:12px;justify-content:space-between;padding:10px 12px}.food-item-info{flex:1 1;min-width:0}.food-item-name{color:#fff;display:block;font-size:14px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.food-item-macros{color:#fff9;display:block;font-size:11px}.food-item-row .add-food-btn{flex-shrink:0;font-size:12px;padding:8px 14px;width:auto}.food-item-row .food-added-badge{flex-shrink:0;font-size:12px;gap:4px;padding:6px 12px}.add-all-foods-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-top:12px;padding:12px 16px;transition:all .2s ease;width:100%}.add-all-foods-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-1px)}.add-food-btn{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s ease;width:100%}.add-food-btn:hover:not(:disabled){box-shadow:0 4px 12px #00d4aa4d;transform:translateY(-1px)}.add-food-btn:disabled{cursor:not-allowed;opacity:.7}.add-food-btn .spinner{animation:spin 1s linear infinite}.food-added-badge{background:#00d4aa26;border:1px solid #00d4aa4d;border-radius:8px;color:#00d4aa;font-size:14px;font-weight:500;gap:8px;padding:10px 16px}.food-added-badge,.quantity-modal-overlay{align-items:center;display:flex;justify-content:center}.quantity-modal-overlay{background:#000c;bottom:0;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.quantity-modal{animation:slideUp .3s ease;background:linear-gradient(180deg,#1a1a2e,#16213e);border-radius:20px;box-shadow:0 20px 60px #00000080;box-sizing:border-box;max-width:340px;overflow:hidden;padding:24px;width:calc(100% - 40px)}.quantity-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.quantity-modal-header h3{color:#fff;font-size:18px;font-weight:600;margin:0}.close-modal-btn{background:none;border:none;border-radius:6px;color:#fff9;cursor:pointer;padding:4px;transition:all .2s}.close-modal-btn:hover{background:#ffffff1a;color:#fff}.quantity-modal-food-name{color:#00d4aa;font-size:20px;font-weight:700;margin-bottom:16px;text-transform:capitalize}.quantity-modal-meal-type{margin-bottom:16px}.quantity-modal-meal-type label{color:#ffffffb3;display:block;font-size:14px;font-weight:500;margin-bottom:10px}.quantity-modal-meal-type .meal-type-selector-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.quantity-modal-meal-type .meal-type-option{align-items:center;background:#0000004d;border:2px solid #ffffff1a;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:10px 6px;transition:all .2s ease}.quantity-modal-meal-type .meal-type-option:hover{background:#00d4aa1a;border-color:#00d4aa80}.quantity-modal-meal-type .meal-type-option.active{background:#00d4aa33;border-color:#00d4aa}.quantity-modal-meal-type .meal-type-icon{font-size:18px;margin-bottom:4px}.quantity-modal-meal-type .meal-type-label{color:#ffffffb3;font-size:10px;font-weight:600;line-height:1.2;text-align:center}.quantity-modal-meal-type .meal-type-option.active .meal-type-label{color:#00d4aa}@media (max-width:360px){.quantity-modal-meal-type .meal-type-selector-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.quantity-modal-meal-type .meal-type-option{padding:12px 8px}.quantity-modal-meal-type .meal-type-icon{font-size:20px}.quantity-modal-meal-type .meal-type-label{font-size:11px}}.quantity-modal-input-section{align-items:center;background:#0003;border-radius:12px;box-sizing:border-box;display:flex;gap:12px;margin-bottom:20px;padding:16px}.quantity-modal-input-section label{color:#ffffffb3;flex-shrink:0;font-size:14px;white-space:nowrap}.quantity-modal-input-section input{background:#0000004d;border:1px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;flex:1 1;font-size:18px;font-weight:600;max-width:120px;min-width:0;padding:12px 16px;text-align:center}.quantity-modal-input-section input:focus{border-color:#00d4aa;outline:none}.quantity-modal-nutrition{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.nutrition-preview-item{background:#0003;border-radius:10px;padding:12px 8px;text-align:center}.nutrition-preview-value{color:#fff;display:block;font-size:18px;font-weight:700}.nutrition-preview-label{color:#ffffff80;display:block;font-size:11px;margin-top:2px}.quantity-modal-actions{display:flex;flex-direction:column;gap:10px}.confirm-add-btn{align-items:center;background:linear-gradient(135deg,#00d4aa,#00b894);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;transition:all .2s ease}.confirm-add-btn:hover:not(:disabled){box-shadow:0 4px 12px #00d4aa4d;transform:translateY(-1px)}.confirm-add-btn:disabled{cursor:not-allowed;opacity:.5}.cancel-add-btn{background:#0000;border:1px solid #fff3;border-radius:12px;color:#ffffffb3;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s ease}.cancel-add-btn:hover{background:#ffffff0d;border-color:#ffffff4d}.install-app-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:14px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;margin-top:16px;padding:14px 20px;transition:all .3s ease;width:100%}.install-app-button:hover:not(:disabled){box-shadow:0 8px 24px #667eea66;transform:translateY(-2px)}.install-app-button:disabled{cursor:wait;opacity:.7}.install-app-button svg{flex-shrink:0}.ios-modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ios-modal{animation:slideUp .4s ease;background:linear-gradient(180deg,#1a1a2e,#16213e);border:1px solid #ffffff1a;border-radius:24px;max-width:360px;padding:28px 24px;width:100%}.ios-modal-header{align-items:center;display:flex;flex-direction:column;margin-bottom:16px}.ios-modal-icon{border-radius:14px;box-shadow:0 8px 24px #00d4aa4d;height:64px;margin-bottom:12px;width:64px}.ios-modal-header h3{color:#fff;font-size:20px;font-weight:700;margin:0}.ios-modal-subtitle{color:#fff9;font-size:14px;line-height:1.5;margin:0 0 16px;text-align:center}.ios-safari-warning{align-items:flex-start;background:#ff950026;border:1px solid #ff95004d;border-radius:12px;display:flex;gap:10px;margin-bottom:20px;padding:12px 14px}.ios-safari-warning svg{flex-shrink:0;margin-top:2px}.ios-safari-warning span{color:#ffffffe6;font-size:13px;line-height:1.5}.ios-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.ios-step-item{align-items:flex-start;display:flex;gap:14px}.step-number{align-items:center;background:linear-gradient(135deg,#00d4aa,#00a085);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}.step-content{flex:1 1}.step-text{color:#ffffffe6;display:block;font-size:14px;line-height:1.5;margin-bottom:8px}.step-icon{padding:8px}.step-action,.step-icon{background:#ffffff1a;border-radius:8px;display:inline-flex}.step-action{align-items:center;color:#ffffffe6;font-size:13px;gap:8px;padding:8px 14px}.step-action svg{color:#007aff}.ios-modal-close{background:linear-gradient(135deg,#00d4aa,#00a085);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px 20px;transition:all .3s ease;width:100%}.ios-modal-close:hover{box-shadow:0 8px 24px #00d4aa66;transform:translateY(-2px)}.goals-setup-overlay{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:3000}.goals-setup-modal{animation:slideUp .3s ease;background:var(--bg-card);border-radius:24px;display:flex;flex-direction:column;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.goals-header{padding:20px 20px 16px;position:relative}.goals-close-btn{align-items:center;background:var(--bg-elevated);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px}.goals-close-btn:hover{background:var(--bg-glass);color:var(--text-primary)}.goals-progress{background:var(--bg-elevated);border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.goals-progress-bar{background:var(--gradient-button);border-radius:2px;height:100%;transition:width .3s ease}.goals-step-indicator{color:var(--text-muted);display:block;font-size:.8rem;margin-top:8px;text-align:center}.goals-content{flex:1 1;overflow-y:auto;padding:0 24px}.goals-step{padding-bottom:20px}.goals-step-header{margin-bottom:24px;text-align:center}.goals-step-icon{color:var(--brand-primary);margin-bottom:12px}.goals-step-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 8px}.goals-step-header p{color:var(--text-secondary);font-size:.95rem;margin:0}.goals-options{display:flex;flex-direction:column;gap:12px}.goals-option{align-items:center;background:var(--bg-elevated);border:2px solid var(--border-light);border-radius:16px;cursor:pointer;display:flex;gap:16px;padding:16px;text-align:left;transition:all .2s ease}.goals-option.selected,.goals-option:hover{background:var(--bg-glass);border-color:var(--option-color,var(--brand-primary))}.goals-option.selected{box-shadow:0 0 20px #00d9a533}.goals-option-icon{align-items:center;background:#ffffff0d;border-radius:14px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.goals-option-text{display:flex;flex:1 1;flex-direction:column;gap:4px}.goals-option-title{color:var(--text-primary);font-size:1rem;font-weight:600}.goals-option-desc{color:var(--text-secondary);font-size:.85rem}.goals-option-check{color:var(--brand-primary);flex-shrink:0}.goals-form{display:flex;flex-direction:column;gap:16px}.goals-form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.goals-form-group{display:flex;flex-direction:column;gap:6px}.goals-form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.goals-form-group input{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:12px;color:var(--text-primary);font-size:1rem;padding:14px 16px;transition:all .2s ease}.goals-form-group input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px #00d9a51a;outline:none}.goals-form-group input::placeholder{color:var(--text-muted)}.goals-gender-options{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.goals-gender-btn{background:var(--bg-elevated);border:2px solid var(--border-light);border-radius:12px;color:var(--text-secondary);cursor:pointer;font-size:1rem;font-weight:500;padding:14px 16px;transition:all .2s ease}.goals-gender-btn:hover{border-color:var(--brand-primary);color:var(--text-primary)}.goals-gender-btn.selected{background:#00d9a51a;border-color:var(--brand-primary);color:var(--brand-primary)}.goals-activity-options{display:flex;flex-direction:column;gap:10px}.goals-activity-option{align-items:center;background:var(--bg-elevated);border:2px solid var(--border-light);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;text-align:left;transition:all .2s ease}.goals-activity-option.selected,.goals-activity-option:hover{border-color:var(--brand-primary)}.goals-activity-option.selected{background:#00d9a51a}.goals-activity-info{display:flex;flex-direction:column;gap:2px}.goals-activity-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.goals-activity-desc{color:var(--text-secondary);font-size:.8rem}.goals-activity-multiplier{background:#00d9a51a;border-radius:20px;color:var(--brand-primary);font-size:.85rem;font-weight:600;padding:4px 10px}.goals-results{text-align:center}.goals-success-icon{color:var(--brand-primary);margin-bottom:8px}.goals-results-cards{display:flex;flex-direction:column;gap:16px;margin-top:24px}.goals-result-card{align-items:center;background:var(--bg-elevated);border-radius:16px;display:flex;gap:16px;padding:20px}.goals-result-card.calories{background:linear-gradient(135deg,#00d9a526,#00d9a50d);border:1px solid #00d9a54d;flex-direction:column;text-align:center}.goals-result-card.calories .goals-result-value{color:var(--brand-primary);font-size:3rem;font-weight:800;line-height:1}.goals-result-card.calories .goals-result-unit{color:var(--text-secondary);font-size:1.2rem}.goals-result-card.water{background:linear-gradient(135deg,#3b82f626,#3b82f60d);border:1px solid #3b82f64d}.goals-result-card.water svg{color:#3b82f6}.goals-result-card.prediction{background:linear-gradient(135deg,#a855f726,#a855f70d);border:1px solid #a855f74d}.goals-result-card.prediction svg{color:#a855f7}.goals-result-card>div{display:flex;flex-direction:column;text-align:left}.goals-result-label{color:var(--text-secondary);font-size:.85rem}.goals-result-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.goals-result-detail{color:var(--text-muted);font-size:.8rem}.goals-macros-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.goals-macro-card{align-items:center;background:var(--bg-elevated);border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:16px 12px}.goals-macro-card.protein{border-left:3px solid #ef4444}.goals-macro-card.carbs{border-left:3px solid #f59e0b}.goals-macro-card.fat{border-left:3px solid #3b82f6}.goals-macro-value{color:var(--text-primary);font-size:1.25rem;font-weight:700}.goals-macro-label{color:var(--text-secondary);font-size:.75rem}.goals-info-box{background:var(--bg-elevated);border-radius:12px;margin-top:16px;padding:16px}.goals-info-box p{color:var(--text-secondary);font-size:.85rem;margin:0}.goals-info-box strong{color:var(--text-primary)}.goals-info-note{color:var(--text-muted)!important;font-size:.8rem!important;margin-top:8px!important}.goals-footer{border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.goals-back-btn{align-items:center;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:6px;padding:14px 20px;transition:all .2s ease}.goals-back-btn:hover{background:var(--bg-glass);color:var(--text-primary)}.goals-done-btn,.goals-next-btn,.goals-submit-btn{align-items:center;background:var(--gradient-button);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:6px;justify-content:center;padding:14px 24px;transition:all .2s ease}.goals-next-btn:disabled,.goals-submit-btn:disabled{cursor:not-allowed;opacity:.5}.goals-done-btn:hover,.goals-next-btn:not(:disabled):hover,.goals-submit-btn:not(:disabled):hover{box-shadow:0 8px 24px #00d9a566;transform:translateY(-2px)}@media (max-width:480px){.goals-setup-overlay{align-items:flex-end;padding:0}.goals-setup-modal{border-radius:24px 24px 0 0;max-height:95vh}.goals-form-row,.goals-macros-row{grid-template-columns:1fr}}.voice-button{align-items:center;background:linear-gradient(135deg,var(--primary) 0,#00b894 100%);border:none;border-radius:50%;box-shadow:0 2px 8px #00d4aa4d;color:#fff;cursor:pointer;display:flex;justify-content:center;position:relative;transition:all .3s ease}.voice-button:hover:not(:disabled){box-shadow:0 4px 16px #00d4aa66;transform:scale(1.05)}.voice-button:active:not(:disabled){transform:scale(.95)}.voice-button:disabled{cursor:not-allowed;opacity:.7}.voice-btn-small{height:36px;width:36px}.voice-btn-medium{height:44px;width:44px}.voice-btn-large{height:56px;width:56px}.voice-button.recording{animation:voice-glow 1.5s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a5a);box-shadow:0 2px 8px #ff6b6b66}@keyframes voice-glow{0%,to{box-shadow:0 2px 8px #ff6b6b66}50%{box-shadow:0 4px 20px #ff6b6b99}}.voice-button.processing{background:linear-gradient(135deg,#667eea,#764ba2)}.voice-spinner{animation:spin 1s linear infinite}.voice-pulse{animation:pulse-ring 1.5s ease-out infinite;background:#ff6b6b4d;border-radius:50%;height:100%;pointer-events:none;position:absolute;width:100%}@keyframes pulse-ring{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.voice-recording-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;inset:0;justify-content:center;position:fixed;z-index:1000}.voice-recording-content,.voice-recording-overlay{align-items:center;display:flex;flex-direction:column}.voice-recording-content{gap:24px;padding:32px}.voice-recording-animation{height:120px;position:relative;width:120px}.voice-recording-animation,.voice-recording-circle{align-items:center;display:flex;justify-content:center}.voice-recording-circle{background:linear-gradient(135deg,#ff6b6b,#ee5a5a);border-radius:50%;color:#fff;height:80px;width:80px;z-index:2}.voice-recording-wave{animation:wave-expand 1.5s ease-out infinite;border:3px solid #ff6b6b80;border-radius:50%;height:80px;position:absolute;width:80px}.voice-recording-wave:nth-child(2){animation-delay:.5s}.voice-recording-wave:nth-child(3){animation-delay:1s}@keyframes wave-expand{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(2)}}.voice-recording-text{color:#fff;font-size:18px;font-weight:500}.voice-recording-hint{color:#fff9;font-size:14px}.voice-cancel-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:24px;color:#fff;cursor:pointer;font-size:14px;margin-top:16px;padding:12px 32px;transition:all .2s ease}.voice-cancel-btn:hover{background:#fff3}.voice-food-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:9999}.voice-food-modal{animation:slideUp .3s ease-out;background:#1a1a2e;background:var(--card-bg,#1a1a2e);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 -4px 30px #0000004d;display:flex;flex-direction:column;margin:12px;max-height:calc(100vh - 160px);max-width:500px;width:calc(100% - 24px)}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.voice-food-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 16px}.voice-food-header h3{color:var(--text-primary);font-size:18px;margin:0}.voice-food-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.voice-food-close:hover{background:#ffffff1a;color:var(--text-primary)}.voice-food-body{flex:1 1;min-height:0;overflow-y:auto;padding:12px 16px}.voice-transcription{background:#00d4aa1a;border:1px solid #00d4aa33;border-radius:8px;margin-bottom:12px;padding:10px}.voice-transcription-label{color:var(--text-muted);font-size:12px;margin-bottom:4px}.voice-transcription-text{color:var(--primary);font-size:14px;font-style:italic}.voice-food-name{color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:12px}.voice-food-nutrition{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-bottom:12px}.voice-nutrition-item{background:#ffffff0d;border-radius:8px;padding:10px 8px;text-align:center}.voice-nutrition-value{color:var(--text-primary);font-size:18px;font-weight:600}.voice-nutrition-label{color:var(--text-muted);font-size:11px;margin-top:2px}.voice-nutrition-item.calories .voice-nutrition-value{color:#ff6b6b}.voice-nutrition-item.protein .voice-nutrition-value{color:#00d4aa}.voice-nutrition-item.carbs .voice-nutrition-value{color:#667eea}.voice-nutrition-item.fat .voice-nutrition-value{color:#ffd93d}.voice-quantity-section{margin-bottom:12px}.voice-quantity-section label{color:var(--text-secondary);display:block;font-size:13px;margin-bottom:6px}.voice-quantity-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:16px;padding:10px 12px;width:100%}.voice-quantity-input:focus{border-color:var(--primary);outline:none}.voice-food-actions{background:#1a1a2e;background:var(--card-bg,#1a1a2e);border-radius:0 0 20px 20px;display:flex;flex-shrink:0;gap:12px;padding:12px 16px 16px}.voice-food-actions button{border-radius:12px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:16px;transition:all .2s ease}.voice-add-btn{background:linear-gradient(135deg,var(--primary) 0,#00b894 100%);border:none;color:#fff}.voice-add-btn:hover{box-shadow:0 4px 12px #00d4aa4d;transform:translateY(-1px)}.voice-cancel-food-btn{background:#0000;border:1px solid var(--border-color);color:var(--text-secondary)}.voice-cancel-food-btn:hover{background:#ffffff0d}.voice-food-not-found{padding:20px;text-align:center}.voice-food-not-found-icon{font-size:48px;margin-bottom:12px}.voice-food-not-found h4{color:var(--text-primary);margin-bottom:8px}.voice-food-not-found p{color:var(--text-muted);font-size:14px;margin-bottom:16px}.voice-meal-type-section{margin-bottom:8px}.voice-meal-type-section label{color:var(--text-secondary);display:block;font-size:13px;margin-bottom:6px}.voice-meal-type-select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:16px;padding:10px 12px;width:100%}.voice-meal-type-select:focus{border-color:var(--primary);outline:none}.voice-food-actions button:disabled{cursor:not-allowed;opacity:.6;transform:none}.voice-add-btn .voice-spinner{animation:spin 1s linear infinite;margin-right:8px}.voice-food-actions{background:var(--card-bg);border-top:1px solid var(--border-color);bottom:0;margin-top:20px;padding-top:16px;position:-webkit-sticky;position:sticky}@media (max-height:600px){.voice-food-modal{max-height:95vh}.voice-food-body{padding:12px}.voice-food-nutrition{gap:8px}.voice-nutrition-item{padding:8px}.voice-meal-type-section,.voice-quantity-section{margin-bottom:12px}}.voice-limit-body{padding:24px 16px!important;text-align:center}.voice-limit-icon{color:#ffd93d;margin-bottom:16px}.voice-limit-message{color:var(--text-primary);font-size:16px;line-height:1.5;margin-bottom:12px}.voice-limit-hint{color:var(--text-muted);font-size:14px;margin-bottom:8px}.voice-upgrade-btn{align-items:center;background:linear-gradient(135deg,#ffd93d,#ff9f43)!important;color:#1a1a2e!important;display:flex;gap:8px;justify-content:center}.voice-upgrade-btn:hover{box-shadow:0 4px 12px #ffd93d4d!important}.voice-initial-modal{max-width:340px}.voice-initial-modal .voice-food-body{align-items:center;display:flex;flex-direction:column}.landing-page{background:linear-gradient(180deg,#0a0a1a,#1a1a2e 50%,#16213e);color:#fff;min-height:100vh;overflow-x:hidden}.landing-header{left:0;padding:16px 24px;position:absolute;right:0;top:0;z-index:100}.landing-header-content{align-items:center;display:flex;justify-content:flex-end;margin:0 auto;max-width:1200px}.inapp-browser-tip{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom:1px solid #00d4aa4d;display:flex;gap:12px;justify-content:space-between;left:0;padding:12px 16px;position:fixed;right:0;top:0;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.tip-content{align-items:center;display:flex;flex:1 1;gap:10px}.tip-icon{flex-shrink:0;font-size:20px}.tip-content p{color:#e0e0e0;font-size:13px;line-height:1.4;margin:0}.tip-content strong{color:#00d4aa}.tip-close-btn{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#a0a0a0;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;transition:all .2s ease;width:28px}.tip-close-btn:hover{background:#fff3;color:#fff}.hero-section{margin:0 auto;max-width:600px;padding:60px 20px 40px;text-align:center}.landing-page:has(.inapp-browser-tip) .hero-section{padding-top:100px}.hero-content{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-logo-section{display:flex;justify-content:center;margin-bottom:24px}.hero-logo{border-radius:20px;box-shadow:0 8px 32px #00d4aa4d;height:80px;width:80px}.hero-title{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.title-main{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#00d4aa,#00f5c4 50%,#4ecdc4);-webkit-background-clip:text;background-clip:text;font-size:42px;font-weight:800;letter-spacing:-1px}.title-sub{color:#a0a0b0;font-size:18px;font-weight:500;letter-spacing:.5px}.hero-description{color:#b0b0c0;font-size:16px;line-height:1.7;margin-bottom:32px;padding:0 10px}.hero-benefits{display:flex;flex-wrap:wrap;gap:32px;justify-content:center;margin-bottom:40px}.benefit-item{align-items:center;display:flex;flex-direction:column;gap:4px}.benefit-number{color:#00d4aa;font-size:28px;font-weight:800}.benefit-label{color:#808090;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.hero-cta{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.btn-google-hero{align-items:center;background:#fff;border:none;border-radius:12px;box-shadow:0 4px 20px #ffffff1a;color:#1a1a2e;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;justify-content:center;padding:16px 24px;transition:all .3s ease;width:100%}.btn-google-hero:hover{box-shadow:0 6px 30px #fff3;transform:translateY(-2px)}.btn-google-hero:active{transform:translateY(0)}.btn-email-hero{background:#0000;border:2px solid #00d4aa;border-radius:12px;color:#00d4aa;cursor:pointer;font-size:16px;font-weight:600;padding:16px 24px;transition:all .3s ease;width:100%}.btn-email-hero:hover{background:#00d4aa1a;transform:translateY(-2px)}.hero-login-link{color:#808090;font-size:14px}.hero-login-link span{color:#00d4aa;cursor:pointer;font-weight:600;transition:color .2s ease}.hero-login-link span:hover{color:#00f5c4;text-decoration:underline}.features-section{background:linear-gradient(180deg,#0000,#00d4aa05);padding:60px 20px}.section-title{color:#fff;font-size:24px;font-weight:700;margin-bottom:40px;text-align:center}.features-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr;margin:0 auto;max-width:600px}@media (min-width:480px){.features-grid{grid-template-columns:repeat(2,1fr)}}.feature-card{background:#ffffff08;border:1px solid #ffffff0f;border-radius:16px;padding:24px 20px;transition:all .3s ease}.feature-card:hover{background:#ffffff0f;border-color:#ffffff1a;border-color:var(--feature-color,#ffffff1a);transform:translateY(-4px)}.feature-icon-wrapper{align-items:center;background:#ffffff0d;border-radius:14px;color:#00d4aa;color:var(--feature-color,#00d4aa);display:flex;height:56px;justify-content:center;margin-bottom:16px;width:56px}.ia-icon-text{color:inherit;font-size:24px;font-weight:900;letter-spacing:-1px}.feature-card .feature-title{color:#fff;font-size:17px;font-weight:700;margin-bottom:8px}.feature-card .feature-description{color:#909099;font-size:14px;line-height:1.5}.trust-section{background:#00d4aa08;padding:40px 20px}.trust-content{margin:0 auto;max-width:500px;text-align:center}.trust-badge{align-items:center;background:#00d4aa1a;border-radius:20px;color:#00d4aa;display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:16px;padding:8px 16px}.trust-text{color:#909099;font-size:14px;line-height:1.6}.final-cta-section{background:linear-gradient(180deg,#0000,#00d4aa0d);padding:60px 20px;text-align:center}.final-cta-section h2{color:#fff;font-size:28px;font-weight:700;margin-bottom:12px}.final-cta-section p{color:#909099;font-size:16px;margin-bottom:32px}.btn-final-cta{background:linear-gradient(135deg,#00d4aa,#00b896);border:none;border-radius:12px;box-shadow:0 4px 24px #00d4aa4d;color:#0a0a1a;cursor:pointer;font-size:18px;font-weight:700;padding:18px 48px;transition:all .3s ease}.btn-final-cta:hover{box-shadow:0 6px 32px #00d4aa66;transform:translateY(-2px)}.btn-final-cta:active{transform:translateY(0)}.landing-footer{border-top:1px solid #ffffff0d;padding:40px 20px;text-align:center}.footer-links{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:16px}.footer-link{color:#00d4aa;cursor:pointer;font-size:13px;transition:color .2s ease}.footer-link:hover{color:#00f5c4;text-decoration:underline}.footer-separator{color:#404050;font-size:10px}.landing-footer p{color:#606070;font-size:13px;margin-bottom:8px}.footer-support a{color:#00d4aa;text-decoration:none}.footer-support a:hover{text-decoration:underline}.footer-social{gap:20px;margin:20px 0}.footer-social,.social-link{align-items:center;display:flex;justify-content:center}.social-link{border-radius:50%;height:48px;transition:all .3s ease;width:48px}.social-link.whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}.social-link.whatsapp:hover{box-shadow:0 4px 20px #25d36666;transform:scale(1.1)}.social-link.instagram{background:linear-gradient(135deg,#833ab4,#fd1d1d 50%,#fcaf45);color:#fff}.social-link.instagram:hover{box-shadow:0 4px 20px #833ab466;transform:scale(1.1)}.forgot-success,.reset-invalid,.reset-loading,.reset-success{padding:40px 20px;text-align:center}.reset-loading .spinner{animation:spin .8s linear infinite;border:3px solid #00d4aa33;border-radius:50%;border-top-color:#00d4aa;height:40px;margin:0 auto 20px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.forgot-info p,.reset-loading p{color:#909099}.invalid-icon,.success-icon{margin-bottom:24px}.forgot-success h2,.reset-invalid h2,.reset-success h2{color:#fff;font-size:24px;font-weight:700;margin-bottom:12px}.forgot-success p,.reset-invalid p,.reset-success p{color:#909099;line-height:1.6;margin-bottom:24px}.reset-info{background:#00d4aa1a;border-radius:12px;margin-bottom:24px;padding:16px}.reset-info .body-small{color:#909099;margin-bottom:4px}.reset-email{color:#00d4aa;font-size:16px;font-weight:600}.forgot-info{margin-bottom:24px}.forgot-password-link{margin-top:16px;text-align:center}.forgot-password-link .btn-link{color:#00d4aa;font-size:14px}@media (max-width:380px){.title-main{font-size:36px}.hero-benefits{gap:20px}.benefit-number{font-size:24px}}.legal-page{background:linear-gradient(180deg,#0a0a1a,#1a1a2e 50%,#16213e);color:#fff;min-height:100vh;padding:20px;position:relative}.legal-language-selector{position:absolute;right:20px;top:20px;z-index:100}.legal-container{margin:0 auto;max-width:800px;padding-top:40px}.back-btn{align-items:center;background:#0000;border:none;color:#a0a0b0;cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:8px 0;transition:color .2s ease}.back-btn:hover{color:#00d4aa}.back-btn svg{transition:transform .2s ease}.back-btn:hover svg{transform:translateX(-4px)}.legal-header{border-bottom:1px solid #ffffff1a;margin-bottom:40px;padding-bottom:30px;text-align:center}.legal-logo{border-radius:14px;height:60px;margin-bottom:16px;width:60px}.legal-header h1{color:#fff;font-size:32px;font-weight:700;margin-bottom:8px}.legal-date{color:#808090;font-size:14px}.legal-content{line-height:1.7}.legal-content section{margin-bottom:32px}.legal-content h2{border-bottom:1px solid #00d4aa33;color:#00d4aa;font-size:22px;font-weight:700;margin-bottom:16px;padding-bottom:8px}.legal-content h3{color:#e0e0e0;font-size:17px;font-weight:600;margin:20px 0 12px}.legal-content p{color:#b0b0c0;font-size:15px;margin-bottom:12px}.legal-content ul{margin:12px 0;padding-left:24px}.legal-content li{color:#b0b0c0;font-size:15px;margin-bottom:8px}.legal-content li strong{color:#e0e0e0}.legal-content a{color:#00d4aa;text-decoration:none;transition:color .2s ease}.legal-content a:hover{color:#00f5c4;text-decoration:underline}.contact-info{background:#00d4aa0d;border:1px solid #00d4aa33;border-radius:12px;margin-top:16px;padding:20px}.contact-info p{margin-bottom:8px}.contact-info p:last-child{margin-bottom:0}.warning-box{background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:12px;margin:16px 0;padding:20px}.warning-box p:first-child{color:#ff6b6b;margin-bottom:12px}.warning-box ul{margin-bottom:12px}.legal-footer{border-top:1px solid #ffffff1a;margin-top:48px;padding-top:32px;text-align:center}.legal-footer .btn-primary{background:linear-gradient(135deg,#00d4aa,#00b896);border:none;border-radius:10px;color:#0a0a1a;cursor:pointer;font-size:16px;font-weight:600;padding:14px 32px;transition:all .3s ease}.legal-footer .btn-primary:hover{box-shadow:0 4px 20px #00d4aa4d;transform:translateY(-2px)}@media (max-width:600px){.legal-page{padding:16px}.legal-header h1{font-size:26px}.legal-content h2{font-size:19px}.legal-content li,.legal-content p{font-size:14px}}
/*# sourceMappingURL=main.e1fe1ef1.css.map*/