@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&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}.dark{--background:0 0% 3.9%;--foreground:0 0% 98%;--card:0 0% 3.9%;--card-foreground:0 0% 98%;--popover:0 0% 3.9%;--popover-foreground:0 0% 98%;--primary:0 0% 98%;--primary-foreground:0 0% 9%;--secondary:0 0% 14.9%;--secondary-foreground:0 0% 98%;--muted:0 0% 14.9%;--muted-foreground:0 0% 63.9%;--accent:0 0% 14.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:0 0% 14.9%;--input:0 0% 14.9%;--ring:0 0% 83.1%;--chart-1:220 70% 50%;--chart-2:160 60% 45%;--chart-3:30 80% 55%;--chart-4:280 65% 60%;--chart-5:340 75% 55%}*{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}.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}.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))}.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;margin:0}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}:root{--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--bg-glass:#ffffffb3;--bg-glass-strong:#ffffffd9;--primary-indigo:#4f46e5;--primary-violet:#7c3aed;--primary-gradient:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);--primary-glow:#4f46e540;--success:#10b981;--success-light:#10b9811a;--warning:#f59e0b;--warning-light:#f59e0b1a;--risk:#ef4444;--risk-light:#ef44441a;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-white:#fff;--border-light:#fff6;--border-subtle:#0000000f;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 30px #0000001a;--shadow-glow:0 8px 32px #4f46e540;--blur-sm:8px;--blur-md:16px;--blur-lg:24px;--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;background:var(--bg-primary);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.2}.app-container{background:linear-gradient(180deg,#eef2ff,#f8fafc 30%,#fff);display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;position:relative}.main-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding-bottom:120px}.glass-card{backdrop-filter:blur(24px);backdrop-filter:blur(var(--blur-lg));-webkit-backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(var(--blur-lg));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);transition:all .3s ease}.glass-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.glass-card-strong{border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md)}.bottom-nav,.glass-card-strong{backdrop-filter:blur(24px);backdrop-filter:blur(var(--blur-lg));-webkit-backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(var(--blur-lg));background:#ffffffd9;background:var(--bg-glass-strong)}.bottom-nav{border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);bottom:20px;box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);justify-content:space-around;left:50%;max-width:400px;padding:12px 24px;position:fixed;transform:translateX(-50%);width:calc(100% - 40px);z-index:100}.bottom-nav,.nav-item{align-items:center;display:flex}.nav-item{background:none;border:none;border-radius:16px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);cursor:pointer;flex-direction:column;gap:4px;padding:8px 14px;transition:all .3s ease}.nav-item:hover{color:#475569;color:var(--text-secondary)}.nav-item.active{color:#4f46e5;color:var(--primary-indigo)}.nav-item span{font-size:11px;font-weight:600;letter-spacing:.02em}.scan-nav-wrapper{margin-top:-32px;position:relative}.scan-nav-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:4px solid #fff;border-radius:50%;box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;cursor:pointer;display:flex;height:64px;justify-content:center;transition:all .3s ease;width:64px}.scan-nav-btn:hover{box-shadow:0 12px 40px #4f46e559;transform:scale(1.08)}.scan-nav-btn:active{transform:scale(.95)}.home-view{margin:0 auto;max-width:480px;padding:24px 20px}.greeting-header{margin-bottom:24px}.greeting-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.greeting-text{color:#475569;color:var(--text-secondary);font-size:15px;font-weight:500}.greeting-name{color:#0f172a;color:var(--text-primary);font-size:28px;font-weight:800}.header-actions{display:flex;gap:10px}.icon-btn{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s ease;width:44px}.icon-btn:hover{background:#ffffffd9;background:var(--bg-glass-strong);color:#4f46e5;color:var(--primary-indigo);transform:translateY(-2px)}.health-score-hero{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);margin-bottom:20px;overflow:hidden;padding:28px 24px;position:relative}.health-score-hero:before{background:#ffffff1a;border-radius:50%;content:"";height:200px;position:absolute;right:-30%;top:-50%;width:200px}.health-score-hero:after{background:#ffffff14;border-radius:50%;bottom:-30%;content:"";height:150px;left:-20%;position:absolute;width:150px}.health-score-content{align-items:center;display:flex;gap:24px;position:relative;z-index:1}.health-ring-container{flex-shrink:0;height:120px;position:relative;width:120px}.health-ring-svg{height:100%;transform:rotate(-90deg);width:100%}.health-ring-bg{fill:none;stroke:#fff3;stroke-width:10}.health-ring-progress{fill:none;stroke:#fff;stroke-width:10;stroke-linecap:round;filter:drop-shadow(0 0 8px rgba(255,255,255,.5));transition:stroke-dashoffset 1s ease-out}.health-ring-center{color:#fff;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.health-score-number{font-family:Plus Jakarta Sans,sans-serif;font-size:36px;font-weight:800;line-height:1}.health-score-label{font-size:12px;font-weight:600;letter-spacing:.05em;opacity:.9;text-transform:uppercase}.health-score-info{color:#fff;flex:1 1}.health-status-badge{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:13px;font-weight:600;gap:6px;margin-bottom:12px;padding:6px 14px}.health-status-badge.excellent{background:#10b9814d}.health-status-badge.good{background:#f59e0b4d}.health-status-badge.attention{background:#ef44444d}.health-insight-text{font-size:14px;font-weight:500;line-height:1.5;opacity:.95}.quick-metrics{display:flex;gap:8px;margin-top:20px}.quick-metric{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border-radius:16px;border-radius:var(--radius-md);display:flex;flex:1 1;gap:8px;padding:10px 12px}.quick-metric-icon{font-size:16px}.quick-metric-text{color:#fff;font-size:12px;font-weight:600}.scan-cta-section{margin-bottom:20px}.scan-cta-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:20px 24px;position:relative;transition:all .3s ease;width:100%}.scan-cta-btn:before{background:linear-gradient(135deg,#ffffff26,#fff0 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.scan-cta-btn:hover{box-shadow:0 12px 40px #4f46e559;transform:translateY(-3px)}.scan-cta-btn:active{transform:translateY(0)}.scan-cta-icon{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:24px;border-radius:var(--radius-lg);color:#fff;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.scan-cta-content{color:#fff;flex:1 1;position:relative;text-align:left;z-index:1}.scan-cta-title{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700;margin-bottom:4px}.scan-cta-subtitle{font-size:13px;font-weight:500;opacity:.9}.scan-cta-arrow{color:#fff;opacity:.8}.section-title{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:18px;font-weight:700;gap:8px;margin-bottom:14px}.section-title svg{color:#4f46e5;color:var(--primary-indigo)}.actions-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.action-card{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:14px;padding:16px;transition:all .3s ease}.action-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);transform:translateX(4px)}.action-icon{align-items:center;border-radius:16px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.action-icon.water{background:#10b9811a;background:var(--success-light);color:#10b981;color:var(--success)}.action-icon.protein{background:#4f46e51a;color:#4f46e5;color:var(--primary-indigo)}.action-icon.walk{background:#f59e0b1a;background:var(--warning-light);color:#f59e0b;color:var(--warning)}.action-icon.sugar{background:#ef44441a;background:var(--risk-light);color:#ef4444;color:var(--risk)}.action-text{color:#0f172a;color:var(--text-primary);flex:1 1;font-size:14px;font-weight:600}.action-check{align-items:center;border:2px solid #0000000f;border:2px solid var(--border-subtle);border-radius:9999px;border-radius:var(--radius-full);color:#0000;display:flex;height:28px;justify-content:center;transition:all .3s ease;width:28px}.action-card:hover .action-check{border-color:#4f46e5;border-color:var(--primary-indigo);color:#4f46e5;color:var(--primary-indigo)}.bento-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.bento-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;padding:18px;transition:all .3s ease}.bento-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);transform:translateY(-2px)}.bento-icon{align-items:center;border-radius:16px;border-radius:var(--radius-md);display:flex;height:40px;justify-content:center;margin-bottom:12px;width:40px}.bento-icon.water{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.bento-icon.fire{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff}.bento-icon.badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.bento-icon.streak{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.bento-value{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:24px;font-weight:800;margin-bottom:4px}.bento-label{color:#94a3b8;color:var(--text-muted);font-size:13px;font-weight:500}.bento-progress{background:#f1f5f9;background:var(--bg-secondary);height:6px;margin-top:12px;overflow:hidden}.bento-progress,.bento-progress-fill{border-radius:9999px;border-radius:var(--radius-full)}.bento-progress-fill{height:100%;transition:width .5s ease}.insights-section{margin-bottom:24px}.insight-card{align-items:flex-start;background:linear-gradient(135deg,#4f46e50d,#7c3aed0d);border:1px solid #4f46e51a;border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:14px;margin-bottom:10px;padding:16px}.insight-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:16px;border-radius:var(--radius-md);color:#fff;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.insight-content{flex:1 1}.insight-text{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:500;line-height:1.5}.insight-meta{color:#94a3b8;color:var(--text-muted);font-size:12px;margin-top:6px}.notification{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);font-size:14px;font-weight:600;left:50%;padding:14px 24px;position:fixed;top:20px;transform:translateX(-50%);z-index:1000}.notification.success{background:#10b981;background:var(--success);color:#fff}.notification.error{background:#ef4444;background:var(--risk);color:#fff}.badge-notification{align-items:center;animation:badgePop .5s cubic-bezier(.175,.885,.32,1.275);background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 20px 60px #f59e0b66;color:#fff;display:flex;flex-direction:column;gap:14px;left:50%;padding:32px 40px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:1001}@keyframes badgePop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.badge-notification span{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700}.page-header{align-items:center;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(var(--blur-lg));backdrop-filter:blur(var(--blur-lg));background:#ffffffd9;background:var(--bg-glass-strong);border-bottom:1px solid #fff6;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.page-header.transparent{background:#0000;border-bottom:none;position:absolute;width:100%}.page-header h1{font-size:18px;font-weight:700}.back-btn{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s ease;width:44px}.back-btn:hover{background:#ffffffd9;background:var(--bg-glass-strong);color:#0f172a;color:var(--text-primary)}.back-btn.light{background:#fff3;border-color:#ffffff4d;color:#fff}.scan-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.mode-toggle{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);display:flex;gap:8px;margin:0 20px 20px;padding:6px}.mode-btn{align-items:center;background:#0000;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .3s ease}.mode-btn.active{background:#fff;box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);color:#4f46e5;color:var(--primary-indigo)}.capture-area{aspect-ratio:4/3;background:#f1f5f9;background:var(--bg-secondary);border-radius:32px;border-radius:var(--radius-xl);margin:0 20px 20px;overflow:hidden;position:relative}.camera-container{height:100%;position:relative;width:100%}.webcam-view{height:100%;object-fit:cover;width:100%}.camera-overlay{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;pointer-events:none;position:absolute}.scan-frame{aspect-ratio:1;position:relative;width:80%}.corner{border:3px solid #fff;height:24px;position:absolute;width:24px}.corner.tl{border-radius:4px 0 0 0;border-right:none;left:0}.corner.tl,.corner.tr{border-bottom:none;top:0}.corner.tr{border-left:none;border-radius:0 4px 0 0;right:0}.corner.bl{border-radius:0 0 0 4px;border-right:none;left:0}.corner.bl,.corner.br{border-top:none;bottom:0}.corner.br{border-left:none;border-radius:0 0 4px 0;right:0}.scan-hint{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border-radius:9999px;border-radius:var(--radius-full);bottom:20px;color:#fff;font-size:13px;font-weight:600;left:50%;padding:10px 20px;position:absolute;transform:translateX(-50%)}.camera-error{color:#94a3b8;color:var(--text-muted);gap:16px;padding:20px;text-align:center}.camera-error,.upload-area{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center}.upload-area{background:#ffffffb3;background:var(--bg-glass);border:2px dashed #0000000f;border:2px dashed var(--border-subtle);border-radius:32px;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease;width:100%}.upload-area:hover{background:#4f46e50d;border-color:#4f46e5;border-color:var(--primary-indigo)}.upload-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:24px;border-radius:var(--radius-lg);color:#fff;display:flex;height:72px;justify-content:center;margin-bottom:16px;width:72px}.upload-title{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:4px}.upload-hint{color:#94a3b8;color:var(--text-muted);font-size:13px}.preview-container{height:100%;position:relative;width:100%}.preview-image{height:100%;object-fit:cover;width:100%}.analyzing-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;color:#fff;display:flex;flex-direction:column;gap:16px;inset:0;justify-content:center;position:absolute}.analyzing-spinner{animation:spin 1s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#fff;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.analyzing-overlay p{font-size:16px;font-weight:600}.analyzing-overlay span{font-size:13px;opacity:.8}.action-buttons{display:flex;gap:12px;margin-bottom:20px;padding:0 20px}.btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;cursor:pointer;flex:1 1;font-size:15px;font-weight:700;padding:16px 24px;transition:all .3s ease}.btn-primary:hover{box-shadow:0 12px 40px #4f46e559;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#ffffffd9;background:var(--bg-glass-strong);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#0f172a;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:16px 24px;transition:all .3s ease}.btn-secondary:hover{background:#fff;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.capture-btn{background:#fff;border:4px solid #4f46e5;border:4px solid var(--primary-indigo);border-radius:50%;cursor:pointer;display:block;height:72px;margin:0 auto;padding:4px;transition:all .3s ease;width:72px}.capture-btn:hover{transform:scale(1.05)}.capture-btn-inner{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:50%;height:100%;width:100%}.scan-tips{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:13px;gap:10px;justify-content:center;padding:16px 20px;text-align:center}.scan-tips svg{color:#4f46e5;color:var(--primary-indigo);flex-shrink:0}.result-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.result-hero{height:280px;overflow:hidden;position:relative}.result-hero img{height:100%;object-fit:cover;width:100%}.result-hero-overlay{background:linear-gradient(0deg,#000c 0,#0000 50%);color:#fff;display:flex;flex-direction:column;inset:0;justify-content:flex-end;padding:24px 20px;position:absolute}.result-hero-overlay h2{font-size:24px;font-weight:800;margin-bottom:4px}.result-hero-overlay p{font-size:14px;opacity:.9}.result-content{margin-top:-24px;padding:20px;position:relative;z-index:1}.calorie-result-card{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;margin-bottom:20px;padding:24px}.calorie-result-main{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:8px}.calorie-big{font-family:Plus Jakarta Sans,sans-serif;font-size:48px;font-weight:800}.calorie-kcal{font-size:18px;font-weight:600;opacity:.9}.calorie-result-percent{font-size:14px;opacity:.9;text-align:center}.streak-result{align-items:center;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 16px #f59e0b4d;color:#fff;display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:20px;padding:10px 18px}.result-section{margin-bottom:24px}.result-section h3{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:14px}.nutrition-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.nutrition-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);padding:16px 12px;text-align:center;transition:all .3s ease}.nutrition-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);transform:translateY(-2px)}.nutrition-card-icon{margin-bottom:8px}.nutrition-card-value{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:20px;font-weight:700}.nutrition-card-label{color:#94a3b8;color:var(--text-muted);font-size:12px;font-weight:500}.ingredients-wrap{display:flex;flex-wrap:wrap;gap:8px}.ingredient-chip{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#475569;color:var(--text-secondary);font-size:13px;font-weight:500;padding:8px 16px}.tips-list{gap:10px}.tip-card{align-items:flex-start;background:#10b9811a;background:var(--success-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;padding:14px 16px}.tip-card.alt{background:#4f46e514}.tip-icon{color:#10b981;color:var(--success);flex-shrink:0;margin-top:2px}.tip-card.alt .tip-icon{color:#4f46e5;color:var(--primary-indigo)}.tip-card span{color:#0f172a;color:var(--text-primary);font-size:14px;line-height:1.5}.result-actions{display:flex;gap:12px;margin-top:24px}.history-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.history-content{padding:20px}.empty-state{flex-direction:column;padding:60px 20px;text-align:center}.empty-icon,.empty-state{align-items:center;display:flex;justify-content:center}.empty-icon{background:#ffffffb3;background:var(--bg-glass);border-radius:32px;border-radius:var(--radius-xl);color:#94a3b8;color:var(--text-muted);height:80px;margin-bottom:20px;width:80px}.empty-state h3{color:#0f172a;color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:8px}.empty-state p{color:#94a3b8;color:var(--text-muted);font-size:14px}.history-day{margin-bottom:24px}.history-date{color:#94a3b8;color:var(--text-muted);font-size:14px;font-weight:600;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.history-list{display:flex;flex-direction:column;gap:10px}.history-card{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:14px;padding:14px;transition:all .3s ease}.history-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);transform:translateX(4px)}.history-img{border-radius:16px;border-radius:var(--radius-md);height:56px;object-fit:cover;width:56px}.history-info{flex:1 1}.history-info h4{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:2px}.history-info p{color:#94a3b8;color:var(--text-muted);font-size:13px}.history-cal{text-align:right}.cal-value{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700}.cal-unit{color:#94a3b8;color:var(--text-muted);font-size:12px;margin-left:2px}.water-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.water-content{padding:20px}.water-visual{display:flex;justify-content:center;margin-bottom:32px}.water-glass{background:#ffffffb3;background:var(--bg-glass);border:2px solid #06b6d44d;border-radius:20px 20px 40px 40px;box-shadow:0 8px 32px #06b6d426;height:220px;overflow:hidden;position:relative;width:160px}.water-fill{background:linear-gradient(0deg,#06b6d4 0,#22d3ee);border-radius:0 0 38px 38px;bottom:0;left:0;position:absolute;right:0;transition:height .5s ease}.water-label{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute;z-index:1}.water-label svg{color:#06b6d4;margin-bottom:8px}.water-amount{font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800}.water-goal{color:#94a3b8;color:var(--text-muted);font-size:13px}.water-buttons{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.water-buttons h3{font-size:16px;font-weight:700;margin-bottom:14px;text-align:center}.water-btn-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.water-btn{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:24px;border-radius:var(--radius-lg);box-shadow:0 4px 16px #06b6d44d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:16px;transition:all .3s ease}.water-btn:hover{box-shadow:0 8px 24px #06b6d466;transform:translateY(-2px)}.water-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.exercise-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.exercise-content{padding:20px}.exercise-stat-hero{align-items:center;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #f973164d;color:#fff;display:flex;flex-direction:column;margin-bottom:24px;padding:32px}.exercise-stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:48px;font-weight:800;margin:8px 0}.exercise-stat-label{font-size:14px;opacity:.9}.add-exercise-btn{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:2px dashed #0000000f;border:2px dashed var(--border-subtle);border-radius:24px;border-radius:var(--radius-lg);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;margin-bottom:24px;padding:18px;transition:all .3s ease;width:100%}.add-exercise-btn:hover{background:#4f46e50d;border-color:#4f46e5;border-color:var(--primary-indigo);color:#4f46e5;color:var(--primary-indigo)}.exercise-form{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:24px;padding:20px}.form-group{margin-bottom:16px}.form-group label{color:#475569;color:var(--text-secondary);display:block;font-size:13px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{background:#fff;border:1px solid #0000000f;border:1px solid var(--border-subtle);border-radius:16px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-primary);font-size:15px;padding:14px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#4f46e5;border-color:var(--primary-indigo);box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-actions{display:flex;gap:12px;margin-top:20px}.exercise-list h3{font-size:16px;font-weight:700;margin-bottom:14px}.no-data{color:#94a3b8;color:var(--text-muted);padding:24px;text-align:center}.exercise-card{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:14px;margin-bottom:10px;padding:14px}.exercise-card-icon{align-items:center;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:16px;border-radius:var(--radius-md);color:#fff;display:flex;height:44px;justify-content:center;width:44px}.exercise-card-info{flex:1 1}.exercise-card-info h4{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600}.exercise-card-info p{color:#94a3b8;color:var(--text-muted);font-size:13px}.exercise-card-cal{color:#f97316;font-family:Plus Jakarta Sans,sans-serif;font-size:16px;font-weight:700}.badges-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.badges-content{padding:20px}.badges-hero{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;display:flex;flex-direction:column;margin-bottom:24px;padding:32px}.badges-hero svg{margin-bottom:12px}.badges-hero h2{font-size:32px;font-weight:800}.badges-hero p{font-size:14px;opacity:.9}.badges-section{margin-bottom:24px}.badges-section h3{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:14px}.badges-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.badge-card{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);padding:20px 16px;text-align:center;transition:all .3s ease}.badge-card.earned{background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border-color:#f59e0b4d}.badge-card.locked{opacity:.5}.badge-icon{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);display:flex;height:48px;justify-content:center;margin:0 auto 12px;width:48px}.badge-card.earned .badge-icon{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.badge-card h4{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:700;margin-bottom:4px}.badge-card p{color:#94a3b8;color:var(--text-muted);font-size:12px}.profile-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.profile-stats-row{background:#ffffffb3;background:var(--bg-glass);border-bottom:1px solid #fff6;border-bottom:1px solid var(--border-light);display:flex;gap:32px;justify-content:center;padding:24px 20px}.profile-stat{align-items:center;display:flex;flex-direction:column;gap:6px}.profile-stat svg{color:#4f46e5;color:var(--primary-indigo)}.stat-num{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:24px;font-weight:800}.stat-lbl{color:#94a3b8;color:var(--text-muted);font-size:12px;font-weight:500}.profile-form{padding:20px}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.intake-card{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);margin-bottom:20px;margin-top:20px;padding:20px}.intake-card h3{font-size:16px;font-weight:700;margin-bottom:14px;text-align:center}.intake-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.intake-item{text-align:center}.intake-val{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700}.intake-lbl{display:block;font-size:11px}.intake-lbl,.intake-note{color:#94a3b8;color:var(--text-muted)}.intake-note{font-size:12px;margin-top:12px;text-align:center}.btn-primary.full{width:100%}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.auth-modal,.paywall-modal,.qr-modal{background:#fff;border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);max-width:400px;padding:32px 24px;position:relative;width:100%}.modal-close{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border:none;border-radius:16px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .3s ease;width:40px}.modal-close:hover{background:#f8fafc;background:var(--bg-primary)}.auth-header h2,.modal-close:hover{color:#0f172a;color:var(--text-primary)}.auth-header h2{font-weight:800}.auth-error{align-items:center;background:#ef44441a;background:var(--risk-light);border-radius:16px;border-radius:var(--radius-md);color:#ef4444;color:var(--risk);display:flex;font-size:14px;gap:10px;padding:12px 16px}.auth-error,.auth-form{margin-bottom:16px}.auth-toggle{color:#94a3b8;color:var(--text-muted);font-size:14px;text-align:center}.auth-toggle button{background:none;border:none;color:#4f46e5;color:var(--primary-indigo);cursor:pointer;font-weight:600}.auth-toggle button:hover{text-decoration:underline}.paywall-content{text-align:center}.paywall-icon{align-items:center;background:linear-gradient(135deg,#ec4899,#db2777);border-radius:32px;border-radius:var(--radius-xl);color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.paywall-content h2{font-size:22px;font-weight:800;margin-bottom:12px}.paywall-content p{color:#94a3b8;color:var(--text-muted);font-size:14px;margin-bottom:20px}.support-btn{align-items:center;background:linear-gradient(135deg,#ec4899,#db2777);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 8px 24px #ec48994d;color:#fff;display:inline-flex;font-size:15px;font-weight:700;gap:10px;justify-content:center;margin-bottom:16px;padding:16px 32px;text-decoration:none;transition:all .3s ease}.support-btn:hover{box-shadow:0 12px 32px #ec489966;transform:translateY(-2px)}.paywall-note{color:#94a3b8;color:var(--text-muted);font-size:13px}.qr-content{text-align:center}.qr-content svg:first-child{color:#4f46e5;color:var(--primary-indigo);margin-bottom:12px}.qr-content h2{font-size:22px;font-weight:800;margin-bottom:8px}.qr-content>p{color:#94a3b8;color:var(--text-muted);font-size:14px;margin-bottom:20px}.qr-code-wrap{background:#fff;border-radius:24px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);display:inline-block;margin-bottom:16px;padding:20px}.qr-url{color:#94a3b8;color:var(--text-muted);font-size:12px;word-break:break-all}.email-subscribe-card{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;margin-top:20px;padding:24px}.email-subscribe-card.success{align-items:center;background:#10b981;background:var(--success);box-shadow:0 8px 24px #10b9814d;display:flex;gap:14px}.subscribe-header{align-items:center;display:flex;gap:14px;margin-bottom:18px}.subscribe-header h4{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700;margin-bottom:4px}.subscribe-header p{font-size:13px;opacity:.9}.subscribe-form{display:flex;gap:10px}.subscribe-form input{background:#fffffff2;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#0f172a;color:var(--text-primary);flex:1 1;font-size:14px;padding:14px 18px}.subscribe-form input::placeholder{color:#94a3b8;color:var(--text-muted)}.subscribe-form button{align-items:center;background:#fff;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--primary-indigo);cursor:pointer;display:flex;font-weight:600;justify-content:center;padding:14px 18px;transition:all .3s ease}.subscribe-form button:hover{transform:scale(1.05)}.subscribe-error{color:#fecaca;font-size:13px;margin-top:12px}.text-center{text-align:center}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}@media (max-width:380px){.health-score-content{flex-direction:column;text-align:center}.quick-metrics{flex-wrap:wrap}.quick-metric{flex:1 1 45%}.bento-grid{grid-template-columns:1fr}}.onboarding-container{background:linear-gradient(180deg,#eef2ff,#f8fafc 30%,#fff);display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;overflow:hidden;padding:24px;position:relative}.onboarding-container:before{background:radial-gradient(circle,#4f46e526 0,#0000 70%);border-radius:50%;content:"";height:400px;position:absolute;right:-200px;top:-200px;width:400px}.onboarding-container:after{background:radial-gradient(circle,#7c3aed1a 0,#0000 70%);border-radius:50%;bottom:-150px;content:"";height:300px;left:-150px;position:absolute;width:300px}.onboarding-progress{display:flex;gap:10px;justify-content:center;margin-bottom:32px;position:relative;z-index:1}.progress-dot{background:#0000000f;background:var(--border-subtle);border-radius:50%;height:10px;transition:all .3s ease;width:10px}.progress-dot.active{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 2px 8px #4f46e540;box-shadow:0 2px 8px var(--primary-glow);width:28px}.onboarding-step{display:flex;flex:1 1;flex-direction:column;position:relative;z-index:1}.onboarding-header{margin-bottom:32px;text-align:center}.onboarding-logo{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;display:flex;height:72px;justify-content:center;margin:0 auto 20px;width:72px}.onboarding-header h1{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800;letter-spacing:-.02em;margin-bottom:10px}.onboarding-header p{color:#475569;color:var(--text-secondary);font-size:15px;line-height:1.5}.onboarding-content{flex:1 1}.onboarding-form-group{margin-bottom:24px}.onboarding-form-group label{color:#475569;color:var(--text-secondary);display:block;font-size:14px;font-weight:600;margin-bottom:10px}.onboarding-input{background:#ffffffd9;background:var(--bg-glass-strong);border:2px solid #0000;border-radius:24px;border-radius:var(--radius-lg);color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:600;padding:18px 20px;text-align:center;transition:all .3s ease;width:100%}.onboarding-input:focus{border-color:#4f46e5;border-color:var(--primary-indigo);box-shadow:0 0 0 4px #4f46e540;box-shadow:0 0 0 4px var(--primary-glow);outline:none}.onboarding-input::placeholder{color:#94a3b8;color:var(--text-muted);font-weight:500}.onboarding-features{display:flex;flex-direction:column;gap:14px;margin-top:24px}.feature-item{align-items:center;background:#ffffffb3;background:var(--bg-glass);border-radius:24px;border-radius:var(--radius-lg);color:#0f172a;color:var(--text-primary);display:flex;font-size:14px;font-weight:500;gap:14px;padding:16px}.feature-item svg{color:#4f46e5;color:var(--primary-indigo);flex-shrink:0}.goal-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.goal-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:2px solid #0000;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;padding:20px 16px;position:relative;text-align:center;transition:all .3s ease}.goal-card:hover{background:#ffffffd9;background:var(--bg-glass-strong);transform:translateY(-2px)}.goal-card.selected{background:#4f46e514;border-color:#4f46e5;border-color:var(--primary-indigo)}.goal-icon{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);display:flex;height:48px;justify-content:center;margin:0 auto 12px;transition:all .3s ease;width:48px}.goal-card.selected .goal-icon{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);color:#fff}.goal-card h4{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:700;margin-bottom:4px}.goal-card p{color:#94a3b8;color:var(--text-muted);font-size:12px;line-height:1.3}.goal-check{align-items:center;background:#10b981;background:var(--success);border-radius:50%;color:#fff;display:flex;height:24px;justify-content:center;position:absolute;right:10px;top:10px;width:24px}.preference-list{display:flex;flex-direction:column;gap:10px}.preference-card{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:2px solid #0000;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;justify-content:space-between;padding:18px 20px;text-align:left;transition:all .3s ease}.preference-card:hover{background:#ffffffd9;background:var(--bg-glass-strong)}.preference-card.selected{background:#4f46e514;border-color:#4f46e5;border-color:var(--primary-indigo)}.preference-info h4{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:2px}.preference-info p{font-size:13px}.preference-check,.preference-info p{color:#94a3b8;color:var(--text-muted)}.preference-check{transition:all .3s ease}.preference-card.selected .preference-check{color:#4f46e5;color:var(--primary-indigo)}.age-section{background:#ffffffb3;background:var(--bg-glass);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:24px;padding:20px;text-align:center}.age-section label{color:#475569;color:var(--text-secondary);display:block;font-size:14px;font-weight:600;margin-bottom:16px}.age-input-wrapper{align-items:center;display:flex;gap:24px;justify-content:center}.age-btn{background:#f1f5f9;background:var(--bg-secondary);border:none;border-radius:16px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-primary);cursor:pointer;font-size:24px;font-weight:600;height:48px;transition:all .2s ease;width:48px}.age-btn:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);color:#fff}.age-value{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:40px;font-weight:800;min-width:80px}.activity-list{display:flex;flex-direction:column;gap:10px}.activity-card{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:2px solid #0000;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;justify-content:space-between;padding:16px 18px;text-align:left;transition:all .3s ease}.activity-card:hover{background:#ffffffd9;background:var(--bg-glass-strong)}.activity-card.selected{background:#4f46e514;border-color:#4f46e5;border-color:var(--primary-indigo)}.activity-info h4{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:2px}.activity-info p{color:#94a3b8;color:var(--text-muted);font-size:12px}.activity-check{color:#4f46e5;color:var(--primary-indigo)}.onboarding-nav{display:flex;gap:12px;padding-top:24px;position:relative;z-index:1}.onboarding-btn{align-items:center;border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:700;gap:8px;justify-content:center;padding:18px 24px;transition:all .3s ease}.onboarding-btn.primary{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff}.onboarding-btn.primary:hover:not(:disabled){box-shadow:0 12px 40px #4f46e559;transform:translateY(-2px)}.onboarding-btn.primary:disabled{cursor:not-allowed;opacity:.5}.onboarding-btn.secondary{background:#ffffffd9;background:var(--bg-glass-strong);border:1px solid #fff6;border:1px solid var(--border-light);color:#0f172a;color:var(--text-primary)}.onboarding-btn.secondary:hover{background:#fff}.onboarding-btn.text{background:#0000;border:none;color:#94a3b8;color:var(--text-muted);font-weight:500}.onboarding-btn.text:hover{color:#475569;color:var(--text-secondary)}.progress-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.progress-content{padding:20px}.period-selector{background:#ffffffb3;background:var(--bg-glass);border-radius:9999px;border-radius:var(--radius-full);display:flex;gap:8px;margin-bottom:20px;padding:6px}.period-btn{background:#0000;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px;transition:all .3s ease}.period-btn.active{background:#fff;box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);color:#4f46e5;color:var(--primary-indigo)}.progress-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.progress-stat-card{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;padding:16px}.progress-stat-card .stat-icon{align-items:center;border-radius:16px;border-radius:var(--radius-md);color:#fff;display:flex;height:40px;justify-content:center;width:40px}.stat-icon.calories{background:linear-gradient(135deg,#f97316,#ea580c)}.stat-icon.meals{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.stat-icon.streak{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-icon.best{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:20px}.stat-label{font-weight:500}.chart-section{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:24px;padding:20px}.chart-section h3{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:16px;font-weight:700;gap:8px;margin-bottom:20px}.chart-section h3 svg{color:#4f46e5;color:var(--primary-indigo)}.bar-chart{align-items:flex-end;display:flex;gap:8px;height:160px;justify-content:space-between}.bar-column{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:6px}.bar-wrapper{align-items:flex-end;background:#f1f5f9;background:var(--bg-secondary);display:flex;height:120px;overflow:hidden}.bar,.bar-wrapper{border-radius:16px;border-radius:var(--radius-md);width:100%}.bar{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);min-height:4px}.bar-label{color:#475569;color:var(--text-secondary);font-size:12px;font-weight:600}.bar-value{color:#94a3b8;color:var(--text-muted);font-size:10px}.breakdown-section{margin-bottom:24px}.breakdown-section h3{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:16px;font-weight:700;gap:8px;margin-bottom:14px}.breakdown-section h3 svg{color:#4f46e5;color:var(--primary-indigo)}.breakdown-list{display:flex;flex-direction:column;gap:10px}.breakdown-card{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:14px 16px}.breakdown-date{display:flex;flex-direction:column}.day-name{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600}.date-str{color:#94a3b8;color:var(--text-muted);font-size:12px}.breakdown-stats{display:flex;gap:16px}.breakdown-stat{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:12px;gap:4px}.breakdown-stat svg{color:#94a3b8;color:var(--text-muted)}.reminders-card{align-items:center;background:linear-gradient(135deg,#4f46e514,#7c3aed14);border:1px solid #4f46e526;border-radius:32px;border-radius:var(--radius-xl);display:flex;justify-content:space-between;padding:18px 20px}.reminders-header{align-items:center;display:flex;gap:14px}.reminders-header svg{color:#4f46e5;color:var(--primary-indigo)}.reminders-header h4{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:2px}.reminders-header p{color:#94a3b8;color:var(--text-muted);font-size:13px}.reminder-toggle{background:#ffffffd9;background:var(--bg-glass-strong);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#475569;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:10px 20px;transition:all .3s ease}.reminder-toggle.enabled{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-color:#0000;color:#fff}.reminder-toggle:hover:not(.enabled){background:#fff;color:#4f46e5;color:var(--primary-indigo)}.icon-btn.active{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-color:#0000;color:#fff}.dark-mode{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-glass:#1e293bb3;--bg-glass-strong:#1e293be6;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--border-light:#ffffff1a;--border-subtle:#ffffff0d}.dark-mode .app-container{background:linear-gradient(180deg,#0f172a,#1e293b 50%,#0f172a)}.dark-mode .health-score-hero{box-shadow:0 8px 32px #4f46e54d}.dark-mode .bottom-nav{background:#1e293bf2;border-color:#ffffff1a}.dark-mode .scan-nav-btn{border-color:#f1f5f9;border-color:var(--bg-secondary)}.dark-mode .mode-btn.active,.dark-mode .period-btn.active,.dark-mode input,.dark-mode select{background:#f1f5f9;background:var(--bg-secondary)}.dark-mode input,.dark-mode select{border-color:#fff6;border-color:var(--border-light);color:#0f172a;color:var(--text-primary)}.dark-mode .subscribe-form input{background:#ffffffe6;color:#0f172a;color:var(--text-primary)}.barcode-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.barcode-content{padding:20px}.barcode-input-section{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);margin-bottom:24px;padding:32px 20px;text-align:center}.barcode-icon-wrap,.barcode-input-section{border-radius:32px;border-radius:var(--radius-xl)}.barcode-icon-wrap{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;display:flex;height:72px;justify-content:center;margin:0 auto 20px;width:72px}.barcode-input-section h2{font-size:22px;font-weight:800;margin-bottom:8px}.barcode-input-section>p{color:#94a3b8;color:var(--text-muted);font-size:14px;margin-bottom:24px}.barcode-input-wrapper{display:flex;gap:10px;margin:0 auto;max-width:320px}.barcode-input-wrapper input{border:2px solid #0000000f;border:2px solid var(--border-subtle);border-radius:24px;border-radius:var(--radius-lg);flex:1 1;font-size:16px;font-weight:600;letter-spacing:.1em;padding:16px;text-align:center}.barcode-input-wrapper input:focus{border-color:#4f46e5;border-color:var(--primary-indigo);outline:none}.lookup-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:16px 24px;transition:all .3s ease}.lookup-btn:hover{box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);transform:translateY(-2px)}.lookup-btn:disabled{cursor:not-allowed;opacity:.6}.barcode-error{align-items:center;background:#ef44441a;background:var(--risk-light);border-radius:16px;border-radius:var(--radius-md);color:#ef4444;color:var(--risk);display:flex;font-size:14px;gap:8px;justify-content:center;margin-top:16px;padding:12px}.product-result{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.product-header{display:flex;gap:16px;margin-bottom:16px}.product-image{background:#fff;border-radius:16px;border-radius:var(--radius-md);height:80px;object-fit:contain;width:80px}.product-info{flex:1 1}.product-info h3{color:#0f172a;color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:4px}.product-brand{color:#475569;color:var(--text-secondary);font-size:14px;margin-bottom:4px}.product-serving{color:#94a3b8;color:var(--text-muted);font-size:12px}.nutriscore{border-radius:9999px;border-radius:var(--radius-full);display:inline-block;font-size:12px;font-weight:700;margin-bottom:16px;padding:6px 14px}.nutriscore-a{background:#038141;color:#fff}.nutriscore-b{background:#85bb2f;color:#fff}.nutriscore-c{background:#fecb02;color:#333}.nutriscore-d{background:#ee8100;color:#fff}.nutriscore-e{background:#e63e11;color:#fff}.nutrition-quick-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.nutrition-quick-item{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;padding:12px 8px}.nutrition-quick-item svg{color:#4f46e5;color:var(--primary-indigo)}.nq-value{color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:16px;font-weight:700}.nq-label{color:#94a3b8;color:var(--text-muted);font-size:10px;text-transform:uppercase}.servings-selector{background:#f1f5f9;background:var(--bg-secondary);border-radius:24px;border-radius:var(--radius-lg);margin-bottom:20px;padding:16px;text-align:center}.servings-selector label{color:#94a3b8;color:var(--text-muted);display:block;font-size:13px;margin-bottom:10px}.servings-controls{align-items:center;display:flex;gap:20px;justify-content:center}.servings-controls button{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-md);cursor:pointer;font-size:20px;font-weight:600;height:40px;transition:all .2s ease;width:40px}.servings-controls button:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-color:#0000;color:#fff}.servings-controls span{font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800;min-width:50px}.servings-total{color:#4f46e5;color:var(--primary-indigo);font-size:14px;font-weight:600;margin-top:10px}.full-width{width:100%}.data-source{color:#94a3b8;color:var(--text-muted);font-size:12px;margin-top:12px;text-align:center}.sample-barcodes{padding:20px;text-align:center}.sample-barcodes>p{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-bottom:12px}.sample-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.sample-list button{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#475569;color:var(--text-secondary);cursor:pointer;font-family:monospace;font-size:12px;padding:8px 16px;transition:all .2s ease}.sample-list button:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-color:#0000;color:#fff}.barcode-cta-btn{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin-top:12px;padding:14px 20px;transition:all .3s ease;width:100%}.barcode-cta-btn:hover{background:#ffffffd9;background:var(--bg-glass-strong);transform:translateX(4px)}.barcode-cta-btn svg:first-child,.barcode-cta-btn:hover{color:#4f46e5;color:var(--primary-indigo)}.camera-scanner-section{aspect-ratio:4/3;background:#000;border-radius:32px;border-radius:var(--radius-xl);margin-bottom:20px;overflow:hidden;position:relative}.scanner-viewport{height:100%;width:100%}.scanner-viewport video{height:100%;object-fit:cover;width:100%}.scanner-overlay{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;pointer-events:none;position:absolute}.scanner-line{animation:scanLine 2s ease-in-out infinite;background:#4f46e5;background:var(--primary-indigo);box-shadow:0 0 20px #4f46e5;box-shadow:0 0 20px var(--primary-indigo);height:2px;width:80%}@keyframes scanLine{0%,to{transform:translateY(-60px)}50%{transform:translateY(60px)}}.scanner-overlay p{color:#fff;font-size:14px;font-weight:600;margin-top:20px;text-shadow:0 2px 4px #00000080}.voice-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.voice-content{padding:20px}.voice-hero{flex-direction:column;padding:40px 20px}.voice-btn,.voice-hero{align-items:center;display:flex}.voice-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:50%;box-shadow:0 8px 32px #4f46e540;box-shadow:var(--shadow-glow);color:#fff;cursor:pointer;height:100px;justify-content:center;margin-bottom:16px;transition:all .3s ease;width:100px}.voice-btn:hover{transform:scale(1.05)}.voice-btn.listening{animation:pulse 1.5s ease-in-out infinite;background:linear-gradient(135deg,#ef4444,#dc2626)}.voice-hero p{color:#475569;color:var(--text-secondary);font-size:16px;font-weight:600}.voice-input-section{margin:24px 0}.voice-input-section label{color:#475569;color:var(--text-secondary);display:block;font-size:14px;font-weight:600;margin-bottom:10px}.voice-input-section textarea{border:2px solid #0000000f;border:2px solid var(--border-subtle);border-radius:24px;border-radius:var(--radius-lg);font-family:inherit;font-size:16px;padding:16px;resize:none;width:100%}.voice-input-section textarea:focus{border-color:#4f46e5;border-color:var(--primary-indigo);outline:none}.voice-result-card{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:20px;padding:24px;text-align:center}.voice-result-card h3{font-size:20px;font-weight:700;margin-bottom:16px}.voice-nutrition{display:flex;gap:24px;justify-content:center;margin-bottom:16px}.voice-nutrition div{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:14px;font-weight:600;gap:6px}.voice-nutrition svg{color:#4f46e5;color:var(--primary-indigo)}.voice-tip{color:#94a3b8;color:var(--text-muted);font-size:14px;font-style:italic}.voice-cta-btn{align-items:center;background:linear-gradient(135deg,#10b9811a,#06b6d41a);border:1px solid #10b98133;border-radius:9999px;border-radius:var(--radius-full);color:#10b981;color:var(--success);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin-top:10px;padding:14px 20px;transition:all .3s ease;width:100%}.voice-cta-btn:hover{background:#10b98126;transform:translateX(4px)}.mealplan-view{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.mealplan-content{padding:20px}.loading-state{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.loading-state p{color:#475569;color:var(--text-secondary);font-size:16px}.mealplan-header-card{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:32px;border-radius:var(--radius-xl);color:#fff;display:flex;gap:14px;margin-bottom:20px;padding:20px}.mealplan-header-card svg{flex-shrink:0}.mealplan-header-card h3{font-size:18px;font-weight:700}.mealplan-header-card p{font-size:13px;opacity:.9}.total-cal{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700;margin-left:auto}.meal-card{background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);margin-bottom:12px;padding:16px;position:relative}.meal-time{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:inline-block;font-size:11px;font-weight:700;margin-bottom:10px;padding:4px 12px;text-transform:uppercase}.meal-card h4{font-size:16px;font-weight:700;margin-bottom:6px}.meal-card p{color:#94a3b8;color:var(--text-muted);font-size:14px;margin-bottom:8px}.meal-cal{color:#4f46e5;color:var(--primary-indigo);font-size:13px;font-weight:600}.mealplan-tips{background:#4f46e514;border-radius:24px;border-radius:var(--radius-lg);margin-top:20px;padding:16px}.mealplan-tips h4{color:#4f46e5;color:var(--primary-indigo);font-size:14px;font-weight:700;margin-bottom:10px}.mealplan-tips p{color:#475569;color:var(--text-secondary);font-size:13px;margin-bottom:6px}.viral-section{margin-bottom:var(--spacing-lg);padding:0 var(--spacing-md)}.viral-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.viral-card{align-items:center;background:#ffffffb3;background:var(--bg-glass);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:6px;justify-content:center;padding:14px 8px;transition:all .2s ease}.viral-card:hover{box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.viral-card svg{color:#4f46e5;color:var(--primary-indigo)}.viral-card span{color:#475569;color:var(--text-secondary);font-size:11px;font-weight:600;text-align:center}.viral-card.coach{background:linear-gradient(135deg,#a855f71a,#8b5cf60d)}.viral-card.coach svg{color:#a855f7}.viral-card.challenges{background:linear-gradient(135deg,#f59e0b1a,#fbbf240d)}.viral-card.challenges svg{color:#f59e0b}.viral-card.leaderboard{background:linear-gradient(135deg,#10b9811a,#34d3990d)}.viral-card.leaderboard svg{color:#10b981}.viral-card.mealplan{background:linear-gradient(135deg,#4f46e51a,#6366f10d)}.viral-card.mealplan svg{color:#4f46e5}.referral-banner{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;justify-content:space-between;margin:0 var(--spacing-md) var(--spacing-lg);padding:14px 16px;transition:transform .2s ease}.referral-banner:hover{transform:scale(1.01)}.referral-content{align-items:center;color:#fff;display:flex;gap:12px}.referral-content svg{flex-shrink:0}.referral-title{display:block;font-size:14px;font-weight:700}.referral-subtitle{display:block;font-size:12px;opacity:.85}.referral-banner>svg{color:#fff;opacity:.8}.coach-view{background:#f1f5f9;background:var(--bg-secondary);display:flex;flex-direction:column;min-height:100vh}.coach-view .page-header{background:#f8fafc;background:var(--bg-primary)}.coach-avatar{align-items:center;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:50%;color:#fff;display:flex;height:36px;justify-content:center;width:36px}.coach-content{display:flex;flex:1 1;flex-direction:column;padding:var(--spacing-md);padding-bottom:100px}.coach-messages{flex:1 1;overflow-y:auto;padding-bottom:var(--spacing-lg)}.coach-message{display:flex;gap:10px;margin-bottom:16px;max-width:85%}.coach-message.user{flex-direction:row-reverse;margin-left:auto}.coach-icon{align-items:center;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.message-bubble{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:12px 16px}.coach-message.coach .message-bubble{border-radius:4px 32px 32px 32px;border-radius:4px var(--radius-xl) var(--radius-xl) var(--radius-xl)}.coach-message.user .message-bubble{background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:32px 4px 32px 32px;border-radius:var(--radius-xl) 4px var(--radius-xl) var(--radius-xl);color:#fff}.message-bubble p{font-size:14px;line-height:1.5;margin:0}.message-bubble.typing{display:flex;gap:4px;padding:16px}.message-bubble.typing span{animation:typing 1.4s infinite both;background:#4f46e5;background:var(--primary-indigo);border-radius:50%;height:8px;width:8px}.message-bubble.typing span:nth-child(2){animation-delay:.2s}.message-bubble.typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.quick-questions{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.quick-questions p{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-bottom:10px}.quick-btns{display:flex;flex-wrap:wrap;gap:8px}.quick-btns button{background:#4f46e514;border:1px solid #4f46e533;border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--primary-indigo);cursor:pointer;font-size:13px;padding:8px 14px;transition:all .2s ease}.quick-btns button:hover{background:#4f46e526}.coach-input-area{background:#f8fafc;background:var(--bg-primary);border-top:1px solid #fff6;border-top:1px solid var(--border-light);bottom:0;display:flex;gap:10px;left:0;padding:var(--spacing-md);position:fixed;right:0}.coach-input-area input{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);flex:1 1;font-size:15px;outline:none;padding:14px 18px;transition:border-color .2s ease}.coach-input-area input:focus{border-color:#4f46e5;border-color:var(--primary-indigo)}.send-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;transition:transform .2s ease,opacity .2s ease;width:48px}.send-btn:hover:not(:disabled){transform:scale(1.05)}.send-btn:disabled{cursor:not-allowed;opacity:.5}.challenges-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.challenges-content{padding:var(--spacing-md);padding-bottom:100px}.challenge-notification{background:#10b981;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);color:#fff;gap:8px;left:50%;padding:12px 20px;position:fixed;top:80px;transform:translateX(-50%);z-index:100}.challenges-intro{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.challenges-intro svg{color:#4f46e5;color:var(--primary-indigo);margin-bottom:12px}.challenges-intro h2{font-size:22px;font-weight:800;margin-bottom:8px}.challenges-intro p{color:#94a3b8;color:var(--text-muted);font-size:14px}.challenges-list{gap:16px}.challenge-card{padding:20px;transition:transform .2s ease,box-shadow .2s ease}.challenge-card:hover{box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.challenge-header{justify-content:space-between;margin-bottom:12px}.challenge-badge{border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.challenge-participants{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.challenge-card h3{font-size:18px;font-weight:700;margin-bottom:6px}.challenge-desc{color:#475569;color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:16px}.challenge-rewards{background:#4f46e50d;border-radius:24px;border-radius:var(--radius-lg);gap:16px;margin-bottom:16px;padding:12px}.reward{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:13px;gap:6px}.reward svg{color:#4f46e5;color:var(--primary-indigo)}.challenge-footer{align-items:center;display:flex;justify-content:space-between}.challenge-duration{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:13px;gap:4px}.join-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:9999px;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:transform .2s ease,opacity .2s ease}.join-btn:hover:not(:disabled){transform:scale(1.02)}.join-btn:disabled{cursor:not-allowed;opacity:.7}.leaderboard-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.leaderboard-content{padding:var(--spacing-md);padding-bottom:100px}.period-toggle{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);display:flex;margin-bottom:var(--spacing-lg);padding:4px}.period-toggle button{background:none;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.period-toggle button.active{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);color:#fff}.leaderboard-hero{background:linear-gradient(135deg,#4f46e51a,#8b5cf60d);border:1px solid #4f46e51a;border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.leaderboard-hero svg{color:#4f46e5;color:var(--primary-indigo);margin-bottom:12px}.leaderboard-hero h2{font-size:22px;font-weight:800;margin-bottom:8px}.leaderboard-hero p{color:#94a3b8;color:var(--text-muted);font-size:14px}.leaders-list{display:flex;flex-direction:column;gap:12px}.leader-card{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:14px;padding:16px;transition:transform .2s ease}.leader-card:hover{transform:translateX(4px)}.leader-card.top-three{background:linear-gradient(135deg,#4f46e50d,#8b5cf605);border:2px solid #4f46e54d}.leader-rank{font-size:20px;font-weight:700;text-align:center;width:40px}.leader-info{flex:1 1}.leader-info h4{font-size:15px;font-weight:700;margin-bottom:4px}.leader-stats{display:flex;gap:12px}.leader-stats span{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.leader-stats svg{color:#4f46e5;color:var(--primary-indigo)}.leader-score{text-align:right}.score-value{color:#4f46e5;color:var(--primary-indigo);display:block;font-size:20px;font-weight:800}.score-label{color:#94a3b8;color:var(--text-muted);font-size:11px}.referral-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.referral-content{padding:var(--spacing-md);padding-bottom:100px}.referral-notification{align-items:center;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);display:flex;font-size:14px;font-weight:600;gap:8px;left:50%;padding:12px 20px;position:fixed;top:80px;transform:translateX(-50%);z-index:100}.referral-notification.success{background:#10b981;color:#fff}.referral-notification.error{background:#ef4444;color:#fff}.referral-hero{padding:var(--spacing-xl);text-align:center}.referral-gift-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto 16px;width:64px}.referral-hero h2{font-size:26px;font-weight:800;margin-bottom:8px}.referral-hero p{font-size:15px;opacity:.9}.referral-code-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg);padding:24px;text-align:center}.referral-code-section h3{color:#94a3b8;color:var(--text-muted);font-size:14px;font-weight:600;margin-bottom:16px}.referral-code-loading{padding:24px}.referral-code-card{align-items:center;background:#4f46e514;border:2px dashed #4f46e54d;border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;justify-content:center;margin-bottom:16px;padding:16px 24px}.referral-code{color:#4f46e5;color:var(--primary-indigo);font-family:Plus Jakarta Sans,monospace;font-size:24px;font-weight:800;letter-spacing:2px}.copy-btn{border:none;border-radius:16px;border-radius:var(--radius-md);font-size:13px;padding:8px 16px}.copy-btn,.share-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);color:#fff;cursor:pointer;font-weight:600}.share-btn{align-items:center;border:none;border-radius:24px;border-radius:var(--radius-lg);display:flex;font-size:15px;gap:8px;justify-content:center;padding:14px;transition:transform .2s ease;width:100%}.share-btn:hover{transform:scale(1.01)}.referral-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:var(--spacing-lg)}.referral-stats .stat-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);padding:20px;text-align:center}.referral-stats .stat-card svg{color:#4f46e5;color:var(--primary-indigo);margin-bottom:8px}.stat-value{color:#0f172a;color:var(--text-primary);display:block;font-size:28px;font-weight:800;margin-bottom:4px}.apply-code-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg);padding:24px}.apply-code-section h3{font-size:16px;font-weight:700;margin-bottom:16px}.apply-code-form{display:flex;gap:10px}.apply-code-form input{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);flex:1 1;font-size:14px;letter-spacing:1px;padding:14px 16px;text-transform:uppercase}.apply-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:14px 24px}.apply-btn:disabled{cursor:not-allowed;opacity:.5}.already-referred{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-top:12px}.how-it-works{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:24px}.how-it-works h3{font-size:16px;font-weight:700;margin-bottom:20px}.steps{flex-direction:column}.step,.steps{display:flex;gap:16px}.step,.step-number{align-items:center}.step-number{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.step p{color:#475569;color:var(--text-secondary);font-size:14px}.dark-mode .coach-message.user .message-bubble{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.dark-mode .viral-card{background:#ffffffb3;background:var(--bg-glass)}.dark-mode .viral-card.coach{background:#a855f726}.dark-mode .viral-card.challenges{background:#f59e0b26}.dark-mode .viral-card.leaderboard{background:#10b98126}.dark-mode .viral-card.mealplan{background:#4f46e526}.dark-mode .referral-code{color:#a78bfa}.dark-mode .referral-code-card{background:#8b5cf626;border-color:#8b5cf64d}.dark-mode .challenge-rewards{background:#8b5cf61a}.dark-mode .leaderboard-hero{background:linear-gradient(135deg,#6366f126,#8b5cf61a);border-color:#6366f133}.dark-mode .leader-card.top-three{background:linear-gradient(135deg,#6366f11a,#8b5cf60d);border-color:#8b5cf666}.dark-mode .quick-btns button{background:#8b5cf626;border-color:#8b5cf64d;color:#a78bfa}.subscription-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.subscription-content{padding:var(--spacing-md);padding-bottom:100px}.subscription-status{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin:var(--spacing-md);padding:14px}.subscription-status.checking{background:#4f46e51a;color:#4f46e5;color:var(--primary-indigo)}.subscription-status.success{background:#10b9811a;color:#10b981}.subscription-status.error{background:#ef44441a;color:#ef4444}.subscription-hero{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:32px;border-radius:var(--radius-xl);color:#fff;margin-bottom:var(--spacing-lg);padding:var(--spacing-xl);text-align:center}.subscription-hero svg{color:#ffffffe6;margin-bottom:12px}.subscription-hero h2{font-size:24px;font-weight:800;margin-bottom:8px}.subscription-hero p{font-size:15px;opacity:.9}.plans-list{display:flex;flex-direction:column;gap:16px}.plan-card{background:#f8fafc;background:var(--bg-primary);border:2px solid #fff6;border:2px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:24px;position:relative;transition:all .2s ease}.plan-card:hover{box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.plan-card.popular{border-color:#4f46e5;border-color:var(--primary-indigo)}.plan-card.current{background:#10b98108;border-color:#10b981}.popular-badge{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);left:50%;padding:4px 16px;transform:translateX(-50%)}.current-badge,.popular-badge{border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-size:11px;font-weight:700;position:absolute;text-transform:uppercase;top:-12px}.current-badge{background:#10b981;padding:4px 12px;right:20px}.plan-header{margin-bottom:20px}.plan-header h3{font-size:20px;font-weight:700;margin-bottom:8px}.plan-price{align-items:baseline;display:flex;gap:4px}.price-free{color:#10b981;font-size:28px;font-weight:800}.price-amount{color:#0f172a;color:var(--text-primary);font-size:32px;font-weight:800}.price-period{color:#94a3b8;color:var(--text-muted);font-size:14px}.plan-features{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.feature{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:14px;gap:10px}.feature svg{color:#10b981;flex-shrink:0}.subscribe-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px;transition:transform .2s ease,opacity .2s ease;width:100%}.subscribe-btn:hover:not(:disabled){transform:scale(1.01)}.subscribe-btn:disabled{cursor:not-allowed;opacity:.6}.subscription-footer{margin-top:var(--spacing-lg);text-align:center}.subscription-footer p{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-bottom:12px}.coffee-link{align-items:center;color:#4f46e5;color:var(--primary-indigo);display:inline-flex;font-size:13px;gap:6px;text-decoration:none}.coffee-link:hover{text-decoration:underline}.share-card-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.share-card-content{padding:var(--spacing-md);padding-bottom:100px}.card-preview{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.achievement-canvas{border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 8px 30px #0000001a;box-shadow:var(--shadow-lg);height:auto;max-width:300px;width:100%}.share-actions{display:flex;gap:12px}.share-action-btn{align-items:center;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex:1 1;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px;transition:transform .2s ease}.share-action-btn:hover{transform:scale(1.02)}.share-action-btn.primary{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;color:#fff}.share-action-btn.secondary{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);color:#0f172a;color:var(--text-primary)}.share-tips{margin-top:var(--spacing-lg);text-align:center}.share-tips p{color:#94a3b8;color:var(--text-muted);font-size:14px}.menu-scanner-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.menu-scanner-content{padding:var(--spacing-md);padding-bottom:100px}.menu-intro{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-md);padding:var(--spacing-lg);text-align:center}.menu-intro svg{color:#4f46e5;color:var(--primary-indigo);margin-bottom:12px}.menu-intro h2{font-size:22px;font-weight:800;margin-bottom:8px}.menu-intro p{color:#94a3b8;color:var(--text-muted);font-size:14px}.menu-result{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:var(--spacing-md)}.menu-result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.menu-result-header h2{font-size:20px;font-weight:700}.btn-secondary.small{font-size:12px;padding:8px 14px}.menu-section{border-radius:24px;border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.menu-section.healthy{background:#10b98114}.menu-section.avoid{background:#ef444414}.menu-section h3{align-items:center;display:flex;font-size:14px;font-weight:700;gap:8px;margin-bottom:12px}.menu-section.healthy h3{color:#10b981}.menu-section.avoid h3{color:#ef4444}.picks-list{display:flex;flex-wrap:wrap;gap:8px}.pick-chip{border-radius:9999px;border-radius:var(--radius-full);font-size:13px;padding:6px 12px}.pick-chip.healthy{background:#10b981;color:#fff}.pick-chip.avoid{background:#ef4444;color:#fff}.menu-items-list{margin-top:var(--spacing-md)}.menu-items-list h3{font-size:16px;font-weight:700;margin-bottom:12px}.menu-item-card{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);margin-bottom:12px;padding:16px}.menu-item-card.healthy-choice{background:#10b98108;border-color:#10b9814d}.menu-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.menu-item-header h4{font-size:15px;font-weight:700}.health-rating{border-radius:9999px;border-radius:var(--radius-full);font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.health-rating.good{background:#10b981;color:#fff}.health-rating.moderate{background:#f59e0b;color:#fff}.health-rating.indulgent{background:#ef4444;color:#fff}.menu-item-nutrition{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.menu-item-nutrition span{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.menu-item-notes{color:#475569;color:var(--text-secondary);font-size:13px;font-style:italic;margin-top:8px}.healthier-badge{align-items:center;background:#10b9811a;border-radius:9999px;border-radius:var(--radius-full);color:#10b981;display:inline-flex;font-size:11px;font-weight:600;gap:4px;margin-top:8px;padding:4px 10px}.menu-tips{background:#4f46e50d;border-radius:24px;border-radius:var(--radius-lg);margin-top:var(--spacing-md);padding:var(--spacing-md)}.menu-tips h3{color:#4f46e5;color:var(--primary-indigo);font-size:14px;font-weight:700;margin-bottom:8px}.menu-tips p{color:#475569;color:var(--text-secondary);font-size:13px;margin-bottom:4px}.btn-primary.full-width{margin-top:var(--spacing-md);width:100%}.quick-actions-section{margin-bottom:var(--spacing-md);padding:0 var(--spacing-md)}.quick-actions-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.quick-action-btn{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s ease}.quick-action-btn:hover{box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.quick-action-btn.menu-scanner{background:linear-gradient(135deg,#ec489914,#f43f5e0d);border-color:#ec489933;color:#ec4899}.quick-action-btn.menu-scanner svg{color:#ec4899}.quick-action-btn.share-card{background:linear-gradient(135deg,#3b82f614,#6366f10d);border-color:#3b82f633;color:#3b82f6}.quick-action-btn.share-card svg{color:#3b82f6}.usage-badge.clickable{cursor:pointer;transition:all .2s ease}.usage-badge.clickable:hover{background:#4f46e51f}.usage-badge .upgrade-icon{color:#f59e0b;margin-left:auto}.paywall-content .upgrade-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;width:100%}.paywall-content .upgrade-btn,.paywall-divider{align-items:center;display:flex;margin-bottom:16px}.paywall-divider{gap:12px}.paywall-divider:after,.paywall-divider:before{background:#fff6;background:var(--border-light);content:"";flex:1 1;height:1px}.paywall-divider span{color:#94a3b8;color:var(--text-muted);font-size:12px;text-transform:uppercase}.paywall-content .support-btn{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);color:#0f172a;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;text-decoration:none;transition:all .2s ease;width:100%}.dark-mode .plan-card,.paywall-content .support-btn:hover{background:#f8fafc;background:var(--bg-primary)}.dark-mode .plan-card.popular{border-color:#8b5cf6}.dark-mode .menu-item-card{background:#ffffff08}.dark-mode .quick-action-btn{background:#f8fafc;background:var(--bg-primary)}.dark-mode .quick-action-btn.menu-scanner{background:#ec48991f}.dark-mode .quick-action-btn.share-card{background:#3b82f61f}.auth-modal{background:#f8fafc;background:var(--bg-primary);border-radius:32px;border-radius:var(--radius-xl);max-width:420px;padding:32px;position:relative;width:90%}.auth-header{margin-bottom:24px;text-align:center}.auth-icon-wrap{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:50%;color:#fff;display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.auth-header h2{font-size:24px;font-weight:700;margin-bottom:8px}.auth-header p{color:#94a3b8;color:var(--text-muted);font-size:14px;line-height:1.5}.auth-message{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;font-size:14px;gap:8px;margin-bottom:16px;padding:12px 16px}.auth-message.error{background:#ef44441a;color:#ef4444}.auth-message.success{background:#10b9811a;color:#10b981}.auth-form{gap:16px}.auth-form,.auth-form .form-group{display:flex;flex-direction:column}.auth-form .form-group{gap:8px}.auth-form label{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:13px;font-weight:600;gap:6px}.auth-form input{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);font-size:15px;padding:14px 16px;transition:all .2s ease}.auth-form input:focus{border-color:#4f46e5;border-color:var(--primary-indigo);box-shadow:0 0 0 3px #4f46e51a;outline:none}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:48px;width:100%}.password-toggle{background:none;border:none;color:#94a3b8;color:var(--text-muted);cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.password-toggle:hover{color:#0f172a;color:var(--text-primary)}.forgot-password-btn{align-self:flex-end;background:none;border:none;color:#4f46e5;color:var(--primary-indigo);cursor:pointer;font-size:13px;margin-top:-8px}.forgot-password-btn:hover{text-decoration:underline}.auth-submit{font-size:16px;margin-top:8px;padding:14px 24px}.btn-loading{align-items:center;display:flex;gap:8px;justify-content:center}.auth-switch{margin-top:20px;text-align:center}.auth-switch p{color:#94a3b8;color:var(--text-muted);font-size:14px}.auth-switch button{background:none;border:none;color:#4f46e5;color:var(--primary-indigo);cursor:pointer;font-weight:600}.auth-switch button:hover{text-decoration:underline}.auth-terms{border-top:1px solid #fff6;border-top:1px solid var(--border-light);margin-top:16px;padding-top:16px;text-align:center}.auth-terms p{color:#94a3b8;color:var(--text-muted);font-size:12px}.auth-terms a{color:#4f46e5;color:var(--primary-indigo);text-decoration:none}.auth-terms a:hover{text-decoration:underline}.dark-mode .auth-modal{background:#f8fafc;background:var(--bg-primary)}.dark-mode .auth-form input{background:#ffffff0d;border-color:#ffffff1a}.dark-mode .auth-form input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626}.share-modal{background:#f8fafc;background:var(--bg-primary);border-radius:32px;border-radius:var(--radius-xl);max-width:420px;padding:32px;position:relative;width:90%}.share-header{margin-bottom:24px;text-align:center}.share-icon-wrap{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:50%;color:#fff;display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.share-header h2{font-size:22px;font-weight:700;margin-bottom:8px}.share-header p{color:#94a3b8;color:var(--text-muted);font-size:14px}.share-code-box{align-items:center;background:#4f46e514;border:2px dashed #4f46e54d;border-radius:24px;border-radius:var(--radius-lg);display:flex;flex-direction:column;margin-bottom:20px;padding:16px}.share-code-label{color:#94a3b8;color:var(--text-muted);font-size:12px;margin-bottom:4px}.share-code{color:#4f46e5;color:var(--primary-indigo);font-size:24px;font-weight:800;letter-spacing:2px}.share-platforms{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.share-platform-btn{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;padding:14px 16px;position:relative;transition:all .2s ease}.share-platform-btn:hover{background:rgba(var(--platform-color),.05);border-color:var(--platform-color)}.share-platform-btn svg:first-child{color:var(--platform-color)}.share-platform-btn.shared{background:#10b9810d;border-color:#10b981}.share-platform-btn .check-icon{color:#10b981;position:absolute;right:12px}.share-divider{align-items:center;display:flex;gap:12px;margin-bottom:16px}.share-divider:after,.share-divider:before{background:#fff6;background:var(--border-light);content:"";flex:1 1;height:1px}.share-divider span{color:#94a3b8;color:var(--text-muted);font-size:12px}.share-actions-row{display:flex;gap:12px}.share-action{align-items:center;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .2s ease}.share-action.copy{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light)}.share-action.native{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;color:#fff}.share-footer{border-top:1px solid #fff6;border-top:1px solid var(--border-light);margin-top:20px;padding-top:20px;text-align:center}.share-footer p{color:#475569;color:var(--text-secondary);font-size:14px}.community-challenges-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.community-content{padding:var(--spacing-md);padding-bottom:100px}.community-hero{background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:32px;border-radius:var(--radius-xl);color:#fff;margin-bottom:var(--spacing-lg);padding:var(--spacing-xl);text-align:center}.community-hero svg{margin-bottom:12px}.community-hero h2{font-size:24px;font-weight:800;margin-bottom:8px}.community-hero p{font-size:14px;margin-bottom:12px;opacity:.9}.community-stats{display:flex;justify-content:center}.community-stats .stat{align-items:center;display:flex;font-size:14px;gap:6px;opacity:.9}.community-tabs{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);display:flex;margin-bottom:var(--spacing-lg);padding:4px}.community-tabs button{background:none;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.community-tabs button.active{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);color:#fff}.challenges-grid{display:flex;flex-direction:column;gap:16px}.community-challenge-card{align-items:flex-start;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);display:flex;gap:16px;padding:20px}.challenge-icon-wrap{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.challenge-info h3{font-size:16px;font-weight:700;margin-bottom:4px}.challenge-info p{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-bottom:12px}.challenge-meta{display:flex;gap:16px;margin-bottom:8px}.challenge-meta span{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.challenge-rewards{display:flex;gap:12px}.reward-badge{background:#8b5cf61a;color:#8b5cf6}.reward-badge,.reward-scans{border-radius:16px;border-radius:var(--radius-md);font-size:12px;padding:4px 8px}.reward-scans{background:#10b9811a;color:#10b981}.join-challenge-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:10px 16px;white-space:nowrap}.progress-list{display:flex;flex-direction:column;gap:12px}.progress-card{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:16px;padding:16px}.progress-card.completed{background:#10b98108;border-color:#10b9814d}.progress-icon{align-items:center;background:#4f46e51a;border-radius:16px;border-radius:var(--radius-md);color:#4f46e5;color:var(--primary-indigo);display:flex;height:40px;justify-content:center;width:40px}.progress-info{flex:1 1}.progress-info h4{font-size:14px;font-weight:700;margin-bottom:8px}.progress-bar-wrap{background:#f1f5f9;background:var(--bg-secondary);border-radius:9999px;border-radius:var(--radius-full);height:8px;margin-bottom:4px;overflow:hidden}.progress-bar-fill{transition:width .3s ease}.completed-badge{align-items:center;background:#10b981;border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;font-size:12px;font-weight:600;gap:4px;padding:6px 12px}.referral-tiers-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.referral-tiers-content{padding:var(--spacing-md);padding-bottom:100px}.referral-status-card{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:32px;border-radius:var(--radius-xl);color:#fff;display:flex;gap:16px;margin-bottom:var(--spacing-lg);padding:24px}.status-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;height:56px;justify-content:center;width:56px}.status-info{flex:1 1}.status-info h2{font-size:32px;font-weight:800;line-height:1}.status-info p{font-size:14px;opacity:.9}.status-bonus{text-align:right}.bonus-value{display:block;font-size:24px;font-weight:800}.bonus-label{font-size:12px;opacity:.8}.tier-progress-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-md);padding:20px}.tier-progress-card .progress-header{display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:8px}.tier-progress-card .progress-bar{background:#f1f5f9;background:var(--bg-secondary);border-radius:9999px;border-radius:var(--radius-full);height:10px;margin-bottom:8px;overflow:hidden}.tier-progress-card .progress-fill{border-radius:9999px;border-radius:var(--radius-full);height:100%;transition:width .5s ease}.tier-progress-card .progress-text{color:#94a3b8;color:var(--text-muted);font-size:13px}.share-invite-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-bottom:var(--spacing-lg);padding:16px;width:100%}.how-it-works-section h3,.tiers-section h3{font-size:16px;font-weight:700;margin-bottom:16px}.tiers-list{display:flex;flex-direction:column;gap:12px;margin-bottom:var(--spacing-lg)}.tier-card{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:14px;opacity:.6;padding:16px;position:relative}.tier-card.unlocked{opacity:1}.tier-card.current{border:2px solid #4f46e5;border:2px solid var(--primary-indigo)}.tier-icon{align-items:center;border-radius:50%;display:flex;height:40px;justify-content:center;width:40px}.tier-info{flex:1 1}.tier-info h4{font-size:15px;font-weight:700}.tier-info p{color:#94a3b8;color:var(--text-muted);font-size:12px}.tier-reward{text-align:right}.tier-reward .reward-value{color:#10b981;display:block;font-size:18px;font-weight:800}.tier-reward .reward-label{color:#94a3b8;color:var(--text-muted);font-size:11px}.unlocked-badge{align-items:center;background:#10b981;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;position:absolute;right:-6px;top:-6px;width:24px}.how-it-works-section .steps{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.how-it-works-section .step{align-items:flex-start;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;padding:16px}.how-it-works-section .step-num{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}.how-it-works-section .step p{color:#475569;color:var(--text-secondary);font-size:13px;line-height:1.4}.landing-page{background:#f8fafc;background:var(--bg-primary);min-height:100vh}.landing-hero{align-items:center;background:linear-gradient(180deg,#4f46e50d,#0000);display:flex;flex-direction:column;padding:60px 20px 40px;text-align:center}.hero-content{max-width:600px}.hero-badge{align-items:center;background:#4f46e51a;border:1px solid #4f46e533;border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--primary-indigo);display:inline-flex;font-size:13px;font-weight:600;gap:6px;margin-bottom:24px;padding:8px 16px}.landing-hero h1{font-size:36px;font-weight:800;line-height:1.2;margin-bottom:16px}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#475569;color:var(--text-secondary);font-size:18px;line-height:1.6;margin-bottom:24px}.hero-stats{display:flex;gap:32px;justify-content:center;margin-bottom:32px}.hero-stats .stat{text-align:center}.stat-number{color:#4f46e5;color:var(--primary-indigo);display:block;font-size:24px;font-weight:800}.stat-label{color:#94a3b8;color:var(--text-muted);font-size:12px}.hero-cta{flex-direction:column;gap:12px}.cta-primary,.hero-cta{align-items:center;display:flex}.cta-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:9999px;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-size:16px;font-weight:700;gap:8px;padding:16px 32px;transition:transform .2s ease,box-shadow .2s ease}.cta-primary:hover{box-shadow:0 10px 30px #4f46e54d;transform:translateY(-2px)}.cta-primary.large{font-size:18px;padding:18px 40px}.cta-note{color:#94a3b8;color:var(--text-muted);font-size:13px}.hero-visual{margin-top:40px}.phone-mockup{background:#1a1a2e;border-radius:32px;box-shadow:0 20px 60px #0000004d;height:480px;padding:8px;width:240px}.phone-screen{align-items:center;background:linear-gradient(180deg,#0f0f1a,#1a1a2e);border-radius:24px;display:flex;flex-direction:column;height:100%;padding:20px}.mock-header{color:#fff;font-size:18px;font-weight:700;margin-bottom:24px}.mock-score{margin-bottom:24px;text-align:center}.mock-score .score-value{color:#10b981;display:block;font-size:64px;font-weight:800}.mock-score .score-label{color:#fff9;font-size:14px}.mock-stats{display:flex;gap:24px}.mock-stat{color:#fff;text-align:center}.mock-stat span{display:block;font-size:20px;font-weight:700}.mock-stat small{font-size:12px;opacity:.6}.landing-features{padding:60px 20px;text-align:center}.landing-features h2{font-size:28px;font-weight:800;margin-bottom:40px}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:800px}.feature-card{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:24px;text-align:center}.feature-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:24px;border-radius:var(--radius-lg);color:#fff;display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.feature-card h3{font-size:16px;font-weight:700;margin-bottom:8px}.feature-card p{color:#94a3b8;color:var(--text-muted);font-size:14px}.landing-social-proof{background:#f1f5f9;background:var(--bg-secondary);padding:60px 20px;text-align:center}.landing-social-proof h2{font-size:28px;font-weight:800;margin-bottom:40px}.proof-stats{display:flex;gap:40px;justify-content:center;margin-bottom:40px}.proof-stat{align-items:center;display:flex;flex-direction:column;gap:8px}.proof-stat svg{color:#4f46e5;color:var(--primary-indigo)}.proof-number{color:#475569;color:var(--text-secondary);font-size:14px;font-weight:600}.testimonials-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:800px}.testimonial-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);padding:20px;text-align:left}.testimonial-stars{display:flex;gap:2px;margin-bottom:12px}.testimonial-card p{color:#475569;color:var(--text-secondary);font-size:14px;font-style:italic;margin-bottom:12px}.testimonial-author{color:#0f172a;color:var(--text-primary);font-size:13px;font-weight:600}.landing-pricing{padding:60px 20px;text-align:center}.landing-pricing h2{font-size:28px;font-weight:800;margin-bottom:8px}.pricing-subtitle{color:#94a3b8;color:var(--text-muted);font-size:16px;margin-bottom:40px}.pricing-cards{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:0 auto;max-width:1000px}.pricing-card{background:#f8fafc;background:var(--bg-primary);border:2px solid #fff6;border:2px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:32px 24px;position:relative;text-align:left;width:280px}.pricing-card.popular{border-color:#4f46e5;border-color:var(--primary-indigo);transform:scale(1.05)}.popular-tag{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-size:11px;font-weight:700;left:50%;padding:6px 16px;position:absolute;text-transform:uppercase;top:-12px;transform:translateX(-50%)}.pricing-card h3{font-size:20px;font-weight:700;margin-bottom:8px}.pricing-card .price{font-size:36px;font-weight:800;margin-bottom:20px}.pricing-card .price span{color:#94a3b8;color:var(--text-muted);font-size:16px;font-weight:500}.pricing-card ul{list-style:none;margin:0 0 24px;padding:0}.pricing-card li{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:14px;gap:10px;padding:8px 0}.pricing-card li svg{color:#10b981;flex-shrink:0}.pricing-btn{border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;font-size:15px;font-weight:600;padding:14px;transition:all .2s ease;width:100%}.pricing-btn.primary{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;color:#fff}.pricing-btn.secondary{background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);color:#0f172a;color:var(--text-primary)}.landing-final-cta{background:linear-gradient(180deg,#0000,#4f46e50d);padding:80px 20px;text-align:center}.landing-final-cta svg{color:#4f46e5;color:var(--primary-indigo);margin-bottom:20px}.landing-final-cta h2{font-size:28px;font-weight:800;margin-bottom:12px}.landing-final-cta p{color:#94a3b8;color:var(--text-muted);font-size:16px;margin-bottom:32px}.trust-badges{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:20px}.trust-badges span{color:#94a3b8;color:var(--text-muted);font-size:13px}.landing-footer{background:#f1f5f9;background:var(--bg-secondary);padding:40px 20px;text-align:center}.footer-brand h3{font-size:20px;font-weight:700;margin-bottom:4px}.footer-brand p{color:#94a3b8;color:var(--text-muted);font-size:13px;margin-bottom:20px}.footer-links{display:flex;gap:24px;justify-content:center;margin-bottom:20px}.footer-links a{color:#475569;color:var(--text-secondary);font-size:13px;text-decoration:none}.footer-links a:hover{color:#4f46e5;color:var(--primary-indigo)}.footer-social span{color:#94a3b8;color:var(--text-muted);font-size:12px}.dark-mode .landing-hero{background:linear-gradient(180deg,#8b5cf61a,#0000)}.dark-mode .phone-mockup{background:#0f0f1a;box-shadow:0 20px 60px #00000080}.dark-mode .community-hero{background:linear-gradient(135deg,#d97706,#dc2626)}@media (max-width:768px){.landing-hero h1{font-size:28px}.hero-stats{gap:20px}.features-grid,.testimonials-grid{grid-template-columns:1fr}.pricing-cards{align-items:center;flex-direction:column}.pricing-card.popular{transform:none}.how-it-works-section .steps,.share-platforms{grid-template-columns:1fr}}.referral-rewards-banner{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:32px;border-radius:var(--radius-xl);cursor:pointer;display:flex;gap:14px;margin:0 var(--spacing-md) var(--spacing-md);padding:16px;transition:transform .2s ease}.referral-rewards-banner:hover{transform:scale(1.01)}.referral-rewards-banner .banner-icon{align-items:center;background:#fff3;border-radius:24px;border-radius:var(--radius-lg);color:#fff;display:flex;height:44px;justify-content:center;width:44px}.referral-rewards-banner .banner-content{color:#fff;flex:1 1}.referral-rewards-banner .banner-title{display:block;font-size:15px;font-weight:700}.referral-rewards-banner .banner-subtitle{display:block;font-size:13px;opacity:.9}.referral-rewards-banner>svg{color:#fff;opacity:.8}.referral-dashboard{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.referral-dashboard-content{padding:var(--spacing-md);padding-bottom:100px}.referral-hero{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:32px;border-radius:var(--radius-xl);color:#fff;display:flex;flex-direction:column;gap:12px;margin-bottom:var(--spacing-lg);overflow:hidden;padding:32px 24px;position:relative}.referral-hero:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:100%;position:absolute;right:-50%;top:-50%;width:100%}.referral-hero .hero-icon{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:50%;display:flex;height:72px;justify-content:center;width:72px}.referral-hero .hero-stats{text-align:center}.referral-hero .hero-stats h2{font-size:48px;font-weight:800;line-height:1}.referral-hero .hero-stats p{font-size:14px;margin-top:4px;opacity:.9}.referral-hero .hero-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;font-size:12px;font-weight:600;gap:6px;padding:6px 14px}.referral-code-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-md);padding:20px}.referral-code-card .code-label{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;font-weight:600;gap:6px;margin-bottom:12px}.referral-code-card .code-display{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;margin-bottom:16px;padding:12px 16px}.referral-code-card .code{color:#4f46e5;color:var(--primary-indigo);flex:1 1;font-family:Monaco,Consolas,monospace;font-size:20px;font-weight:700;letter-spacing:2px}.referral-code-card .copy-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:16px;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 14px;transition:all .2s ease}.referral-code-card .copy-btn:hover{transform:scale(1.02)}.share-code-btn{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);color:#0f172a;color:var(--text-primary);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;padding:14px;transition:all .2s ease;width:100%}.share-code-btn:hover{background:var(--bg-tertiary)}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:var(--spacing-lg)}.stats-grid .stat-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);padding:16px;text-align:center}.stats-grid .stat-icon{margin-bottom:8px}.stats-grid .stat-icon.active{color:#10b981}.stats-grid .stat-icon.trending{color:#3b82f6}.stats-grid .stat-icon.bonus{color:#f59e0b}.stats-grid .stat-icon.premium{color:#8b5cf6}.stats-grid .stat-value{color:#0f172a;color:var(--text-primary);font-size:24px;font-weight:800}.stats-grid .stat-label{color:#94a3b8;color:var(--text-muted);font-size:12px}.tab-navigation{background:var(--bg-tertiary);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:8px;margin-bottom:var(--spacing-md);padding:6px}.tab-navigation .tab-btn{align-items:center;background:#0000;border:none;border-radius:16px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:10px 12px;transition:all .2s ease}.tab-navigation .tab-btn.active{background:#f8fafc;background:var(--bg-primary);box-shadow:0 2px 8px #00000014;color:#0f172a;color:var(--text-primary)}.tab-content{min-height:300px}.progress-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-md);padding:20px}.progress-section .progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.progress-section .progress-title{display:flex;flex-direction:column;gap:2px}.progress-section .progress-title span{color:#94a3b8;color:var(--text-muted);font-size:12px}.progress-section .progress-title strong{font-size:16px;font-weight:700}.progress-section .progress-percent{color:#4f46e5;color:var(--primary-indigo);font-size:24px;font-weight:800}.progress-bar-container{background:#f1f5f9;background:var(--bg-secondary);border-radius:9999px;border-radius:var(--radius-full);height:12px;margin-bottom:12px;overflow:hidden}.progress-bar-fill{transition:width .5s ease}.progress-section .progress-info{color:#94a3b8;color:var(--text-muted);display:flex;font-size:13px;justify-content:space-between;margin-bottom:12px}.progress-section .progress-reward{align-items:center;color:#f59e0b;display:flex;font-weight:600;gap:4px}.progress-section .progress-motivation{background:#f1f5f9;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);font-size:14px;padding:12px;text-align:center}.max-tier-achieved{align-items:center;color:#f59e0b;display:flex;flex-direction:column;gap:12px;padding:40px;text-align:center}.max-tier-achieved h3{color:#0f172a;color:var(--text-primary);font-size:20px}.max-tier-achieved p{color:#94a3b8;color:var(--text-muted)}.tips-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.tips-section h3{font-size:15px;font-weight:700;margin-bottom:16px}.tips-list{flex-direction:column}.tip-item,.tips-list{display:flex;gap:12px}.tip-item{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-md);padding:12px}.tip-item .tip-icon{font-size:20px}.tip-item p{color:#475569;color:var(--text-secondary);font-size:14px}.network-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.network-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.network-header h3{font-size:16px;font-weight:700}.network-count{background:#f1f5f9;background:var(--bg-secondary);border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-muted);font-size:13px;padding:4px 10px}.referrals-list{display:flex;flex-direction:column;gap:10px}.referral-item{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:12px;padding:12px}.referral-avatar{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;color:#fff;display:flex;height:40px;justify-content:center;width:40px}.referral-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.referral-name{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600}.referral-date{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.referral-badges{display:flex;gap:6px}.referral-badges .badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;font-size:10px;font-weight:600;gap:4px;padding:4px 8px}.referral-badges .badge.premium{background:#8b5cf626;color:#8b5cf6}.referral-badges .badge.active{background:#10b98126;color:#10b981}.referral-badges .badge.inactive{background:#6b728026;color:#6b7280}.empty-network{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;flex-direction:column;gap:12px;padding:40px 20px;text-align:center}.empty-network h4{color:#0f172a;color:var(--text-primary);font-size:16px}.empty-network p{font-size:14px}.empty-network .invite-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;margin-top:8px;padding:12px 24px}.empty-network .invite-btn,.network-impact{border-radius:24px;border-radius:var(--radius-lg)}.network-impact{background:linear-gradient(135deg,#4f46e51a,#7c3aed1a);margin-top:20px;padding:16px;text-align:center}.network-impact h4{font-size:14px;margin-bottom:6px}.network-impact p{color:#475569;color:var(--text-secondary);font-size:13px}.milestones-section{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.milestones-section h3{font-size:16px;font-weight:700;margin-bottom:20px}.milestones-timeline{display:flex;flex-direction:column;gap:0}.milestone-item{display:flex;gap:16px;opacity:.5;padding-bottom:24px;position:relative}.milestone-item.achieved{opacity:1}.milestone-item:last-child{padding-bottom:0}.milestone-line{background:#fff6;background:var(--border-light);bottom:0;left:23px;position:absolute;top:48px;width:3px}.milestone-item:last-child .milestone-line{display:none}.milestone-line .line{background:var(--bg-tertiary);height:100%;transition:background .3s ease;width:100%}.milestone-item.achieved .milestone-line .line{background:linear-gradient(180deg,#4f46e5,#7c3aed)}.milestone-icon{align-items:center;border:3px solid;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;transition:all .3s ease;width:48px;z-index:1}.milestone-content{flex:1 1;padding-top:4px}.milestone-content h4{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:700;margin-bottom:4px}.milestone-requirement{color:#94a3b8;color:var(--text-muted);font-size:12px;margin-bottom:8px}.milestone-reward{color:#f59e0b;display:flex;font-size:13px;gap:6px}.achieved-badge,.milestone-reward{align-items:center;font-weight:600}.achieved-badge{background:#10b98126;border-radius:9999px;border-radius:var(--radius-full);color:#10b981;display:inline-flex;font-size:11px;gap:4px;margin-top:8px;padding:4px 10px}.remaining-text{color:#94a3b8;color:var(--text-muted);font-size:12px;font-style:italic;margin-top:6px}.cta-section{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:32px;border-radius:var(--radius-xl);display:flex;gap:16px;margin-top:var(--spacing-lg);padding:20px}.cta-section .cta-text{color:#fff;flex:1 1}.cta-section .cta-text h3{font-size:16px;font-weight:700;margin-bottom:4px}.cta-section .cta-text p{font-size:13px;opacity:.9}.cta-section .cta-btn{align-items:center;background:#fff;border:none;border-radius:24px;border-radius:var(--radius-lg);color:#4f46e5;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 18px;transition:transform .2s ease;white-space:nowrap}.cta-section .cta-btn:hover{transform:scale(1.02)}.dark-mode .referral-code-card .code{color:#818cf8}.dark-mode .milestone-line,.dark-mode .referral-item,.dark-mode .tip-item{background:var(--bg-tertiary)}.dashboard-link-card{align-items:center;background:linear-gradient(135deg,#4f46e51a,#7c3aed1a);border:1px solid #4f46e533;border-radius:32px;border-radius:var(--radius-xl);cursor:pointer;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:16px;transition:all .2s ease}.dashboard-link-card:hover{background:linear-gradient(135deg,#4f46e526,#7c3aed26);transform:translateY(-2px)}.dashboard-link-content{align-items:center;display:flex;gap:14px}.dashboard-link-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.dashboard-link-text{display:flex;flex-direction:column;gap:2px}.dashboard-link-title{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:700}.dashboard-link-subtitle{color:#94a3b8;color:var(--text-muted);font-size:13px}.referral-challenges-view{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.referral-challenges-content{padding:var(--spacing-md);padding-bottom:100px}.challenge-notification{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;font-size:14px;font-weight:600;gap:10px;margin:0 var(--spacing-md) var(--spacing-md);padding:14px 16px}.challenge-notification.success{background:#10b98126;color:#10b981}.challenge-notification.error{background:#ef444426;color:#ef4444}.challenges-hero{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:32px;border-radius:var(--radius-xl);color:#fff;display:flex;flex-direction:column;gap:8px;margin-bottom:var(--spacing-lg);overflow:hidden;padding:32px 24px;position:relative}.challenges-hero:before{background:radial-gradient(circle,#fff3 0,#0000 70%);content:"";height:200px;position:absolute;right:-30%;top:-50%;width:200px}.hero-flames{align-items:flex-end;display:flex;gap:4px;margin-bottom:8px}.hero-flames .flame-icon{animation:flicker 1.5s infinite alternate}.hero-flames .flame-icon.center{animation-delay:.2s}@keyframes flicker{0%{opacity:.8;transform:scale(1) translateY(0)}to{opacity:1;transform:scale(1.1) translateY(-2px)}}.challenges-hero h2{font-size:24px;font-weight:800;margin:0}.challenges-hero p{font-size:14px;margin:0;opacity:.9}.timer-badge{background:#0003;border-radius:9999px;border-radius:var(--radius-full);font-size:14px;font-weight:600;gap:6px;margin-top:8px;padding:8px 16px}.progress-summary,.timer-badge{align-items:center;display:flex}.progress-summary{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);justify-content:space-around;margin-bottom:var(--spacing-lg);padding:20px}.summary-stat{align-items:center;display:flex;gap:12px}.summary-stat svg{color:#4f46e5;color:var(--primary-indigo)}.stat-info{display:flex;flex-direction:column}.stat-info .stat-value{color:#0f172a;color:var(--text-primary);font-size:20px;font-weight:800}.stat-info .stat-label{color:#94a3b8;color:var(--text-muted);font-size:12px}.summary-divider{background:#fff6;background:var(--border-light);height:40px;width:1px}.challenges-list{display:flex;flex-direction:column;gap:12px;margin-bottom:var(--spacing-lg)}.challenge-card{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);display:flex;gap:14px;overflow:hidden;padding:16px;position:relative;transition:all .3s ease}.challenge-card.completed{border-color:#0000;box-shadow:0 4px 20px #4f46e526}.challenge-card.claimed{opacity:.7}.challenge-icon{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:56px;justify-content:center;transition:all .3s ease;width:56px}.challenge-info{flex:1 1;min-width:0}.challenge-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.challenge-header h3{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:700;margin:0}.difficulty-badge{border-radius:9999px;border-radius:var(--radius-full);font-size:10px;font-weight:700;padding:2px 8px;text-transform:uppercase}.challenge-description{color:#94a3b8;color:var(--text-muted);font-size:13px;margin:0 0 10px}.challenge-progress{align-items:center;display:flex;gap:10px}.progress-bar-bg{background:var(--bg-tertiary);flex:1 1;height:6px;overflow:hidden}.progress-bar-bg,.progress-bar-fill{border-radius:9999px;border-radius:var(--radius-full)}.progress-bar-fill{height:100%}.progress-text{color:#94a3b8;color:var(--text-muted);font-size:12px;font-weight:600;white-space:nowrap}.challenge-reward{flex-direction:column;gap:4px}.challenge-reward,.claim-btn{align-items:center;display:flex}.claim-btn{animation:pulse-glow 2s infinite;background:linear-gradient(135deg,#10b981,#34d399);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:14px;font-weight:700;gap:6px;padding:10px 16px;transition:all .2s ease}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.claim-btn:hover{transform:scale(1.05)}.claim-btn:disabled{animation:none;cursor:not-allowed;opacity:.7}.btn-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.claimed-badge{background:#10b98126;color:#10b981;font-size:13px;font-weight:600}.claimed-badge,.reward-preview{align-items:center;border-radius:24px;border-radius:var(--radius-lg);display:flex;gap:4px;padding:8px 14px}.reward-preview{background:var(--bg-tertiary);color:#94a3b8;color:var(--text-muted);font-size:14px;font-weight:700}.completion-glow{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#10b9811a,#0000);bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.invite-cta{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:32px;border-radius:var(--radius-xl);display:flex;gap:16px;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:20px}.invite-cta .cta-content{align-items:center;color:#fff;display:flex;gap:12px}.invite-cta .cta-content svg{flex-shrink:0}.invite-cta .cta-content h3{font-size:15px;font-weight:700;margin:0 0 2px}.invite-cta .cta-content p{font-size:12px;margin:0;opacity:.9}.invite-cta .cta-btn{align-items:center;background:#fff;border:none;border-radius:24px;border-radius:var(--radius-lg);color:#4f46e5;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:12px 16px;transition:transform .2s ease;white-space:nowrap}.invite-cta .cta-btn:hover{transform:scale(1.02)}.tips-card{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);padding:20px}.tips-card h3{font-size:15px;font-weight:700;margin:0 0 12px}.tips-card ul{margin:0;padding:0 0 0 20px}.tips-card li{color:#475569;color:var(--text-secondary);font-size:13px;line-height:1.5;margin-bottom:8px}.tips-card li:last-child{margin-bottom:0}.dark-mode .challenge-card.completed{box-shadow:0 4px 20px #4f46e540}@media (max-width:480px){.progress-summary{flex-wrap:wrap;gap:16px}.summary-divider{display:none}.summary-stat{flex:1 1;justify-content:center;min-width:80px}.challenge-card{flex-wrap:wrap}.challenge-info{flex:1 1 100%;margin-top:12px;order:2}.challenge-icon{order:1}.challenge-reward{margin-left:auto;order:1}.invite-cta{text-align:center}.invite-cta,.invite-cta .cta-content{flex-direction:column}.invite-cta .cta-btn{justify-content:center;width:100%}}.challenges-banner{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:32px;border-radius:var(--radius-xl);color:#fff;cursor:pointer;display:flex;gap:12px;margin-bottom:var(--spacing-md);padding:16px;transition:all .2s ease}.challenges-banner:hover{box-shadow:0 8px 20px #f59e0b4d;transform:translateY(-2px)}.challenges-banner .banner-flames{align-items:center;animation:pulse 2s infinite;background:#fff3;border-radius:50%;display:flex;height:40px;justify-content:center;width:40px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.challenges-banner .banner-content{display:flex;flex:1 1;flex-direction:column;gap:2px}.challenges-banner .banner-title{font-size:15px;font-weight:700}.challenges-banner .banner-subtitle{font-size:12px;opacity:.9}.challenges-banner .banner-badge{animation:badge-pulse 2s infinite;background:#fff;border-radius:9999px;border-radius:var(--radius-full);color:#ef4444;font-size:10px;font-weight:700;padding:4px 10px}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.8}}.notification-bell-btn{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:50%;color:#0f172a;color:var(--text-primary);cursor:pointer;display:flex;height:44px;justify-content:center;position:relative;transition:all .2s ease;width:44px}.notification-bell-btn:hover{background:#f1f5f9;background:var(--bg-secondary);transform:scale(1.05)}.notification-badge{align-items:center;animation:badge-bounce .5s ease;background:linear-gradient(135deg,#ef4444,#f87171);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px;position:absolute;right:-4px;top:-4px}@keyframes badge-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.notification-backdrop{background:#0000004d;bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.notification-panel{background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;max-height:70vh;max-width:calc(100vw - 32px);overflow:hidden;position:fixed;right:16px;top:70px;width:360px;z-index:999}.notification-header{align-items:center;border-bottom:1px solid #fff6;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px}.notification-header h3{font-size:16px;font-weight:700;margin:0}.notification-header .header-actions{align-items:center;display:flex;gap:8px}.mark-all-read-btn{align-items:center;background:#4f46e51a;border:none;border-radius:16px;border-radius:var(--radius-md);color:#4f46e5;color:var(--primary-indigo);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:4px;padding:6px 12px;transition:all .2s ease}.mark-all-read-btn:hover{background:#4f46e526}.notification-header .close-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.notification-header .close-btn:hover{background:#f1f5f9;background:var(--bg-secondary);color:#0f172a;color:var(--text-primary)}.notification-list{flex:1 1;overflow-y:auto;padding:8px}.notification-item{align-items:flex-start;border-radius:24px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:12px;padding:12px;position:relative;transition:all .2s ease}.notification-item:hover{background:#f1f5f9;background:var(--bg-secondary)}.notification-item.unread{background:#4f46e50d}.notification-item .notification-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.notification-item.urgent .notification-icon{background:#ef444426;color:#ef4444}.notification-item.celebration .notification-icon{background:#10b98126;color:#10b981}.notification-item.motivation .notification-icon{background:#f59e0b26;color:#f59e0b}.notification-item.reminder .notification-icon{background:#3b82f626;color:#3b82f6}.notification-item.info .notification-icon{background:#6b728026;color:#6b7280}.notification-content{flex:1 1;min-width:0}.notification-content h4{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 4px}.notification-content p{color:#475569;color:var(--text-secondary);font-size:13px;line-height:1.4;margin:0 0 6px}.notification-time{color:#94a3b8;color:var(--text-muted);font-size:11px}.notification-item .action-arrow{color:#94a3b8;color:var(--text-muted);flex-shrink:0;margin-top:8px}.unread-dot{background:#4f46e5;background:var(--primary-indigo);border-radius:50%;height:8px;position:absolute;right:12px;top:12px;width:8px}.empty-notifications{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.empty-notifications svg{margin-bottom:12px;opacity:.5}.empty-notifications p{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 4px}.empty-notifications span{font-size:13px}.notification-footer{border-top:1px solid #fff6;border-top:1px solid var(--border-light);padding:12px}.view-all-btn{align-items:center;background:#4f46e51a;border:none;border-radius:24px;border-radius:var(--radius-lg);color:#4f46e5;color:var(--primary-indigo);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:12px;transition:all .2s ease;width:100%}.view-all-btn:hover{background:#4f46e526}.notification-toast{align-items:flex-start;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:32px;border-radius:var(--radius-xl);box-shadow:0 10px 40px #0003;display:flex;gap:12px;max-width:calc(100vw - 40px);overflow:hidden;padding:16px;position:fixed;right:20px;top:20px;width:360px;z-index:1000}.notification-toast.urgent{border-left:4px solid #ef4444}.notification-toast.celebration{border-left:4px solid #10b981}.notification-toast.motivation{border-left:4px solid #f59e0b}.notification-toast .toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.notification-toast.urgent .toast-icon{background:#ef444426;color:#ef4444}.notification-toast.celebration .toast-icon{background:#10b98126;color:#10b981}.notification-toast.motivation .toast-icon{background:#f59e0b26;color:#f59e0b}.notification-toast .toast-content{flex:1 1}.notification-toast .toast-content h4{font-size:14px;font-weight:700;margin:0 0 4px}.notification-toast .toast-content p{color:#475569;color:var(--text-secondary);font-size:13px;line-height:1.4;margin:0}.notification-toast .toast-actions{display:flex;gap:8px}.toast-action-btn,.toast-close-btn{align-items:center;background:#f1f5f9;background:var(--bg-secondary);border:none;border-radius:50%;color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.toast-action-btn:hover,.toast-close-btn:hover{background:var(--bg-tertiary);color:#0f172a;color:var(--text-primary)}.toast-action-btn.primary{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.toast-progress{background:var(--bg-tertiary);bottom:0;height:3px;left:0;position:absolute;right:0}.toast-progress .progress-bar{background:#4f46e5;background:var(--primary-indigo);height:100%}.notification-settings{background:#f1f5f9;background:var(--bg-secondary);min-height:100vh}.notification-settings .settings-content{padding:var(--spacing-md);padding-bottom:100px}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section h3{color:#94a3b8;color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:1px;margin:0 0 12px;padding-left:4px;text-transform:uppercase}.setting-item{align-items:center;background:#f8fafc;background:var(--bg-primary);border:1px solid #fff6;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:8px;padding:16px}.setting-item .setting-info{align-items:center;display:flex;gap:14px}.setting-item .setting-info svg{color:#4f46e5;color:var(--primary-indigo)}.setting-item .setting-info h4{font-size:15px;font-weight:600;margin:0 0 2px}.setting-item .setting-info p{color:#94a3b8;color:var(--text-muted);font-size:12px;margin:0}.toggle-btn{background:var(--bg-tertiary);border:none;border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;height:28px;position:relative;transition:all .3s ease;width:50px}.toggle-btn.active{background:linear-gradient(135deg,#10b981,#34d399)}.toggle-knob{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:22px;left:3px;position:absolute;top:3px;transition:all .3s ease;width:22px}.toggle-btn.active .toggle-knob{left:25px}.save-preferences-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#8b5cf6);background:var(--primary-gradient);border:none;border-radius:24px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-top:var(--spacing-lg);padding:16px;transition:all .2s ease;width:100%}.save-preferences-btn:hover:not(:disabled){box-shadow:0 8px 20px #4f46e54d;transform:translateY(-2px)}.save-preferences-btn:disabled{cursor:not-allowed;opacity:.7}.dark-mode .notification-panel,.dark-mode .notification-toast{box-shadow:0 10px 40px #0006}@media (max-width:480px){.notification-panel{right:8px;top:60px;width:calc(100vw - 16px)}.notification-toast{left:10px;right:10px;width:auto}}
/*# sourceMappingURL=main.250a4c48.css.map*/