*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-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;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:before,:after,::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: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.bottom-0{bottom:0}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-4{right:1rem}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-10{z-index:10}.z-50{z-index:50}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.ml-auto{margin-left:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.aspect-square{aspect-ratio:1}.size-10{width:2.5rem;height:2.5rem}.size-2{width:.5rem;height:.5rem}.size-3{width:.75rem;height:.75rem}.size-3\.5{width:.875rem;height:.875rem}.size-4{width:1rem;height:1rem}.size-6{width:1.5rem;height:1.5rem}.size-8{width:2rem;height:2rem}.size-9{width:2.25rem;height:2.25rem}.size-full{width:100%;height:100%}.h-10{height:2.5rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-px{height:1px}.max-h-\[85vh\]{max-height:85vh}.w-fit{width:fit-content}.w-full{width:100%}.min-w-0{min-width:0}.min-w-\[8rem\]{min-width:8rem}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.translate-x-\[-50\%\]{--tw-translate-x:-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%;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))}.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))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-default{cursor:default}.select-none{-webkit-user-select:none;user-select:none}.auto-rows-min{grid-auto-rows:min-content}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.-space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(-.5rem*var(--tw-space-x-reverse));margin-left:calc(-.5rem*calc(1 - var(--tw-space-x-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:end}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-xs{border-radius:calc(var(--radius) - 6px)}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-border{border-color:hsl(var(--border))}.border-input{border-color:hsl(var(--input))}.border-transparent{border-color:#0000}.bg-background{background-color:hsl(var(--background))}.bg-black\/50{background-color:#00000080}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-muted{background-color:hsl(var(--muted))}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-secondary{background-color:hsl(var(--secondary))}.bg-transparent{background-color:#0000}.fill-current{fill:currentColor}.p-1{padding:.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0{padding-top:0;padding-bottom:0}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.text-center{text-align:center}.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-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.tracking-widest{letter-spacing:.1em}.text-card-foreground{color:hsl(var(--card-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.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:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.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);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);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline-offset:2px;outline:2px solid #0000}.outline{outline-style:solid}.ring-2{--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),var(--tw-shadow,0 0 #0000)}.ring-background{--tw-ring-color:hsl(var(--background))}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur)var(--tw-brightness)var(--tw-contrast)var(--tw-grayscale)var(--tw-hue-rotate)var(--tw-invert)var(--tw-saturate)var(--tw-sepia)var(--tw-drop-shadow)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur)var(--tw-brightness)var(--tw-contrast)var(--tw-grayscale)var(--tw-hue-rotate)var(--tw-invert)var(--tw-saturate)var(--tw-sepia)var(--tw-drop-shadow)}.filter{filter:var(--tw-blur)var(--tw-brightness)var(--tw-contrast)var(--tw-grayscale)var(--tw-hue-rotate)var(--tw-invert)var(--tw-saturate)var(--tw-sepia)var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-property:opacity;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);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:var(--tw-exit-opacity,1);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))}}.duration-200{animation-duration:.2s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.running{animation-play-state:running}:root{--background:0 0% 100%;--foreground:240 10% 4%;--card:0 0% 100%;--card-foreground:240 10% 4%;--popover:0 0% 100%;--popover-foreground:240 10% 4%;--primary:245 58% 57%;--primary-foreground:0 0% 100%;--secondary:240 5% 96%;--secondary-foreground:240 5% 10%;--muted:240 5% 96%;--muted-foreground:220 9% 46%;--accent:240 5% 96%;--accent-foreground:240 5% 10%;--destructive:0 72% 51%;--destructive-foreground:0 0% 100%;--border:220 13% 91%;--input:220 13% 91%;--ring:245 58% 57%;--radius:.75rem}.logo-light{display:inline-block}.logo-dark,.dark .logo-light{display:none}.dark .logo-dark{display:inline-block}.dark{--background:224 71% 4%;--foreground:213 31% 91%;--card:224 71% 4%;--card-foreground:213 31% 91%;--popover:224 71% 4%;--popover-foreground:213 31% 91%;--primary:210 40% 98%;--primary-foreground:222.2 47.4% 11.2%;--secondary:222.2 47.4% 11.2%;--secondary-foreground:210 40% 98%;--muted:223 47% 11%;--muted-foreground:215.4 16.3% 56.9%;--accent:216 34% 17%;--accent-foreground:210 40% 98%;--destructive:0 63% 31%;--destructive-foreground:210 40% 98%;--border:216 34% 17%;--input:216 34% 17%;--ring:216 34% 17%}*{box-sizing:border-box;margin:0;padding:0}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:system-ui,sans-serif}.app-shell{background:hsl(var(--muted));min-height:100dvh}.app-topbar{z-index:30;background:hsl(var(--card));border-bottom:1px solid hsl(var(--border));height:48px;position:sticky;top:0}.app-topbar-inner{justify-content:space-between;align-items:center;max-width:640px;height:100%;margin:0 auto;padding:0 16px;display:flex}.app-topbar-brand{color:hsl(var(--foreground));white-space:nowrap;font-size:17px;font-weight:700}@media (max-width:767px){.brand-text{display:none}.app-topbar-inner{position:relative}.app-hh-switcher,.app-hh-label{position:absolute;left:50%;transform:translate(-50%)}#topbar-actions{margin-left:auto;display:block}}.app-topbar-actions{align-items:center;gap:8px;display:flex}.app-topbar-nav{display:none}.app-nav-item{color:hsl(var(--muted-foreground));-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:2px;padding:4px 16px;font-size:10px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.app-nav-item.active{color:hsl(var(--primary));font-weight:700}.app-main{max-width:640px;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px));min-height:calc(100dvh - 48px);margin:0 auto}.app-bottom-nav{z-index:30;height:calc(84px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:hsl(var(--card));border-top:1px solid hsl(var(--border));justify-content:space-around;align-items:flex-start;padding-top:6px;display:flex;position:fixed;bottom:0;left:0;right:0}.app-hh-switcher{color:hsl(var(--foreground));background:hsl(var(--accent));cursor:pointer;white-space:nowrap;text-overflow:ellipsis;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;align-items:center;gap:4px;max-width:140px;padding:6px 10px;font-size:13px;font-weight:500;display:flex;overflow:hidden}.app-hh-label{color:hsl(var(--muted-foreground));white-space:nowrap;text-overflow:ellipsis;max-width:140px;padding:6px 10px;font-size:13px;font-weight:500;overflow:hidden}@media (min-width:768px){.app-topbar{height:56px}.app-topbar-inner{gap:8px;max-width:960px}.app-topbar-nav{flex:1;align-items:center;gap:4px;margin-left:24px;display:flex}.app-topbar-nav .app-nav-item{border-radius:8px;flex-direction:row;gap:6px;padding:6px 14px;font-size:13px;font-weight:500}.app-topbar-nav .app-nav-item:hover{background:hsl(var(--accent))}.app-topbar-nav .app-nav-item.active{background:hsl(var(--accent));color:hsl(var(--primary));font-weight:650}.app-bottom-nav{display:none}.app-main{max-width:960px;min-height:calc(100dvh - 56px);padding-bottom:24px}}.app-page-header{padding:20px 20px 0}.app-title{color:hsl(var(--foreground));font-size:22px;font-weight:700}.app-subtitle{color:hsl(var(--muted-foreground));max-width:60ch;margin-top:4px;font-size:13px}.app-brand{color:hsl(var(--muted-foreground));font-size:12px}.app-chip{background:hsl(var(--accent));max-width:240px;color:hsl(var(--primary));white-space:nowrap;text-overflow:ellipsis;border-radius:999px;padding:6px 10px;font-size:12px;display:inline-block;overflow:hidden}.dark .app-chip{background:hsl(var(--secondary));color:hsl(var(--foreground))}.app-content{flex-direction:column;gap:10px;padding:14px;display:flex}.app-card{background:hsl(var(--card));border:1px solid hsl(var(--border));color:hsl(var(--card-foreground));border-radius:14px;padding:14px;box-shadow:0 1px 2px #0000000a}.dark .app-card{box-shadow:0 1px 2px #0003}.app-grid{gap:4px;display:grid}.app-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.app-section-title{color:hsl(var(--foreground));margin-bottom:8px;font-size:16px;font-weight:650}.app-muted{color:hsl(var(--muted-foreground));font-size:13px}.app-list-item{border:1px solid hsl(var(--border));border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:12px;display:flex}.app-status-note{color:hsl(var(--foreground));background:hsl(var(--accent));border:1px solid hsl(var(--border));border-radius:8px;padding:4px 8px;font-size:12px}.dark .app-status-note{color:hsl(var(--foreground));background:hsl(var(--secondary))}.app-day-chips{gap:8px;padding-bottom:2px;display:flex;overflow:auto}.app-day-chip{border:1px solid hsl(var(--border));background:hsl(var(--card));color:hsl(var(--foreground));white-space:nowrap;border-radius:999px;padding:8px 12px;font-size:13px}.app-day-chip.active{color:hsl(var(--primary));background:hsl(var(--accent));border-color:hsl(var(--ring))}.dark .app-day-chip.active{color:hsl(var(--foreground));background:hsl(var(--secondary))}.app-details{border:1px solid hsl(var(--border));background:hsl(var(--card));border-radius:12px}.app-details summary{cursor:pointer;color:hsl(var(--foreground));justify-content:space-between;align-items:center;gap:8px;padding:12px;font-weight:650;list-style:none;display:flex}.app-details summary::-webkit-details-marker{display:none}.app-details-body{border-top:1px solid hsl(var(--border));gap:6px;min-width:0;padding:12px;display:grid;overflow:hidden}.app-details-body>*{min-width:0;max-width:100%}.app-kv{color:hsl(var(--muted-foreground));font-size:13px}.touch-btn{border:1px solid hsl(var(--border));background:hsl(var(--card));min-height:44px;color:hsl(var(--foreground));cursor:pointer;border-radius:10px;padding:10px 12px;font-weight:600;transition:background .1s,border-color .1s}.touch-btn:hover:not(:disabled){background:hsl(var(--accent))}.touch-btn:disabled{opacity:.5;cursor:not-allowed}.touch-btn.primary{background:hsl(var(--primary));border-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.dark .touch-btn.primary{color:#fff;background:#5c52d1;border-color:#5c52d1}.touch-btn.primary:hover:not(:disabled),.dark .touch-btn.primary:hover:not(:disabled){background:#4236c9;border-color:#4236c9}.btn{border-radius:.375rem;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background-color:hsl(var(--foreground));color:hsl(var(--background))}.btn-primary:hover{opacity:.85}.btn-outline{color:hsl(var(--foreground));border:1px solid hsl(var(--border));background-color:#0000}.btn-outline:hover{background-color:hsl(var(--accent))}.btn-lg{padding:.875rem 2rem;font-size:1.125rem}.shopping-item-row{border:1px solid hsl(var(--border));-webkit-user-select:none;user-select:none;cursor:pointer;background:hsl(var(--card));border-radius:12px;align-items:center;gap:10px;padding:9px;transition:opacity .15s;display:flex;position:relative;overflow:hidden}.shopping-item-row.purchased{opacity:.5}.shopping-item-row.item-selected{background:hsl(var(--accent));border-color:hsl(var(--ring))}.shopping-item-row.purchased .shopping-item-name{text-decoration:line-through}.shopping-item-name{color:hsl(var(--foreground));font-size:14px;font-weight:500}.shopping-item-qty{background:hsl(var(--accent));color:hsl(var(--primary));border-radius:6px;margin-left:6px;padding:1px 6px;font-size:12px;font-weight:600;display:inline-block}.dark .shopping-item-qty{background:hsl(var(--secondary));color:hsl(var(--foreground))}.shopping-item-meta{color:hsl(var(--muted-foreground));margin-top:2px;font-size:12px}@keyframes longPressProgress{0%{width:0}to{width:100%}}.long-press-indicator{background:hsl(var(--ring));border-radius:0 0 12px 12px;height:3px;animation:.5s linear forwards longPressProgress;position:absolute;bottom:0;left:0}.dialog-solid-bg{background-color:hsl(var(--card));opacity:1!important}.modal-section{gap:6px;display:grid}.modal-section-label{color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:600}.price-list{gap:4px;display:grid}.price-row{border:1px solid hsl(var(--border));background:hsl(var(--card));border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.price-store{color:hsl(var(--foreground));flex:1;font-weight:500}.price-amount{color:#059669;font-weight:600}.dark .price-amount{color:#34d399}.price-delete{color:#dc2626;cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:12px;line-height:1}.price-add-form{align-items:center;gap:6px;margin-top:4px;display:flex}.item-detail-dialog{max-height:90vh;overflow-y:auto}.item-detail-body{flex-direction:column;gap:0;display:flex}.item-detail-header{align-items:flex-start;gap:12px;display:flex}.item-detail-emoji-btn{border:2px solid hsl(var(--border));background:hsl(var(--accent));cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:26px;transition:border-color .15s;display:flex}.item-detail-emoji-btn:hover{border-color:hsl(var(--primary))}.item-detail-emoji-input{border:2px solid hsl(var(--primary));background:hsl(var(--accent));text-align:center;cursor:text;border-radius:12px;outline:none;flex-shrink:0;width:48px;height:48px;font-size:26px}.item-detail-section-divider{background:hsl(var(--border)/.6);height:1px;margin:14px 0}.item-detail-section{flex-direction:column;gap:8px;display:flex}.item-detail-section-label{color:hsl(var(--muted-foreground));letter-spacing:.03em;text-transform:uppercase;font-size:12px;font-weight:600}.item-detail-pickers{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:400px){.item-detail-pickers{grid-template-columns:1fr 1fr}}.item-detail-dropdown-wrap{position:relative}.item-detail-dropdown-trigger{border:1px solid hsl(var(--border));background:hsl(var(--card));width:100%;color:hsl(var(--foreground));cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-size:14px;font-weight:500;transition:border-color .12s;display:flex}.item-detail-dropdown-trigger:hover{border-color:hsl(var(--ring))}.item-detail-dropdown-menu{z-index:20;background:hsl(var(--card));border:1px solid hsl(var(--border));box-shadow:0 4px 16px hsl(var(--foreground)/.08);border-radius:10px;max-height:220px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.item-detail-dropdown-option{text-align:left;width:100%;color:hsl(var(--foreground));cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:13px;transition:background .1s;display:block}.item-detail-dropdown-option:hover{background:hsl(var(--accent))}.item-detail-dropdown-option.selected{color:hsl(var(--primary));font-weight:600}.dark .item-detail-dropdown-option.selected{color:hsl(var(--foreground));background:hsl(var(--secondary))}.item-detail-toggles{gap:8px;display:flex}.item-detail-toggle-btn{border:1px solid hsl(var(--border));background:hsl(var(--card));color:hsl(var(--muted-foreground));cursor:pointer;text-align:center;border-radius:10px;flex:1;padding:10px 12px;font-size:13px;font-weight:500;transition:all .12s}.item-detail-toggle-btn:hover{border-color:hsl(var(--ring))}.item-detail-toggle-btn.active.urgent{color:#e08472;background:#e0847222;border-color:#e08472}.dark .item-detail-toggle-btn.active.urgent{color:#f0a090;background:#e0847233}.item-detail-toggle-btn.active.personal{color:#a78bca;background:#a78bca22;border-color:#a78bca}.dark .item-detail-toggle-btn.active.personal{color:#c4aadf;background:#a78bca33}.item-detail-price-row{border-bottom:1px solid hsl(var(--border)/.3);align-items:center;gap:10px;padding:8px 0;display:flex}.item-detail-price-row:last-child{border-bottom:none}.item-detail-price-img{-o-object-fit:cover;object-fit:cover;background:hsl(var(--muted));border-radius:6px;flex-shrink:0;width:44px;height:44px}@keyframes itemEnter{0%{opacity:0;transform:translateY(-10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.item-entering{animation:.22s ease-out itemEnter}@keyframes itemWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-.4deg)}75%{transform:rotate(.4deg)}}.item-wiggle{animation:.35s ease-in-out infinite itemWiggle}.item-wiggle:nth-child(2n){animation-delay:.1s}.item-wiggle:nth-child(3n){animation-direction:reverse}.item-urgent{border-left:4px solid #e08472}.item-personal{border-right:4px solid #a78bca}.toggle-pill{border:1px solid hsl(var(--border));color:hsl(var(--muted-foreground));cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:999px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.toggle-pill:hover{border-color:hsl(var(--foreground)/.3)}.toggle-pill.active.urgent{color:#fff;background:#e08472;border-color:#e08472}.toggle-pill.active.personal{color:#fff;background:#a78bca;border-color:#a78bca}.toggle-pill.active.household{background:hsl(var(--primary));border-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.topbar-add-btn{background:hsl(var(--primary));width:34px;height:34px;color:hsl(var(--primary-foreground));cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .25s,background .15s;display:flex}.topbar-add-btn:hover{background:hsl(var(--primary)/.85)}.topbar-add-btn.open{transform:rotate(45deg)}.topbar-add-btn.sparkle{background:#a78bca;position:relative;overflow:hidden}.topbar-add-btn.sparkle:after{content:"";background:linear-gradient(90deg,#0000,#ffffff59,#0000);width:50%;height:200%;animation:2.5s ease-in-out infinite sparkle-sweep;position:absolute;top:-50%;left:-75%;transform:skew(-20deg)}.topbar-add-btn.sparkle:hover{background:#9678b8}.quick-add-panel{opacity:0;max-height:0;transition:max-height .3s ease-out,opacity .2s ease-out;overflow:hidden}.quick-add-panel.open{opacity:1;max-height:400px;overflow:visible}.item-meta-row{color:hsl(var(--muted-foreground));flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px;font-size:12px;display:flex}.item-store-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.store-compact-only{display:inline}.store-full-only{display:none}@media (min-width:768px){.store-compact-only{display:none}.store-full-only{display:inline-block}}.item-category-chip{background:hsl(var(--accent));color:hsl(var(--accent-foreground));border-radius:999px;padding:1px 8px;font-size:11px;font-weight:500;display:inline-block}.dark .item-category-chip{background:hsl(var(--secondary));color:hsl(var(--secondary-foreground))}.avatar-edit-overlay{opacity:0;background:#00000061;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}:hover>.avatar-edit-overlay{opacity:1}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-7px)}30%{transform:translate(7px)}45%{transform:translate(-5px)}60%{transform:translate(5px)}75%{transform:translate(-2px)}90%{transform:translate(2px)}}@keyframes nudge{0%,65%,to{transform:translateY(0)}75%{transform:translateY(-4px)}85%{transform:translateY(-1px)}92%{transform:translateY(-3px)}}@keyframes sparkle-sweep{0%{left:-75%}55%,to{left:125%}}.touch-btn:active:not(:disabled){transition:transform 80ms;transform:scale(.97)}.shake{animation:.5s ease-in-out shake}.nudge{animation:3s ease-in-out infinite nudge}.touch-btn.sm{min-height:36px;padding:6px 12px;font-size:13px}.touch-btn.danger{color:hsl(var(--destructive));border-color:hsl(var(--destructive)/.25)}.touch-btn.danger:hover:not(:disabled){background:hsl(var(--destructive)/.07);border-color:hsl(var(--destructive)/.45)}.icon-btn{cursor:pointer;width:32px;height:32px;min-height:unset;color:hsl(var(--muted-foreground));background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:background .1s,color .1s;display:flex}.icon-btn:hover:not(:disabled){background:hsl(var(--accent));color:hsl(var(--foreground))}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn.danger{color:hsl(var(--destructive))}.icon-btn.danger:hover:not(:disabled){background:hsl(var(--destructive)/.07)}.hh-pill{background:hsl(var(--muted));color:hsl(var(--foreground))}.hh-pill.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.dark .hh-pill.active{color:#fff;background:#5c52d1}.ai-btn{color:#fff;background:linear-gradient(135deg,#493ecc,#a542d7);border-color:#0000;animation:3s ease-in-out infinite nudge;position:relative;overflow:hidden}.ai-btn:after{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:50%;height:200%;animation:2.5s ease-in-out infinite sparkle-sweep;position:absolute;top:-50%;left:-75%;transform:skew(-20deg)}.ai-btn:hover:not(:disabled){background:linear-gradient(135deg,#3f33c1,#9b2dd2)}.ai-btn:active:not(:disabled){transform:scale(.97)}.spinner{vertical-align:middle;border:2px solid #ffffff59;border-top-color:currentColor;border-radius:50%;width:14px;height:14px;animation:.65s linear infinite spin;display:inline-block}.touch-input{border:1px solid hsl(var(--border));background:hsl(var(--card));min-height:44px;color:hsl(var(--foreground));-webkit-appearance:none;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:15px;font-weight:400;transition:border-color .15s}.touch-input:focus{border-color:hsl(var(--ring));box-shadow:0 0 0 2px hsl(var(--ring)/.15)}.touch-input::placeholder{color:hsl(var(--muted-foreground))}select.touch-input{cursor:pointer;appearance:menulist}.custom-select-wrap{position:relative}.custom-select-trigger{border:1px solid hsl(var(--border));background:hsl(var(--card));width:100%;min-height:44px;color:hsl(var(--foreground));cursor:pointer;text-align:left;border-radius:10px;outline:none;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-family:inherit;font-size:15px;font-weight:400;transition:border-color .15s;display:flex}.custom-select-trigger:focus{border-color:hsl(var(--ring));box-shadow:0 0 0 2px hsl(var(--ring)/.15)}.custom-select-menu{z-index:50;border:1px solid hsl(var(--border));background:hsl(var(--card));border-radius:10px;animation:.15s ease-out selectFadeIn;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #00000040}@keyframes selectFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{width:100%;color:hsl(var(--foreground));text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:background .1s;display:block}.custom-select-option:hover,.custom-select-option:focus{background:hsl(var(--accent))}.custom-select-option.selected{color:hsl(var(--primary));font-weight:500}.custom-select-option+.custom-select-option{border-top:1px solid hsl(var(--border)/.5)}textarea.touch-input{resize:vertical;min-height:88px;line-height:1.5}.app-banner{border:1px solid;border-radius:10px;padding:10px 14px;font-size:14px;line-height:1.5}.app-banner.error{color:#7e2525;background:#fff0f0;border-color:#f4bebe}.dark .app-banner.error{color:#ea8686;background:#321515;border-color:#6b2424}.app-banner.warning{color:#72471d;background:#fff9eb;border-color:#f1d99d}.dark .app-banner.warning{color:#edcf82;background:#342b14;border-color:#685527}.app-banner.success{color:#1f5131;background:#edfdf3;border-color:#aee0c0}.dark .app-banner.success{color:#54d483;background:#122b1b;border-color:#255637}@keyframes pageContentIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-content-in{animation:.25s ease-out both pageContentIn}.skeleton-line,.skeleton-card{background:linear-gradient(90deg,hsl(var(--accent))25%,hsl(var(--muted))50%,hsl(var(--accent))75%);background-size:200% 100%;border-radius:8px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.meal-type-breakfast{color:#7a4d1f;background:#fff5db}.meal-type-lunch{color:#1f427a;background:#dae7fb}.meal-type-dinner{color:#3f2a6f;background:#e6def7}.meal-type-snack{color:#235c36;background:#def7e7}.dark .meal-type-breakfast{color:#e4c167;background:#393018}.dark .meal-type-lunch{color:#6797e4;background:#182539}.dark .meal-type-dinner{color:#a589e6;background:#271e3e}.dark .meal-type-snack{color:#5cd685;background:#193422}.meal-plan-table{border-collapse:separate;border-spacing:4px;width:100%}.meal-plan-header-cell{color:hsl(var(--muted-foreground));text-align:center;background:hsl(var(--card));border:1px solid hsl(var(--border));text-transform:uppercase;letter-spacing:.05em;border-radius:8px;padding:6px 8px;font-size:12px;font-weight:700}.meal-plan-row-label{color:hsl(var(--foreground));text-transform:capitalize;white-space:nowrap;vertical-align:top;padding:6px 8px;font-size:12px;font-weight:600}.meal-plan-cell{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:8px;flex-direction:column;gap:4px;min-height:60px;padding:4px;display:flex}.meal-plan-entry{border-radius:6px;padding:4px 20px 4px 6px;font-size:11px;position:relative}.meal-plan-delete-btn{cursor:pointer;color:hsl(var(--muted-foreground));opacity:.5;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:13px;line-height:1;transition:opacity .15s,color .15s;position:absolute;top:2px;right:2px}.meal-plan-delete-btn:hover{opacity:1;color:hsl(var(--destructive))}.meal-plan-add-btn{border:1px dashed hsl(var(--border));cursor:pointer;color:hsl(var(--muted-foreground));background:0 0;border-radius:6px;width:100%;padding:2px 0;font-size:16px;line-height:1;transition:all .1s}.meal-plan-add-btn:hover:not(:disabled){border-color:hsl(var(--ring));color:hsl(var(--foreground))}.meal-plan-desktop{display:block}.meal-plan-mobile{display:none}@media (max-width:767px){.meal-plan-desktop{display:none}.meal-plan-mobile{display:block}}.recipe-card-row{border:1px solid hsl(var(--border));cursor:pointer;-webkit-user-select:none;user-select:none;background:hsl(var(--card));border-radius:14px;transition:box-shadow .15s;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000000a}.dark .recipe-card-row{box-shadow:0 1px 2px #0003}.recipe-card-row:active{box-shadow:0 0 0 2px hsl(var(--ring)/.2)}.recipe-scaling-bar{background:hsl(var(--accent));border:1px solid hsl(var(--border));color:hsl(var(--foreground));border-radius:10px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;font-weight:500;display:flex}.recipe-scaling-bar button{border:1px solid hsl(var(--border));background:hsl(var(--card));width:32px;height:32px;color:hsl(var(--foreground));cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:background .1s;display:flex}.recipe-scaling-bar button:hover{background:hsl(var(--muted))}.recipe-scaling-bar button:disabled{opacity:.35;cursor:not-allowed}.recipe-ingredient-row{border:1px solid hsl(var(--border));border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;transition:background .1s;display:flex}.recipe-ingredient-row:hover{background:hsl(var(--accent)/.5)}.recipe-ingredient-row .ing-amount{min-width:48px;color:hsl(var(--primary));text-align:right;flex-shrink:0;font-weight:600}.dark .recipe-ingredient-row .ing-amount{color:hsl(var(--foreground))}.recipe-ingredient-row .ing-unit{min-width:36px;color:hsl(var(--muted-foreground));flex-shrink:0}.recipe-ingredient-row .ing-name{color:hsl(var(--foreground));flex:1;min-width:0;font-weight:500}.recipe-notes{border:1px solid hsl(var(--border));background:hsl(var(--card));width:100%;min-height:64px;color:hsl(var(--foreground));resize:vertical;border-radius:10px;outline:none;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.5;transition:border-color .15s}.recipe-notes:focus{border-color:hsl(var(--ring));box-shadow:0 0 0 2px hsl(var(--ring)/.15)}.recipe-notes::placeholder{color:hsl(var(--muted-foreground))}.recipe-preview-chip{background:hsl(var(--accent));color:hsl(var(--foreground));white-space:nowrap;text-overflow:ellipsis;border-radius:6px;max-width:100px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block;overflow:hidden}.dark .recipe-preview-chip{background:hsl(var(--secondary))}.cook-mode-overlay{z-index:100;background:hsl(var(--background));-webkit-overflow-scrolling:touch;animation:.25s ease-out cookModeIn;position:fixed;inset:0;overflow-y:auto}@keyframes cookModeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cook-mode-header{z-index:10;background:hsl(var(--background));border-bottom:1px solid hsl(var(--border));flex-wrap:wrap;align-items:center;gap:12px;padding:12px 20px;display:flex;position:sticky;top:0}.cook-mode-title{color:hsl(var(--foreground));flex:1;min-width:0;margin:0;font-size:20px;font-weight:700}.cook-mode-body{max-width:680px;padding:24px 20px calc(40px + env(safe-area-inset-bottom,0px));gap:32px;margin:0 auto;display:grid}.cook-mode-section-title{text-transform:uppercase;letter-spacing:.05em;color:hsl(var(--muted-foreground));margin:0 0 12px;font-size:14px;font-weight:700}.cook-mode-ingredient{color:hsl(var(--foreground));border-bottom:1px solid hsl(var(--border)/.5);align-items:baseline;gap:10px;padding:6px 0;font-size:17px;line-height:1.5;display:flex}.cook-mode-ing-qty{color:hsl(var(--primary));text-align:right;flex-shrink:0;min-width:60px;font-weight:700}.dark .cook-mode-ing-qty{color:hsl(var(--foreground))}.cook-mode-method{gap:20px;display:grid}.cook-mode-step{align-items:flex-start;gap:14px;display:flex}.cook-mode-step-num{background:hsl(var(--primary));width:32px;height:32px;color:hsl(var(--primary-foreground));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:15px;font-weight:700;display:flex}.dark .cook-mode-step-num{color:#fff;background:#5c52d1}.cook-mode-step p{color:hsl(var(--foreground));margin:0;font-size:17px;line-height:1.7}.cook-mode-phase-block.prep{background:#fff9eb;border:1px solid #f4e0af;border-radius:14px;padding:16px}.dark .cook-mode-phase-block.prep{background:#211d12;border-color:#493f27}.cook-mode-phase-block.cook{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:14px;padding:16px}.cook-mode-phase-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:6px;align-items:center;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.cook-mode-phase-badge.prep{color:#72471d;background:#f7e6ba}.dark .cook-mode-phase-badge.prep{color:#e4c167;background:#473c1f}.cook-mode-phase-badge.cook{background:hsl(var(--primary)/.12);color:hsl(var(--primary))}.dark .cook-mode-phase-badge.cook{color:#958ee1;background:#5c52d133}.cook-mode-step-num.prep{color:#492e12;background:#e9c363}.dark .cook-mode-step-num.prep{color:#faeed1;background:#866d2d}.cook-mode-step-num.cook{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.dark .cook-mode-step-num.cook{color:#fff;background:#5c52d1}.landing-nav{z-index:40;background:#fff;border-bottom:1px solid #e8e4f0;position:sticky;top:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;padding:0 24px;display:flex}.landing-nav-brand{align-items:center;gap:10px;text-decoration:none;display:flex}.landing-nav-signin{color:#fff;background:#3d1068;border-radius:8px;align-items:center;padding:8px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.landing-nav-signin:hover{background:#5a1e96}.landing-hero{color:#fff;text-align:center;background:linear-gradient(135deg,#3d1068 0%,#18b0aa 100%);padding:80px 24px}.landing-hero-inner{flex-direction:column;align-items:center;max-width:760px;margin:0 auto;display:flex}.landing-hero-title{letter-spacing:-.02em;color:#fff;margin-bottom:20px;font-size:clamp(2rem,5vw,3.25rem);font-weight:800;line-height:1.15}.landing-hero-sub{color:#ffffffe0;max-width:560px;margin-bottom:36px;font-size:clamp(1rem,2.5vw,1.2rem);line-height:1.6}.landing-hero-ctas{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:24px;display:flex}.landing-btn-primary{color:#3d1068;cursor:pointer;background:#fff;border:2px solid #fff;border-radius:10px;justify-content:center;align-items:center;padding:14px 32px;font-size:16px;font-weight:700;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.landing-btn-primary:hover{background:#f0eaf8}.landing-btn-ghost{color:#fff;cursor:pointer;background:0 0;border:2px solid #fff9;border-radius:10px;justify-content:center;align-items:center;padding:14px 32px;font-family:inherit;font-size:16px;font-weight:600;text-decoration:none;transition:border-color .15s,background .15s;display:inline-flex}.landing-btn-ghost:hover{background:#ffffff14;border-color:#fff}.landing-hero-badges{color:#ffffffb8;flex-wrap:wrap;justify-content:center;gap:8px;font-size:14px;display:flex}.landing-section{max-width:1100px;margin:0 auto;padding:72px 24px}.landing-section-alt{background:#f7f4fc;max-width:100%;padding:72px 24px}.landing-section-alt>*{max-width:1100px;margin-left:auto;margin-right:auto}.landing-section-title{color:#1a1030;text-align:center;margin-bottom:12px;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800}.landing-section-sub{text-align:center;color:#4a4060;margin-bottom:48px;font-size:1.05rem}.landing-feature-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.landing-feature-card{background:#fff;border:1px solid #e8e4f0;border-radius:16px;flex-direction:column;gap:10px;padding:28px 24px;transition:box-shadow .15s,transform .15s;display:flex}.landing-feature-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3d10681a}.landing-feature-icon{margin-bottom:4px;font-size:2rem;line-height:1}.landing-feature-title{color:#1a1030;font-size:1.05rem;font-weight:700}.landing-feature-body{color:#4a4060;font-size:.9rem;line-height:1.6}.landing-steps{text-align:center;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px;display:grid}.landing-step{flex-direction:column;align-items:center;gap:14px;display:flex}.landing-step-num{color:#fff;background:linear-gradient(135deg,#3d1068,#9b8ac8);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.4rem;font-weight:800;display:flex}.landing-step-title{color:#1a1030;font-size:1.1rem;font-weight:700}.landing-step-body{color:#4a4060;max-width:240px;font-size:.9rem;line-height:1.6}.landing-faq{gap:12px;max-width:720px;margin:0 auto;display:grid}.landing-faq-item{background:#fff;border:1px solid #e8e4f0;border-radius:12px;overflow:hidden}.landing-faq-summary{cursor:pointer;color:#1a1030;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;font-size:1rem;font-weight:600;list-style:none;transition:background .12s;display:flex}.landing-faq-summary::-webkit-details-marker{display:none}.landing-faq-summary:hover{background:#f7f4fc}.landing-faq-chevron{color:#9b8ac8;flex-shrink:0;font-size:1.25rem;transition:transform .2s}details[open] .landing-faq-chevron{transform:rotate(90deg)}.landing-faq-body{color:#4a4060;border-top:1px solid #f0ebf8;padding:14px 20px 18px;font-size:.95rem;line-height:1.7}.landing-cta-banner{text-align:center;background:#3d1068;padding:72px 24px}.landing-cta-inner{flex-direction:column;align-items:center;gap:16px;max-width:640px;margin:0 auto;display:flex}.landing-cta-title{color:#fff;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800}.landing-cta-sub{color:#ffffffbf;margin-bottom:8px;font-size:1.05rem}.landing-footer{color:#ffffffbf;background:#1a1030}.landing-footer-inner{max-width:1100px;margin:0 auto;padding:48px 24px 32px}.landing-footer-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:32px;margin-bottom:40px;display:grid}.landing-footer-heading{text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;margin-bottom:14px;font-size:12px;font-weight:700}.landing-footer-links{flex-direction:column;gap:10px;list-style:none;display:flex}.landing-footer-links a{color:#ffffffb8;font-size:14px;text-decoration:none;transition:color .12s}.landing-footer-links a:hover{color:#fff}.landing-footer-copy{color:#fff6;text-align:center;border-top:1px solid #ffffff1a;padding-top:24px;font-size:13px}.landing-prose-page{max-width:680px;margin:0 auto;padding:56px 24px 80px}.landing-prose-title{color:#1a1030;margin-bottom:8px;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800}.landing-prose-meta{color:#9b8ac8;margin-bottom:40px;font-size:13px}.landing-prose-section{margin-bottom:36px}.landing-prose-section h2{color:#3d1068;margin-bottom:10px;font-size:1.15rem;font-weight:700}.landing-prose-section p{color:#4a4060;font-size:.97rem;line-height:1.75}.landing-prose-section a{color:#18b0aa;text-underline-offset:2px;text-decoration:underline}.landing-prose-section code{color:#3d1068;background:#f0ebf8;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.88em}.dark .landing-nav{background:#0e0820;border-bottom-color:#ffffff14}.dark .landing-nav-brand span{color:#9b8ac8!important}.dark .landing-section-alt{background:#130c28}.dark .landing-feature-card{background:#1a1035;border-color:#ffffff14}.dark .landing-feature-title,.dark .landing-section-title,.dark .landing-step-title{color:#e8e4f8}.dark .landing-feature-body,.dark .landing-section-sub,.dark .landing-step-body{color:#9b96b8}.dark .landing-faq-item{background:#1a1035;border-color:#ffffff14}.dark .landing-faq-summary{color:#e8e4f8}.dark .landing-faq-summary:hover{background:#231545}.dark .landing-faq-body{color:#9b96b8;border-top-color:#ffffff0f}.dark .landing-prose-page .landing-prose-title{color:#e8e4f8}.dark .landing-prose-section h2{color:#9b8ac8}.dark .landing-prose-section p{color:#9b96b8}.dark .landing-prose-section code{color:#c8b8f0;background:#231545}.selection\:bg-primary ::selection{background-color:hsl(var(--primary))}.selection\:text-primary-foreground ::selection{color:hsl(var(--primary-foreground))}.selection\:bg-primary::selection{background-color:hsl(var(--primary))}.selection\:text-primary-foreground::selection{color:hsl(var(--primary-foreground))}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:1.75rem}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive)/.9)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary)/.8)}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:border-ring:focus-visible{border-color:hsl(var(--ring))}.focus-visible\:ring-\[3px\]: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(3px + var(--tw-ring-offset-width))var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:hsl(var(--destructive)/.2)}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:hsl(var(--ring)/.5)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-left:.375rem;padding-right:.375rem}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-left:.625rem;padding-right:.625rem}.has-\[\>svg\]\:px-3:has(>svg){padding-left:.75rem;padding-right:.75rem}.has-\[\>svg\]\:px-4:has(>svg){padding-left:1rem;padding-right:1rem}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[size\=lg\]\:size-10[data-size=lg]{width:2.5rem;height:2.5rem}.data-\[size\=sm\]\:size-6[data-size=sm]{width:1.5rem;height:1.5rem}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[inset\]\:pl-8[data-inset]{padding-left:2rem}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:hsl(var(--destructive))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-name:enter;animation-duration:.15s}.data-\[state\=closed\]\:animate-out[data-state=closed]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-name:exit;animation-duration:.15s}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:.5rem}.\*\:data-\[slot\=avatar\]\:ring-2[data-slot=avatar]>*{--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),var(--tw-shadow,0 0 #0000)}.\*\:data-\[slot\=avatar\]\:ring-background[data-slot=avatar]>*{--tw-ring-color:hsl(var(--background))}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10:focus[data-variant=destructive]{background-color:hsl(var(--destructive)/.1)}.data-\[variant\=destructive\]\:focus\:text-destructive:focus[data-variant=destructive]{color:hsl(var(--destructive))}.group\/avatar[data-size=default] .group-data-\[size\=default\]\/avatar\:size-2\.5{width:.625rem;height:.625rem}.group\/avatar[data-size=lg] .group-data-\[size\=lg\]\/avatar\:size-3{width:.75rem;height:.75rem}.group\/avatar[data-size=sm] .group-data-\[size\=sm\]\/avatar\:size-2{width:.5rem;height:.5rem}.group\/avatar[data-size=sm] .group-data-\[size\=sm\]\/avatar\:text-xs{font-size:.75rem;line-height:1rem}@media (min-width:640px){.sm\:max-w-lg{max-width:32rem}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:text-left{text-align:left}}@media (min-width:768px){.md\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (prefers-color-scheme:dark){.dark\:border-input{border-color:hsl(var(--input))}.dark\:bg-destructive\/60{background-color:hsl(var(--destructive)/.6)}.dark\:bg-input\/30{background-color:hsl(var(--input)/.3)}.dark\:hover\:bg-accent\/50:hover{background-color:hsl(var(--accent)/.5)}.dark\:hover\:bg-input\/50:hover{background-color:hsl(var(--input)/.5)}.dark\:focus-visible\:ring-destructive\/40:focus-visible{--tw-ring-color:hsl(var(--destructive)/.4)}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:focus[data-variant=destructive]{background-color:hsl(var(--destructive)/.2)}}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:.75rem;height:.75rem}.\[\&\>svg\]\:size-4>svg{width:1rem;height:1rem}.group\/avatar[data-size=sm] .group-data-\[size\=sm\]\/avatar\:\[\&\>svg\]\:hidden>svg{display:none}.group\/avatar[data-size=default] .group-data-\[size\=default\]\/avatar\:\[\&\>svg\]\:size-2>svg,.group\/avatar[data-size=lg] .group-data-\[size\=lg\]\/avatar\:\[\&\>svg\]\:size-2>svg{width:.5rem;height:.5rem}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:.75rem;height:.75rem}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:1rem;height:1rem}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:hsl(var(--muted-foreground))}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}a.\[a\&\]\:hover\:bg-accent:hover{background-color:hsl(var(--accent))}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive)/.9)}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:hsl(var(--primary)/.9)}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:hsl(var(--secondary)/.9)}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}
