:root{--font-secondary: "IBM Plex Sans", sans-serif;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light dark;--surface-color: hsla(158, 30%, 88%, 1);--surface-color-10: hsla(158, 30%, 88%, .1);--surface-color-50: hsla(158, 30%, 88%, .5);--surface-color-shadow: hsla(158, 22%, 65%, .6);--surface-color-border: hsla(158, 22%, 65%, .05);--background-color: hsla(158, 28%, 93%, 1);--accent-color: hsl(24, 95%, 52%, 1);--accent-hover: hsl(24, 90%, 45%);--accent-light: hsl(24, 95%, 52%, .1);--accent-70: hsl(24, 95%, 52%, .7);--text-color: hsl(160, 10%, 18%, 1);--text-on-accent: hsl(0, 0%, 100%, 1);--highlight-color: hsl(20, 90%, 45%);--highlight-color-10: hsla(20, 90%, 45%, .1);--highlight-color-50: hsla(20, 90%, 45%, .5);--speaking-color: hsl(24, 95%, 52%);--highlight-color-shadow: hsla(20, 90%, 45%, .35);--speaking-color-shadow: hsla(24, 95%, 52%, .35);--dev-success: hsl(122, 39%, 49%);--dev-error: hsl(4, 90%, 58%);--dev-text-on-status: hsl(0, 0%, 100%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;background-color:var(--background-color);color:var(--text-color);font-family:"Instrument Serif",serif;font-weight:"regular"}a{font-weight:500;color:var(--accent-color);text-decoration:inherit}a:hover{color:var(--accent-hover)}h1{font-size:5.2rem;line-height:1.1}button{border-radius:var(--radius-md);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--accent-color);color:var(--text-on-accent);cursor:pointer;transition:border-color .25s;border:none}button:focus,button:focus-visible{outline:none}input{border-radius:var(--radius-md);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--text-color)}input:focus,input:focus-visible{outline:4px auto -webkit-focus-ring-color}.appWrapper{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:var(--background-color);color:var(--text-color)}.topBar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);width:100%}.topBarLogo{height:24px;width:auto}.topBarIcons{display:flex;gap:var(--spacing-md)}.topBarIcons button{background:none;border:none;cursor:pointer;padding:var(--spacing-sm);color:var(--text-color);display:flex;align-items:center;justify-content:center;transition:opacity .2s ease}.topBarIcons button:hover{opacity:.7}.content{position:relative;display:flex;flex-direction:row;height:100%;width:100%;overflow:hidden;padding-left:var(--spacing-xl);padding-right:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.backgroundImageWrapper{position:absolute;top:0;right:1rem;bottom:1rem;left:1rem;z-index:0;overflow:hidden;border-radius:var(--radius-xl)}.backgroundImageWrapper img{width:100%;height:100%;object-fit:cover}.backgroundImageOverlay{position:absolute;top:0;right:1rem;bottom:1rem;left:1rem;background:linear-gradient(to bottom,#ffffffb3,#ffffffe6)}.mainColumn{display:flex;flex-direction:column;flex:1;min-width:0;height:100%;overflow:hidden}.sceneWrapper{position:relative;z-index:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-items:start;align-content:start;flex:1;min-width:0;min-height:0;gap:var(--spacing-xl);padding:var(--spacing-xl);overflow:auto;mask-image:linear-gradient(to bottom,transparent,black 4rem,black calc(100% - 4rem),transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,black 4rem,black calc(100% - 4rem),transparent);scrollbar-width:none;-ms-overflow-style:none}.sceneWrapper::-webkit-scrollbar{display:none}.chatWrapper--right{position:relative;z-index:2;display:flex;flex-direction:column;width:420px;height:100%;color:var(--text-color)}.chatWrapper--center{position:absolute;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;inset:0;color:var(--text-color)}.backgroundFrame{position:absolute;top:0;right:2rem;bottom:3rem;left:2rem;z-index:0;overflow:hidden;border:none;border-radius:var(--radius-xl)}.productDetailsWrapper{position:relative;z-index:1;display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--spacing-xl);flex:1;min-height:0;padding:var(--spacing-xl);overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.content--mobileResults{flex-direction:column;padding:var(--spacing-sm);padding-bottom:0}.content--mobileResults .sceneWrapper{grid-template-columns:repeat(2,1fr);align-items:start;align-content:start;flex:1;min-height:0;height:auto;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md)!important;mask-image:linear-gradient(to bottom,transparent,black 1rem,black calc(100% - 1rem),transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,black 1rem,black calc(100% - 1rem),transparent)}.content--mobileResults .mainColumn{flex:1;min-height:0}.content--mobileResults .chatWrapper--right{width:100%;height:auto;flex-shrink:0;padding:0 var(--spacing-sm);padding-bottom:var(--spacing-sm)}.content--mobileResults .productDetailsWrapper{gap:var(--spacing-md)}.content--mobileDetails .sceneWrapper{display:none}.filterTagBar{display:flex;gap:.5rem;padding:0 calc(var(--spacing-xl) + var(--spacing-xl));flex-shrink:0;flex-wrap:wrap}.filterTag{padding:.45rem 1rem;border-radius:var(--radius-full);border:1px solid var(--border-color, #ddd);background:var(--surface-color, #fff);color:var(--text-color);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.filterTag:hover{background:var(--surface-hover, #f5f5f5)}.filterTag--active{background:var(--accent-light, rgba(235, 115, 20, .1));color:var(--accent-color);border-color:var(--accent-color)}.filterTag--active:hover{background:var(--accent-light, rgba(235, 115, 20, .1));color:var(--accent-color)}.drawerOverlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drawerContent{position:fixed;left:2rem;right:2rem;bottom:2rem;height:auto;max-height:60vh;background-color:var(--background-color);border-radius:var(--radius-xl);box-shadow:0 -4px 20px #00000026;z-index:1001;display:flex;flex-direction:column}.drawerHeader{padding:var(--spacing-lg);padding-bottom:0;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--surface-color-border)}.drawerHeader h2{font-size:1.5rem;font-weight:600;margin:0}.closeButton{background:transparent;color:var(--text-color);font-size:1.5rem;padding:var(--spacing-xs);line-height:1}.closeButton:hover{background:var(--surface-color)}.drawerBody{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.drawerBody::-webkit-scrollbar{width:6px}.drawerBody::-webkit-scrollbar-track{background:transparent}.drawerBody::-webkit-scrollbar-thumb{background-color:var(--surface-color-shadow);border-radius:var(--radius-full)}.drawerSubcopy{padding:var(--spacing-lg);padding-top:0;font-size:1.2rem;color:var(--text-color-secondary);opacity:.8}.progressiveImage{position:relative;width:100%;height:100%;overflow:hidden;background-color:var(--surface-color, #1a1a1a)}.progressiveImage__placeholder,.progressiveImage__full{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.progressiveImage__placeholder{transform:scale(1.1);z-index:1;pointer-events:none}.progressiveImage__full{z-index:2}@keyframes progressiveImage-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.progressiveImage--loading{background:linear-gradient(90deg,var(--surface-color, #1a1a1a) 25%,var(--surface-lighter, #2a2a2a) 50%,var(--surface-color, #1a1a1a) 75%);background-size:200% 100%;animation:progressiveImage-shimmer 1.5s infinite ease-in-out}.topBar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl)}.topBarLogoButton{background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;line-height:0;opacity:1;transition:opacity .3s ease}.topBarLogoButton:hover{opacity:.7}.topBarIcons{display:flex;gap:var(--spacing-sm)}.topBarIcons button{background:transparent;border:none;cursor:pointer;color:var(--text-color);padding:var(--spacing-xs);position:relative;display:flex;align-items:center;justify-content:center}.badge{position:absolute;top:-5px;right:-5px;background-color:var(--accent-color);color:#fff;font-size:.7rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.animatedButton{position:relative;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border:none;cursor:pointer;appearance:none}.animatedButton__spacer{display:grid;grid-template-areas:"stack";visibility:hidden;opacity:0;pointer-events:none;-webkit-user-select:none;user-select:none}.animatedButton__spacer>.animatedButton__label{grid-area:stack;white-space:nowrap}.animatedButton__content{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.animatedButton__textContainer{display:flex;white-space:nowrap}.animatedStatus{display:flex;align-items:center;justify-content:center;overflow:hidden}.animatedStatus__textContainer{display:flex;white-space:nowrap}.cartItem{display:flex;gap:1rem;padding:1rem;background:var(--surface-color);border-radius:var(--radius-lg);border:1px solid var(--border-color);align-items:center;position:relative}.cartItem__imageWrapper{width:80px;height:100px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;position:relative;background-color:var(--surface-hover)}.cartItem__imageWrapper img{width:100%;height:100%;object-fit:cover}.cartItem__info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.cartItem__brand{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.cartItem__title{font-size:1rem;font-weight:500;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cartItem__details{display:flex;align-items:center;gap:1rem;margin-top:.25rem;font-size:.875rem}.cartItem__size{color:var(--text-secondary)}.cartItem__size span{color:var(--text-color);font-weight:500}.cartItem__price{font-weight:600;color:var(--text-color)}.cartItem__remove{background:transparent;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.cartItem__remove:hover{background-color:var(--surface-hover);color:var(--error-color)}.cartList{display:flex;flex-direction:column;gap:var(--spacing-md);padding-bottom:var(--spacing-md)}.cartItemWrapper{position:relative}.cartTotal{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;border-top:1px solid var(--surface-color-border, #e5e5e5);margin-top:var(--spacing-xs)}.cartTotal__label{font-size:1rem;font-weight:600;color:var(--text-color)}.cartTotal__amount{font-size:1.15rem;font-weight:700;color:var(--text-color)}.productCard{position:relative;display:flex;flex-direction:column;border-radius:var(--radius-xl);color:var(--text-color);overflow:visible}.productCard:hover{cursor:pointer}.productCard--medium,.productCard--large{width:100%;height:auto}.productCard__image{position:relative;width:100%;aspect-ratio:4 / 3;height:auto;overflow:hidden;border-radius:var(--radius-xl);transition:box-shadow .2s ease}.productCard--large .productCard__image{margin-bottom:0}.productCard--medium .productCard__image{height:auto}.productCard__image img{width:100%;height:100%;object-fit:cover}.productCard__info{padding:.75rem .25rem;display:flex;flex-direction:column;gap:.25rem;text-align:left;position:relative;z-index:2}.productCard__titleRow{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.productCard__title{font-size:1rem;font-weight:600;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.productCard--large .productCard__title{font-size:1.2rem}.productCard__cookTime{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:#666;white-space:nowrap;flex-shrink:0}.productCard__description{font-size:.8rem;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.productCard__tags{position:absolute;top:8px;left:8px;display:flex;flex-wrap:wrap;gap:4px;z-index:3}.productCard__tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:#0f0f0fbf;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.productCard__badge{position:absolute;bottom:8px;left:8px;z-index:10;color:var(--highlight-color);padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-family:system-ui,Avenir,Helvetica,Arial,sans-serif}.productCard__badge--highlighted{background:var(--surface-color-50)}.productCard__badge--speaking{color:#fff;background:var(--speaking-color)}.productCard--speaking .productCard__image{animation:speakingPulse 1.2s ease-in-out infinite}@keyframes speakingPulse{0%,to{box-shadow:0 0 0 3px var(--speaking-color),0 0 1rem var(--speaking-color-shadow),0 0 1.25rem var(--speaking-color-shadow)}50%{box-shadow:0 0 0 3px var(--speaking-color),0 0 1.25rem var(--speaking-color-shadow),0 0 1.5rem var(--speaking-color-shadow)}}.cardActions{position:absolute;top:10px;right:10px;display:flex;gap:8px;z-index:2;opacity:0;transition:opacity .3s ease}.productCard:hover .cardActions{opacity:1}.actionButton{background:#ffffffe6;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;padding:0;transition:all .2s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #0000001a}.actionButton:hover{background:#fff;transform:scale(1.1);box-shadow:0 6px 16px #00000026}.actionButton:active{transform:scale(.95)}.actionButton.active{background:var(--accent-color, #ff4081);color:#fff}.productCard--grocery .productCard__image{aspect-ratio:1 / 1;background:#f8f8f8}.productCard--grocery .productCard__image img{object-fit:contain;padding:.5rem}.productCard__price{font-size:.95rem;font-weight:700;color:var(--accent-color, #2d8a4e);white-space:nowrap;flex-shrink:0}.productCard__brand{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:1280px){.cardActions{opacity:1}}.favoritesGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.emptyState{display:flex;justify-content:center;align-items:center;height:50%;color:var(--text-color);opacity:.7}.mealPlanList{display:flex;flex-direction:column;gap:var(--spacing-md);padding-bottom:1rem}.mealPlanItem{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md);background:var(--surface-color)}.mealPlanItem__imageWrapper{width:56px;height:56px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.mealPlanItem__imageWrapper img{width:100%;height:100%;object-fit:cover}.mealPlanItem__fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface-color-border)}.mealPlanItem__info{flex:1;min-width:0}.mealPlanItem__role{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 12%,transparent);padding:.1rem .4rem;border-radius:var(--radius-sm);margin-bottom:.15rem}.mealPlanItem__title{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mealPlanItem__meta{display:flex;gap:var(--spacing-sm);font-size:.75rem;color:var(--text-color-secondary);opacity:.8}.mealPlanItem__meta span+span:before{content:"·";margin-right:var(--spacing-sm)}.mealPlanItem__remove{background:transparent;color:var(--text-color-secondary);padding:var(--spacing-xs);border-radius:var(--radius-sm);flex-shrink:0;opacity:.6;transition:opacity .15s,color .15s}.mealPlanItem__remove:hover{opacity:1;color:var(--danger-color, #e74c3c)}.mealPlanActions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--surface-color-border)}.mealPlanActions__addToCart{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:.65rem 1rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--accent-color);border-radius:var(--radius-md);transition:opacity .15s}.mealPlanActions__addToCart:hover:not(:disabled){opacity:.9}.mealPlanActions__addToCart:disabled{opacity:.5;cursor:not-allowed}.mealPlanActions__clear{padding:.65rem 1rem;font-size:.85rem;font-weight:500;color:var(--text-color-secondary);background:var(--surface-color);border-radius:var(--radius-md);transition:background .15s}.mealPlanActions__clear:hover{background:var(--surface-color-border)}.mealPlanBarWrap{flex-shrink:0;padding:1rem var(--spacing-xl) 0}.mealPlanBar{background:var(--surface-color);border-radius:var(--radius-lg);overflow:hidden}.mealPlanBar__inner{padding:var(--spacing-md) var(--spacing-lg)}.mealPlanBar__label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-color-secondary);margin-bottom:var(--spacing-sm)}.mealPlanBar__dishes{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.mealPlanBar__chip{display:flex;align-items:center;gap:var(--spacing-sm);padding:.4rem .6rem;background:var(--background-color);border-radius:var(--radius-md);border:1px solid var(--surface-color-border, #e5e5e5);max-width:240px}.mealPlanBar__chipImage{width:40px;height:40px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.mealPlanBar__chipImage img{width:100%;height:100%;object-fit:cover}.mealPlanBar__chipFallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface-color-border)}.mealPlanBar__chipInfo{display:flex;flex-direction:column;min-width:0;gap:.1rem}.mealPlanBar__chipRole{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-color);line-height:1}.mealPlanBar__chipTitle{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25}.mealPlanBar__chipRemove{background:transparent;color:var(--text-color-secondary);padding:3px;border-radius:var(--radius-sm);flex-shrink:0;opacity:.4;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.mealPlanBar__chipRemove:hover{opacity:1}.recipeDetails{width:100%;height:100%;display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;mask-image:linear-gradient(to bottom,transparent,black 3rem,black calc(100% - 3rem),transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,black 3rem,black calc(100% - 3rem),transparent)}.recipeDetails::-webkit-scrollbar{display:none}.productDetails__backButton{position:sticky;top:0;left:0;background-color:var(--surface-color);color:var(--text-color);padding:.75rem 1.25rem;border-radius:var(--radius-full);font-size:.95rem;font-weight:500;z-index:100;align-self:flex-start;border:none;cursor:pointer}.recipeDetails__hero{display:flex;flex-direction:row;gap:var(--spacing-xl);align-items:flex-start}.recipeDetails__heroImage{width:30%;aspect-ratio:4 / 3;flex-shrink:0;border-radius:var(--radius-xl);overflow:hidden}.recipeDetails__heroImage img{width:100%;height:100%;object-fit:cover}.recipeDetails__headerInfo{flex:1;display:flex;flex-direction:column;gap:.5rem}.recipeDetails__tags{display:flex;flex-wrap:wrap;gap:.4rem}.recipeDetails__tag{padding:5px 12px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;background:var(--surface-color);color:var(--text-secondary, #777);border:1px solid var(--border-color, #ddd)}.recipeDetails__title{font-size:2rem;font-weight:700;line-height:1.15;margin:0;color:var(--text-color)}.recipeDetails__meta{display:flex;gap:1rem;font-size:1rem;font-weight:400;color:#888}.recipeDetails__description{font-size:1.05rem;line-height:1.6;color:#555;font-weight:400;margin:0}.recipeDetails__actions{display:flex;gap:.5rem;margin-top:.25rem}.recipeDetails__favorite{background:transparent;border:none;cursor:pointer;padding:4px;display:flex;align-items:center}.recipeDetails__body{display:flex;flex-direction:column;gap:var(--spacing-xl)}.recipeDetails__section{display:flex;flex-direction:column;gap:.75rem}.recipeDetails__sectionTitle{font-size:1.2rem;font-weight:700;margin:0;color:var(--text-color);letter-spacing:-.01em}.recipeDetails__ingredientGrid{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-start}.ingredientCard{position:relative;width:100px;display:flex;flex-direction:column;gap:.35rem;text-align:center;cursor:default;flex-shrink:0}.ingredientCard__imageWrap{position:relative;width:100px;aspect-ratio:1 / 1;border-radius:var(--radius-lg);overflow:hidden;background:#e8f5f0}.ingredientCard__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.ingredientCard__placeholder{position:absolute;inset:0;width:100%;height:100%;background:linear-gradient(135deg,#daf0e8,#c8e6da)}.ingredientCard__placeholder--shimmer,.ingredientCard--loading .ingredientCard__placeholder{animation:shimmer 1.5s ease-in-out infinite}.ingredientCard__fallback{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f0ed,#dde8e3)}@keyframes shimmer{0%,to{opacity:.6}50%{opacity:1}}.ingredientCard__addBtn{position:absolute;top:-5px;right:-5px;width:24px;height:24px;min-width:24px;min-height:24px;max-width:24px;max-height:24px;padding:0;margin:0;border-radius:50%;background:var(--accent-color, #333);border:2px solid var(--background-color, #fff);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:0;transition:transform .15s ease;z-index:3;box-shadow:0 1px 4px #00000026;aspect-ratio:1 / 1}.ingredientCard__addBtn:hover{transform:scale(1.15)}.ingredientCard__name{font-size:.9rem;font-weight:400;color:var(--text-color);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.ingredientCard__price{font-size:.9rem;font-weight:600;color:var(--text-color)}.ingredientCard__addAllButton{cursor:pointer;border:none;background:none;padding:0}.ingredientCard__addAllButton .ingredientCard__name{font-weight:500;color:var(--accent-color, #eb7314)}.ingredientCard__addAllIcon{width:100%;aspect-ratio:1 / 1;border-radius:var(--radius-lg);background:var(--accent-color, #eb7314);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #eb73144d}.ingredientCard__addAllButton:hover .ingredientCard__addAllIcon{filter:brightness(1.1);box-shadow:0 4px 12px #eb731466;transform:translateY(-1px)}.recipeDetails__columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.recipeDetails__ingredientTable{width:100%;border-collapse:collapse;font-size:1rem}.recipeDetails__ingredientTable th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid #ddd;font-weight:600;color:#333;font-size:.9rem;text-transform:uppercase;letter-spacing:.03em}.recipeDetails__ingredientTable td{padding:.6rem .75rem;border-bottom:1px solid #eee;color:#555;font-weight:400}.recipeDetails__ingredientTable td strong{font-weight:500;color:#333}.recipeDetails__ingredientTable td:first-child,.recipeDetails__ingredientTable th:first-child{width:2rem;color:#aaa;font-weight:400}.recipeDetails__steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.recipeDetails__step{display:flex;gap:.75rem;align-items:flex-start;font-size:1rem;line-height:1.6;color:#444;font-weight:400}.recipeDetails__stepNumber{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--accent-color, #333);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.recipeDetails__swapBanner{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--surface-color-10, hsla(158, 30%, 88%, .1));border-radius:var(--radius-lg, 8px);font-size:.78rem;color:#777;line-height:1.5}.recipeDetails__swapBanner s{color:#aaa;text-decoration:line-through}.recipeDetails__swapBanner strong{color:#444;font-weight:600}.recipeDetails__swapBannerIcon{font-size:.9rem;flex-shrink:0;opacity:.5}.recipeDetails__ingredientRow--swapped{background:var(--surface-color-10, hsla(158, 30%, 88%, .15))}.recipeDetails__swappedIngredient{display:flex;flex-direction:column;gap:.1rem}.recipeDetails__originalIngredient{color:#bbb;font-size:.75em;text-decoration:line-through;font-weight:400}.recipeDetails__newIngredient{font-weight:600;color:#333}.groceryDetails__hero{display:flex;gap:var(--spacing-lg, 1.5rem);align-items:flex-start}.groceryDetails__heroImage{width:280px;flex-shrink:0;aspect-ratio:1 / 1;border-radius:var(--radius-xl, 12px);overflow:hidden;background:#f8f8f8}.groceryDetails__heroImage img{width:100%;height:100%;object-fit:contain;padding:1rem}.groceryDetails__headerInfo{flex:1;display:flex;flex-direction:column;gap:.5rem}.groceryDetails__price{font-size:1.8rem;font-weight:700;color:var(--accent-color, #2d8a4e)}.groceryDetails__brand{font-size:.9rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.groceryDetails__actions{display:flex;align-items:center;gap:.75rem;margin-top:.75rem}.groceryDetails__addToCart{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border:none;border-radius:var(--radius-full, 50px);background:var(--accent-color, #2d8a4e);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.groceryDetails__addToCart:hover{filter:brightness(1.1);transform:scale(1.02)}.groceryDetails__addToCart:active{transform:scale(.98)}@media(max-width:1280px){.recipeDetails{gap:var(--spacing-md)}.recipeDetails__hero,.groceryDetails__hero{flex-direction:column}.recipeDetails__heroImage{width:100%;aspect-ratio:16 / 9}.groceryDetails__heroImage{width:100%;max-width:300px}.recipeDetails__title{font-size:1.4rem}.recipeDetails__columns{grid-template-columns:1fr}}.loadingStateCard{width:100%;height:100%;overflow:hidden;border-radius:var(--radius-xl);background:linear-gradient(to bottom,var(--surface-color),var(--background-color),var(--surface-color));background-size:100% 200%;animation:loadingStateCardAnimation 2s linear infinite;opacity:0}@keyframes loadingStateCardAnimation{0%{background-position:0% 0%}to{background-position:0% 200%}}.chatProductLink{color:var(--text-on-accent);cursor:pointer;text-decoration:none;background-color:var(--accent-70);padding:1px 6px;border-radius:.25rem;white-space:nowrap;opacity:1;font-style:italic}.chatProductLink:hover{background-color:var(--accent-color)}.chatMessageContent{width:100%;height:100%;text-align:center}.chatMessage{width:100%;padding:var(--spacing-md);border-radius:var(--radius-xl);display:flex;flex-direction:column;font-size:1.4rem;max-width:480px}.chatMessage--small{font-size:1.2rem}.chatMessage--user{align-items:flex-end}.chatMessage--assistant{align-items:flex-start}.chatSurface{position:relative;display:flex;flex-direction:column;align-items:center;height:100%;max-width:100%;background:var(--background-color);padding:var(--spacing-md);gap:var(--spacing-md);overflow:hidden}.chatMotionProtector{position:relative;width:100%;height:100%;overflow:auto}.chatAvatar{position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-full);background-color:transparent}.chatAvatar img{width:100%;height:100%;object-fit:cover;display:block}.chatAvatar__overlay{position:absolute;inset:0;opacity:var(--audio-overlay-opacity, 0);transform:scale(var(--audio-overlay-scale, 1));pointer-events:none;transition:all .15s ease;filter:hue-rotate(120deg)}.chatAvatar__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;border-radius:var(--radius-full);z-index:1}.chatAvatar__video--active{opacity:1}.chatAvatar--video{overflow:hidden}.chatAvatar__connecting{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:2}.chatAvatar__connectingDot{width:12px;height:12px;background:var(--accent-color);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.chatMessages{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);width:100%;height:100%;overflow:auto}.chatFooter{position:absolute;bottom:0;left:0;right:0;width:100%;height:8rem;background:linear-gradient(to top,var(--background-color),var(--background-color) 50%,transparent 100%,transparent);display:flex;justify-content:center;align-items:center}.chatFooter__micButton{width:4rem;height:4rem;border-radius:var(--radius-full);background-color:var(--accent-color);color:var(--text-on-accent);display:flex;justify-content:center;align-items:center}.startShoppingButton{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;font-size:1.2rem;background:#b8e0d2;color:var(--text-color);border-radius:var(--radius-full);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:300;outline:none;border:none}.samplePrompts{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%;max-width:500px;padding-bottom:6rem}.samplePromptButton{padding:.875rem 1.125rem;font-size:1rem;font-weight:300;color:var(--text-color);background:transparent;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease;text-align:center;outline:none;line-height:1.4;white-space:normal}.samplePromptButton--wide{grid-column:1 / -1}.samplePromptButton:hover:not(:disabled){background:#0000000d;border-color:#0000004d}.samplePromptButton:active:not(:disabled){transform:scale(.98);background:#00000014}.samplePromptButton:disabled{opacity:.4;cursor:not-allowed}.agentStatus{font-size:.875rem;color:var(--text-color);opacity:.5;text-align:center;letter-spacing:.05em;text-transform:uppercase;background-color:var(--surface-color);padding:.25rem .5rem;border-radius:.5rem}.chatAvatar__blurOverlay{position:absolute;border-radius:999px;overflow:hidden;inset:0;background:#deede88c;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);opacity:1;pointer-events:none;transition:all .15s ease;box-shadow:inset 0 8px 24px -1px #ffffffe6,inset 0 -2px 2px #0000001a}.chatSurface--compact{flex-direction:column;align-items:center;gap:0;padding:0 var(--spacing-lg) var(--spacing-md);height:auto!important;overflow:visible;position:relative;background-color:var(--background-color);border-radius:var(--radius-xl);box-shadow:0 -4px 20px #00000026}.chatSurface--compact .chatAvatar{flex-shrink:0;position:relative;z-index:2;margin-top:-1.5rem}.chatSurface--compact .chatMessages{width:100%;height:auto;overflow:hidden;min-width:0;gap:var(--spacing-xs);padding:var(--spacing-xs) 0}.chatSurface--compact .chatMessage{font-size:.95rem;padding:var(--spacing-xs) 0;max-width:none;text-align:center}.chatSurface--compact .chatFooter{position:relative;width:auto;height:auto;background:none;flex-shrink:0;padding-top:var(--spacing-xs)}.chatSurface--compact .chatFooter__micWrapper{padding:0}.chatSurface--compact .chatFooter__micButton{width:3rem;height:3rem}.chatSurface--compact .agentStatus{font-size:.75rem;padding:.15rem .4rem}.devPanel{position:fixed;bottom:20px;left:20px;z-index:9999;background:#1e1e23f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006;color:#fff;font-family:Inter,sans-serif;display:flex;flex-direction:column;max-height:90vh}.devPanel--collapsed{width:48px;height:48px;border-radius:50%;padding:0}.devPanel--expanded{width:320px;height:auto;border-radius:16px;padding:16px}.devPanel__header{display:flex;align-items:center;width:100%;cursor:pointer}.devPanel__header--collapsed{justify-content:center;height:100%}.devPanel__header--expanded{justify-content:space-between;margin-bottom:16px}.devPanel__title{display:flex;align-items:center;gap:8px;font-weight:600}.devPanel__content{display:flex;flex-direction:column;gap:16px;flex:1;padding-right:4px;height:100%;overflow-y:auto}.devPanel__tabs{display:flex;gap:.5rem;background:#ffffff0d;padding:4px;border-radius:8px;position:sticky;top:0}.devPanel__tab{flex:1;display:flex;justify-content:center;font-size:12px;font-weight:500}.devPanel__tab--active{background:#ffffff26!important}.devSection{background:#0003;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.devSection__title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;opacity:.5;margin-bottom:8px;display:flex;align-items:center;gap:6px}.devSection__title--spaced{display:flex;justify-content:space-between}.devGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.devRow{display:flex;gap:.5rem}.devRow--mt{margin-top:8px}.devPanel button{background:#ffffff0d;border:none;border-radius:6px;color:#fff;padding:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px}.devPanel button:hover{background:#ffffff1a}.devPanel button.active{background:#eb731499;color:#fff}.devPanel button.danger{color:#f87171}.devPanel button.danger:hover{background:#f871711a}.devPanel button:disabled{opacity:.3;cursor:not-allowed}.devInput{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px;color:#fff;font-size:12px;outline:none}.devInput:focus{border-color:#eb731480}.devInput--flex{flex:1}.devInput--narrow{width:60px}.devCodeBlock{background:#0000004d;padding:8px;border-radius:4px;overflow-wrap:break-word;white-space:pre-wrap}.devTimings{display:flex;flex-direction:column;gap:8px;font-size:12px}.devTimings__row{display:flex;justify-content:space-between;align-items:center}.devTimings__label{opacity:.7}.devTimings__value{font-weight:400;color:#fff}.devTimings__value--highlight{font-weight:700;color:#fb923c}.devTimings__divider{height:1px;background:#ffffff1a;margin:4px 0}.devTimings__event{display:flex;justify-content:space-between;align-items:center;font-size:10px;opacity:.5}.devDebug{min-height:200px;max-height:500px;display:flex;flex-direction:column}.devDebug__traceList{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.devDebug__empty{padding:20px;text-align:center;opacity:.5;font-size:12px}.devDebug__transcript{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.devDebug__transcriptText{font-size:11px}.devDebug__transcriptText--empty{color:#ffffff4d}.devDebug__transcriptText--filled{color:#10b981}.devStatus{font-size:11px;margin-top:4px;opacity:.7}.devStatus--error{color:#f87171;opacity:1}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.authPage{min-height:100vh;width:100%;display:grid;place-items:center;padding:var(--spacing-xl);background-color:var(--background-color);animation:auth-fade-in .24s ease-out}.authCard{width:min(480px,100%);background:var(--surface-color-50);border:1px solid var(--surface-color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md);text-align:center;transform-origin:center;animation:auth-card-in .36s cubic-bezier(.2,.8,.2,1)}.authTitle{font-size:2.2rem;line-height:1.1}.authSubtitle{font-family:var(--font-secondary);color:var(--text-color)}.authButton{margin-top:var(--spacing-sm);transition:transform .18s ease,opacity .18s ease}.authButton:hover:not(:disabled){transform:translateY(-1px)}.authButton:disabled{opacity:.7;cursor:wait}.authCard--status .authSubtitle{opacity:.9}.authProgress{position:relative;width:100%;height:8px;margin-top:var(--spacing-xs);border-radius:var(--radius-pill);background:var(--surface-color-100);overflow:hidden}.authProgress:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--surface-color-active);transform:translate(-60%);animation:auth-progress 1.1s ease-in-out infinite}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}@keyframes auth-card-in{0%{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes auth-progress{0%{transform:translate(-60%)}to{transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.authPage,.authCard,.authProgress:after,.authButton{animation:none;transition:none}}
