.header{background:var(--pastel-mint);color:var(--pastel-text-dark);padding:20px 48px;margin:0;box-shadow:0 2px 12px #00000014;position:relative;border-radius:0;border:none;border-bottom:2px solid var(--pastel-gray-border)}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:100%;position:relative;z-index:1;gap:24px}.header-brand{display:flex;align-items:center;gap:20px;flex:1}.header-icon-wrapper{width:64px;height:64px;background:var(--pastel-green);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);transition:all .3s ease}.header-icon-wrapper:hover{transform:scale(1.05);box-shadow:var(--shadow-medium);background:var(--pastel-green-light)}.header-icon-wrapper i{font-size:28px;color:var(--pastel-text-dark)}.header-text{display:flex;flex-direction:column;gap:6px}.header h1{font-size:clamp(28px,4vw,36px);margin:0;font-weight:600;letter-spacing:-.5px;color:var(--pastel-text-dark);font-family:Poppins,sans-serif;line-height:1.2}.header p{margin:0;font-size:clamp(14px,2vw,16px);font-weight:400;color:var(--pastel-text);font-family:Inter,sans-serif;line-height:1.5}.header-user{display:flex;align-items:center;gap:16px;flex-shrink:0}.theme-toggle-button{width:48px;height:48px;border:none;background:var(--pastel-gray-light);border-radius:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-soft);color:var(--pastel-text-dark);font-size:20px;border:1px solid var(--pastel-gray-border)}.theme-toggle-button:hover{background:var(--pastel-green-light);transform:scale(1.05) rotate(15deg);box-shadow:var(--shadow-medium);color:var(--pastel-green-dark)}.theme-toggle-button:active{transform:scale(.98) rotate(15deg)}.dark-mode .theme-toggle-button{background:var(--pastel-gray);color:var(--pastel-yellow-dark)}.dark-mode .theme-toggle-button:hover{background:var(--pastel-gray-border);color:var(--pastel-yellow-dark)}.user-info-card{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--pastel-gray-light);border-radius:20px;box-shadow:var(--shadow-soft);transition:all .3s ease}.user-info-card:hover{background:var(--pastel-mint);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.user-info-card i{font-size:20px;color:var(--pastel-green-dark)}.user-email{font-size:14px;font-weight:500;color:var(--pastel-text-dark);font-family:Inter,sans-serif}.logout-button{display:flex;align-items:center;gap:8px;background:var(--pastel-pink);color:var(--pastel-text-dark);border:none;padding:12px 24px;border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow-soft);font-family:Inter,sans-serif}.logout-button:hover{background:var(--pastel-pink-dark);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.logout-button:active{transform:translateY(0)}.logout-button i,.logout-button span{font-size:14px}@media(max-width:1024px){.header{padding:18px 32px;margin:0;border-radius:0}.header-icon-wrapper{width:56px;height:56px;border-radius:18px}.header-icon-wrapper i{font-size:24px}}@media(max-width:768px){.header{padding:16px 24px;margin:0;border-radius:0}.header-content{flex-direction:column;align-items:flex-start;gap:20px}.header-brand{width:100%}.header-icon-wrapper{width:52px;height:52px;border-radius:16px;flex-shrink:0}.header-icon-wrapper i{font-size:22px}.header-text{flex:1;min-width:0}.header h1{font-size:24px}.header p{font-size:13px}.header-user{width:100%;justify-content:space-between}.user-info-card{flex:1;min-width:0;padding:10px 16px}.user-email{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-button{padding:10px 20px;font-size:13px}}@media(max-width:480px){.header{padding:14px 20px;margin:0}.header-icon-wrapper{width:48px;height:48px}.header-icon-wrapper i{font-size:20px}.header h1{font-size:22px}.header p{font-size:12px}.user-info-card{padding:8px 12px}.user-info-card i{font-size:18px}.user-email{font-size:12px}.logout-button{padding:8px 16px;font-size:12px}.logout-button span{display:none}}.logout-button:focus-visible{outline:3px solid var(--pastel-green);outline-offset:3px;border-radius:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.header{animation:fadeIn .4s ease}.landing{min-height:100vh;min-height:100dvh;background:var(--pastel-gray-light);color:var(--pastel-text-dark)}.landing-hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:max(16px,env(safe-area-inset-top)) max(24px,env(safe-area-inset-right)) max(32px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));box-sizing:border-box}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:12px 0 24px;flex-shrink:0}.landing-logo{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:700;color:var(--pastel-green-dark);letter-spacing:-.5px}.landing-nav-actions{display:flex;align-items:center;gap:12px}.landing-theme-toggle{width:44px;height:44px;border:2px solid var(--pastel-gray-border);border-radius:14px;background:var(--card-bg);color:var(--pastel-text-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .25s ease;-webkit-tap-highlight-color:transparent}.landing-theme-toggle:hover{border-color:var(--pastel-green);background:var(--pastel-mint);color:var(--pastel-green-dark)}.landing-nav-cta{background:transparent;border:2px solid var(--pastel-gray-border);color:var(--pastel-text-dark);padding:10px 20px;border-radius:16px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .25s ease;-webkit-tap-highlight-color:transparent}.landing-nav-cta:hover{border-color:var(--pastel-green);background:var(--pastel-mint)}.landing-hero-content{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:640px;margin:0 auto;width:100%}.landing-headline{font-family:Poppins,sans-serif;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.15;letter-spacing:-.5px;color:var(--pastel-text-dark);margin-bottom:12px}.landing-subheadline{font-size:clamp(1rem,2.2vw,1.25rem);line-height:1.55;color:var(--pastel-text);margin-bottom:20px;max-width:520px}.landing-cta-primary{align-self:flex-start;background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-green-light) 100%);color:var(--pastel-text-dark);border:none;padding:12px 24px;border-radius:18px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-soft);-webkit-tap-highlight-color:transparent}.landing-cta-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-medium);background:linear-gradient(135deg,var(--pastel-green-light) 0%,var(--pastel-green) 100%)}.landing-cta-large{padding:14px 32px;font-size:1.15rem}.landing-hero-visual{margin-top:28px;flex-shrink:0}.landing-visual-mock{background:var(--card-bg);border:2px solid var(--pastel-gray-border);border-radius:20px;padding:20px 24px;box-shadow:var(--shadow-soft)}.landing-visual-label{display:block;font-size:.9rem;color:var(--pastel-text);margin-bottom:10px;text-align:center}.landing-visual-placeholder{display:flex;align-items:center;justify-content:center;gap:16px;min-height:80px}.landing-visual-icon{font-size:3rem}.landing-visual-arrow{font-size:1.5rem;color:var(--pastel-green-dark)}.landing-section{padding:40px max(24px,env(safe-area-inset-right)) 40px max(24px,env(safe-area-inset-left));max-width:900px;margin:0 auto}.landing-section-title{font-family:Poppins,sans-serif;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--pastel-text-dark);margin-bottom:20px;text-align:center}.landing-pain{background:var(--surface-bg)}.landing-pain-intro{text-align:center;font-size:1.05rem;line-height:1.55;color:var(--pastel-text);max-width:520px;margin:0 auto 16px}.landing-stats{list-style:none;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.landing-stat{background:var(--card-bg);border-radius:18px;padding:20px 22px;border:1px solid var(--pastel-gray-border);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px}.landing-stat-icon{font-size:2rem}.landing-stat-value{font-family:Poppins,sans-serif;font-size:1.75rem;font-weight:700;color:var(--pastel-green-dark)}.landing-stat-desc{font-size:.95rem;color:var(--pastel-text);line-height:1.5}.landing-steps{list-style:none;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.landing-step{background:var(--card-bg);border-radius:18px;padding:44px 22px 20px;border:1px solid var(--pastel-gray-border);box-shadow:var(--shadow-soft);position:relative}.landing-step-num{position:absolute;top:16px;left:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--pastel-green);color:var(--pastel-text-dark);font-family:Poppins,sans-serif;font-weight:700;font-size:1.1rem;border-radius:12px}.landing-step-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:600;color:var(--pastel-text-dark);margin-bottom:6px}.landing-step-desc{font-size:.95rem;color:var(--pastel-text);line-height:1.5}.landing-features{background:var(--surface-bg)}.landing-features-core{background:var(--pastel-gray-light)}.landing-features-core .landing-feature{border-color:var(--pastel-green);box-shadow:var(--shadow-soft)}.landing-feature-list{list-style:none;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.landing-feature{background:var(--card-bg);border-radius:18px;padding:20px 22px;border:1px solid var(--pastel-gray-border);box-shadow:var(--shadow-soft)}.landing-feature-icon{font-size:1.75rem;display:block;margin-bottom:8px}.landing-feature-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600;color:var(--pastel-text-dark);margin-bottom:6px}.landing-feature-desc{font-size:.95rem;color:var(--pastel-text);line-height:1.5}.landing-social{text-align:center}.landing-social-stats{font-size:1.2rem;font-weight:600;color:var(--pastel-green-dark);margin-bottom:12px}.landing-social-numbers{list-style:none;max-width:480px;margin:0 auto 20px;text-align:left;font-size:.98rem;color:var(--pastel-text);line-height:1.6}.landing-social-numbers li{margin-bottom:8px;padding-left:1.5em;position:relative}.landing-social-numbers li:before{content:"✓";position:absolute;left:0;color:var(--pastel-green-dark);font-weight:700}.landing-social-numbers strong{color:var(--pastel-text-dark)}.landing-testimonial{max-width:560px;margin:0 auto;background:var(--card-bg);border-radius:18px;padding:22px 24px;border:1px solid var(--pastel-gray-border);box-shadow:var(--shadow-soft)}.landing-testimonial-text{font-size:1.02rem;line-height:1.55;color:var(--pastel-text-dark);margin-bottom:10px;font-style:italic}.landing-testimonial-author{font-size:.95rem;color:var(--pastel-text)}.landing-final-cta{background:var(--surface-bg);text-align:center;padding-top:48px;padding-bottom:48px}.landing-final-headline{font-family:Poppins,sans-serif;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:700;color:var(--pastel-text-dark);margin-bottom:20px;max-width:520px;margin-left:auto;margin-right:auto}.landing-final-note{margin-top:16px;font-size:.95rem;color:var(--pastel-text)}.landing-link{background:none;border:none;color:var(--pastel-green-dark);font-weight:600;text-decoration:underline;cursor:pointer;padding:4px 8px;font-size:inherit;-webkit-tap-highlight-color:transparent}.landing-link:hover{color:var(--pastel-green)}.login-container{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;padding:max(20px,env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left));box-sizing:border-box}.login-back{position:absolute;top:max(20px,env(safe-area-inset-top));left:max(20px,env(safe-area-inset-left));background:none;border:none;color:var(--pastel-green-dark);font-size:.95rem;font-weight:600;cursor:pointer;padding:8px 12px;-webkit-tap-highlight-color:transparent}.login-back:hover{color:var(--pastel-green);text-decoration:underline}.login-theme-toggle{position:absolute;top:max(20px,env(safe-area-inset-top));right:max(20px,env(safe-area-inset-right));width:44px;height:44px;border:2px solid var(--pastel-gray-border);border-radius:14px;background:var(--card-bg);color:var(--pastel-text-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;-webkit-tap-highlight-color:transparent}.login-theme-toggle:hover{border-color:var(--pastel-green);background:var(--pastel-mint);color:var(--pastel-green-dark)}.login-box{background:var(--card-bg);border-radius:24px;padding:32px 24px;box-shadow:var(--shadow-soft);max-width:420px;width:100%;border:1px solid var(--pastel-gray-border);box-sizing:border-box}@media(min-width:480px){.login-box{padding:48px}}.login-box h2{text-align:center;color:var(--olive-green-dark);margin-bottom:32px;font-size:2.2em;font-weight:700;letter-spacing:-.5px}.login-box .form-group{margin-bottom:20px}.login-box label{display:block;margin-bottom:8px;color:var(--pastel-text-dark);font-weight:500}.login-box input{width:100%;min-height:48px;padding:12px 16px;border:2px solid var(--pastel-gray-border);border-radius:12px;font-size:1em;font-family:inherit;background:var(--pastel-mint);color:var(--pastel-text-dark);box-sizing:border-box;-webkit-appearance:none;appearance:none}.login-box input:focus{outline:none;border-color:var(--pastel-green);box-shadow:0 0 0 3px #b8e6b833;background:var(--card-bg)}.dark-mode .login-box input:focus{box-shadow:0 0 0 3px #4a7c5966}.login-box button[type=submit]{width:100%;min-height:52px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:12px;box-shadow:var(--shadow-soft);letter-spacing:.3px;-webkit-tap-highlight-color:transparent}.login-box button[type=submit]:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-medium);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);color:var(--pastel-text-dark)}.login-box button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.switch-mode{text-align:center;margin-top:20px;color:var(--pastel-text)}.link-button{background:none;border:none;color:var(--pastel-green-dark);cursor:pointer;text-decoration:underline;font-size:inherit;font-weight:600;transition:color .3s ease;min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;margin:-8px -12px;-webkit-tap-highlight-color:transparent}.link-button:hover{color:var(--pastel-green)}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:var(--pastel-text);font-size:.9em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--pastel-gray-border)}.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:52px;padding:14px 20px;border:2px solid var(--pastel-gray-border);border-radius:12px;font-size:1em;font-weight:600;color:var(--pastel-text-dark);background:var(--card-bg);text-decoration:none;cursor:pointer;transition:all .2s ease;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.social-btn:hover{border-color:var(--pastel-green);background:var(--pastel-mint)}.social-google:hover{border-color:#4285f4;background:#f8f9fa}.dark-mode .social-google:hover{border-color:#5a9cf5;background:#2a3a4a}.social-icon{flex-shrink:0}.login-box .success{margin-top:12px;padding:12px 16px;background:#f0fdf4;color:#166534;border-radius:10px;font-size:.95em;border:1px solid #bbf7d0}.dark-mode .login-box .success{background:#4a7c5959;color:var(--pastel-green-dark);border-color:var(--pastel-green)}.login-box .error{margin-top:12px;padding:12px 16px;background:#fef2f2;color:#b91c1c;border-radius:10px;font-size:.95em;border:1px solid #fecaca}.dark-mode .login-box .error{background:var(--pastel-red-light);color:var(--pastel-error);border-color:var(--pastel-pink-dark)}.meal-detail-overlay{position:fixed;inset:0;z-index:1000;display:flex;justify-content:flex-end;align-items:stretch;pointer-events:auto;animation:overlayFadeIn .25s ease-out forwards}.meal-detail-backdrop{position:absolute;inset:0;background:#0000001f;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);cursor:pointer;animation:backdropFadeIn .25s ease-out forwards}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.meal-detail-side-panel{position:relative;width:480px;max-width:100%;height:100%;max-height:100vh;margin:12px 0;border-radius:24px 0 0 24px;background:var(--card-bg);border-left:1px solid var(--pastel-gray-border);box-shadow:-8px 0 32px #00000014,-2px 0 12px #0000000a;display:flex;flex-direction:column;overflow:hidden;font-family:Inter,Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:slideInRightSmooth .35s cubic-bezier(.32,.72,0,1) forwards;backface-visibility:hidden;-webkit-font-smoothing:antialiased;overscroll-behavior:contain;contain:layout style paint;-webkit-transform:translateZ(0);transform:translateZ(0)}@media(max-width:1024px){.meal-detail-side-panel{width:400px;margin:8px 0;border-radius:20px 0 0 20px}}@media(max-width:768px){.meal-detail-side-panel{width:100%;max-width:100%;margin:auto 0 0;border-radius:20px 20px 0 0;max-height:92vh}}@keyframes slideInRightSmooth{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.meal-detail-panel-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior-y:contain;scrollbar-width:thin;scrollbar-color:var(--pastel-gray) transparent;contain:layout style}.meal-detail-hero{width:100%;height:400px;flex-shrink:0;background:var(--pastel-gray-light);position:relative}.meal-detail-hero-image{width:100%;height:100%;object-fit:cover;display:block}.meal-detail-panel-content::-webkit-scrollbar{width:8px}.meal-detail-panel-content::-webkit-scrollbar-track{background:transparent}.meal-detail-panel-content::-webkit-scrollbar-thumb{background:var(--pastel-gray);border-radius:20px}.meal-detail-panel-content::-webkit-scrollbar-thumb:hover{background:var(--pastel-green)}.meal-detail-panel-header{padding:16px;position:absolute;top:0;right:0;z-index:20;display:flex;justify-content:flex-end;background:transparent;border:none;box-shadow:none}.meal-detail-close{width:40px;height:40px;background:#fffffff2;border-radius:50%;font-size:18px;line-height:1;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 12px #00000026;border:none}.meal-detail-close i{font-size:18px}.meal-detail-close:hover{background:var(--pastel-pink-light);color:var(--pastel-text-dark);transform:scale(1.05);box-shadow:0 4px 12px #00000014}.meal-detail-close:active{transform:scale(.98);transition:transform .1s ease}.meal-detail-header{padding:32px 32px 28px;background:var(--card-bg);margin-bottom:8px}.meal-detail-type-badge{display:inline-block;background:var(--pastel-green);color:var(--white);padding:10px 24px;border-radius:28px;font-size:12px;font-weight:600;font-family:Poppins,Inter,sans-serif;text-transform:uppercase;margin-bottom:20px;letter-spacing:.8px;box-shadow:0 2px 8px #4caf5026;border:1px solid rgba(255,255,255,.2)}.meal-detail-name{margin:0 0 16px;color:var(--pastel-text-dark);font-size:clamp(26px,5vw,32px);font-weight:600;font-family:Poppins,Inter,sans-serif;line-height:1.4;letter-spacing:-.02em}.meal-detail-date{color:var(--pastel-text);font-size:15px;font-weight:500}.meal-detail-content{padding:40px 32px 48px;background:transparent}.meal-detail-section{margin-bottom:40px;background:var(--pastel-gray-light);padding:28px 32px;border-radius:32px;border:1px solid var(--pastel-gray-border);box-shadow:0 2px 12px #00000008;transition:all .3s cubic-bezier(.16,1,.3,1)}.meal-detail-section:hover{box-shadow:0 4px 16px #0000000d;transform:translateY(-2px)}.meal-detail-section:last-child{margin-bottom:0}.meal-detail-section-title{display:flex;align-items:center;gap:14px;margin:0 0 24px;color:var(--pastel-text-dark);font-size:20px;font-weight:600;font-family:Poppins,Inter,sans-serif;padding-bottom:16px;border-bottom:1px solid var(--pastel-gray-border);letter-spacing:-.01em}.section-icon{font-size:20px;display:inline-flex;align-items:center}.section-icon i{font-size:20px;color:var(--pastel-green-dark)}.ingredients-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.ingredient-item{display:flex;justify-content:space-between;align-items:center;background:var(--pastel-mint);padding:20px 24px;border-radius:28px;transition:all .3s cubic-bezier(.16,1,.3,1);border:1px solid var(--pastel-gray-border);box-shadow:0 2px 8px #0000000a;margin-bottom:12px}.ingredient-item:hover{background:var(--pastel-mint);border-color:var(--pastel-green);transform:translateY(-3px);box-shadow:0 6px 16px #4caf501f}.ingredient-name{font-size:16px;color:var(--pastel-text-dark);font-weight:500;font-family:Inter,sans-serif;flex:1;letter-spacing:-.01em}.ingredient-quantity{font-size:15px;color:var(--pastel-text-dark);font-weight:600}.meal-detail-section--missing{border-color:var(--pastel-amber-border, #f5d0a9);background:linear-gradient(135deg,var(--pastel-amber-light, #fef3e2) 0%,rgba(255,255,255,.6) 100%)}.dark-mode .meal-detail-section--missing{border-color:var(--pastel-amber-border);background:linear-gradient(135deg,var(--pastel-amber-light) 0%,var(--card-bg) 100%)}.dark-mode .meal-detail-section--missing .meal-detail-section-title{color:var(--pastel-text-dark)}.dark-mode .meal-detail-section--missing .section-icon i{color:var(--pastel-yellow-dark)}.meal-detail-missing-intro{margin-top:8px;margin-bottom:12px;font-size:14px;color:var(--pastel-text)}.dark-mode .meal-detail-missing-intro{color:var(--pastel-text)}.meal-detail-missing-list{list-style:none;padding-left:0;margin:0}.ingredient-item--missing{background:#fff3e2cc;border:1px solid var(--pastel-amber-border, #f5d0a9)}.dark-mode .ingredient-item--missing{background:var(--pastel-amber-light);border-color:var(--pastel-amber-border)}.dark-mode .ingredient-item--missing .ingredient-name,.dark-mode .ingredient-item--missing .ingredient-quantity{color:var(--pastel-text-dark)}.ingredient-tag{background:var(--pastel-green-light);color:var(--pastel-text-dark);padding:10px 18px;border-radius:20px;font-size:14px;font-weight:500;border:none;box-shadow:0 2px 6px #0000000a;transition:all .3s ease}.ingredient-tag:hover{background:var(--pastel-green);transform:translateY(-2px);box-shadow:0 4px 10px #00000014}.meal-detail-instructions{background:transparent;padding:0;border-radius:0;line-height:1.9;color:var(--pastel-text-dark)}.meal-detail-instructions p{margin:0 0 16px;font-size:16px;font-family:Inter,sans-serif;line-height:1.9;padding:18px 24px 18px 28px;border-left:4px solid var(--pastel-green);background:var(--pastel-mint);border-radius:0 24px 24px 0;box-shadow:0 2px 8px #0000000a;transition:all .3s cubic-bezier(.16,1,.3,1)}.meal-detail-instructions p:hover{background:var(--pastel-mint);transform:translate(4px);box-shadow:0 4px 12px #4caf501a}.meal-detail-instructions p:last-child{margin-bottom:0}.meal-detail-instructions .instruction-step{font-weight:500;color:var(--pastel-text-dark)}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-top:8px}.nutrition-item{background:var(--pastel-mint);padding:24px 20px;border-radius:28px;text-align:center;border:1px solid var(--pastel-gray-border);transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #0000000a}.nutrition-item:hover{background:var(--pastel-mint);border-color:var(--pastel-green);transform:translateY(-3px);box-shadow:0 6px 16px #4caf501f}.nutrition-label{font-size:12px;color:var(--pastel-text);margin-bottom:10px;font-weight:600;font-family:Poppins,Inter,sans-serif;text-transform:uppercase;letter-spacing:.8px}.nutrition-value{font-size:26px;font-family:Poppins,Inter,sans-serif;font-weight:600;color:var(--pastel-text-dark);letter-spacing:-.02em}.feedback-buttons{display:flex;gap:12px}.feedback-btn{flex:1;padding:18px 28px;border:1px solid var(--pastel-gray-border);background:var(--pastel-mint);border-radius:28px;cursor:pointer;font-size:15px;font-weight:500;font-family:Inter,sans-serif;color:var(--pastel-text-dark);transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 2px 8px #0000000a}.feedback-btn:hover{transform:translateY(-3px);box-shadow:0 6px 16px #00000014}.feedback-btn.like-btn:hover{background:var(--pastel-green-light)}.feedback-btn.dislike-btn:hover{background:var(--pastel-pink)}.feedback-btn.like-btn.active{background:var(--pastel-green);color:var(--pastel-text-dark)}.feedback-btn.dislike-btn.active{background:var(--pastel-pink-dark);color:var(--pastel-text-dark)}.feedback-icon{font-size:18px;display:inline-flex;align-items:center}.feedback-icon i{font-size:18px}.log-meal-section{background:linear-gradient(135deg,var(--pastel-green-light) 0%,var(--pastel-mint) 100%);border-radius:32px;padding:28px 32px;margin-bottom:32px;border:1px solid var(--pastel-gray-border);box-shadow:0 4px 16px #4caf501a}.btn-log-meal{width:100%;padding:20px 32px;background:var(--pastel-green);color:var(--white);border:none;border-radius:28px;cursor:pointer;font-size:17px;font-weight:600;font-family:Poppins,Inter,sans-serif;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 4px 16px #4caf5033;letter-spacing:.3px}.btn-log-meal:hover:not(:disabled){background:var(--pastel-green-dark);transform:translateY(-3px);box-shadow:0 8px 24px #4caf5040}.btn-log-meal:disabled{opacity:.6;cursor:not-allowed}.btn-log-meal i{font-size:18px}.log-confirm-container{text-align:center}.log-confirm-text{font-size:16px;font-weight:500;color:var(--pastel-text-dark);margin:0 0 12px;display:flex;align-items:center;justify-content:center;gap:8px}.log-confirm-text i{color:var(--pastel-green-dark);font-size:20px}.log-confirm-details{background:var(--pastel-mint);border-radius:28px;padding:20px 24px;margin-bottom:24px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;border:1px solid var(--pastel-gray-border);box-shadow:0 2px 8px #0000000a}.log-confirm-details strong{color:var(--pastel-text-dark);font-size:15px}.log-confirm-details span{background:var(--pastel-gray-light);padding:4px 10px;border-radius:8px}.log-confirm-pantry-checkbox{display:flex;align-items:center;gap:10px;margin:14px 0 18px;font-size:14px;color:var(--pastel-text-dark);cursor:pointer}.log-confirm-pantry-checkbox input{width:18px;height:18px;accent-color:var(--pastel-green);cursor:pointer;font-size:13px;color:var(--pastel-text)}.log-confirm-buttons{display:flex;gap:12px;justify-content:center}.btn-confirm-log{padding:16px 32px;background:var(--pastel-green);color:var(--white);border:none;border-radius:28px;cursor:pointer;font-size:16px;font-weight:600;font-family:Inter,sans-serif;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:10px;box-shadow:0 4px 12px #4caf5033}.btn-confirm-log:hover:not(:disabled){background:var(--pastel-green-dark);transform:translateY(-3px);box-shadow:0 6px 20px #4caf5040}.btn-confirm-log:disabled{opacity:.6;cursor:not-allowed}.btn-cancel-log{padding:16px 32px;background:var(--pastel-mint);color:var(--pastel-text-dark);border:1px solid var(--pastel-gray-border);font-family:Inter,sans-serif;border-radius:12px;cursor:pointer;font-size:15px;font-weight:500;transition:all .3s ease}.btn-cancel-log:hover:not(:disabled){background:var(--pastel-gray-light);border-color:var(--pastel-text)}.log-success-banner{background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-green-light) 100%);color:var(--white);padding:20px 28px;border-radius:28px;display:flex;align-items:center;justify-content:center;gap:12px;font-weight:600;font-size:16px;font-family:Inter,sans-serif;animation:slideInSmooth .4s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 16px #4caf5033;border:1px solid rgba(255,255,255,.2)}.log-success-banner i{font-size:20px}.soft-conflict-card{background:linear-gradient(135deg,var(--pastel-mint) 0%,var(--pastel-gray-light) 100%);border:1px solid var(--pastel-gray-border);border-radius:20px;padding:24px;margin-top:8px}.soft-conflict-message{font-size:15px;line-height:1.5;color:var(--pastel-text-dark);margin:0 0 20px}.soft-conflict-options{display:flex;flex-direction:column;gap:12px}.soft-conflict-option{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:16px;border:1px solid var(--pastel-gray-border);background:var(--card-bg);color:var(--pastel-text-dark);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s}.soft-conflict-option:hover:not(:disabled){background:var(--pastel-mint);box-shadow:0 2px 12px #0000000f}.soft-conflict-option:disabled{opacity:.7;cursor:not-allowed}.soft-conflict-option i{font-size:18px;color:var(--pastel-green-dark)}.soft-conflict-loading{margin:14px 0 0;font-size:13px;color:var(--pastel-text);display:flex;align-items:center;gap:8px}.already-logged-banner{background:var(--pastel-mint);color:var(--pastel-text-dark);padding:20px 28px;border-radius:28px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;font-weight:500;font-size:15px;font-family:Inter,sans-serif;border:1px solid var(--pastel-gray-border);box-shadow:0 2px 8px #0000000a}.already-logged-banner i{font-size:18px;opacity:.7}.btn-unlog-meal{margin-left:8px;padding:8px 14px;border-radius:14px;border:1px solid var(--pastel-gray-border);background:var(--pastel-white);color:var(--pastel-text);font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .2s,color .2s,border-color .2s}.btn-unlog-meal:hover:not(:disabled){background:#f443361f;color:#c62828;border-color:#f443364d}.btn-unlog-meal:disabled{opacity:.6;cursor:not-allowed}@keyframes slideInSmooth{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.comment-count{background:var(--pastel-green);color:var(--pastel-text-dark);font-size:12px;font-weight:600;padding:3px 10px;border-radius:12px;margin-left:10px}.add-comment-container{margin-bottom:28px;padding:24px;background:var(--pastel-gray-light);border-radius:32px;border:1px solid var(--pastel-gray-border);box-shadow:0 2px 8px #00000008}.meal-comment-input{width:100%;padding:20px 24px;border:1px solid var(--pastel-gray-border);border-radius:28px;font-size:15px;font-family:Inter,sans-serif;resize:vertical;min-height:100px;transition:all .3s cubic-bezier(.16,1,.3,1);margin-bottom:16px;background:var(--pastel-mint);color:var(--pastel-text-dark);line-height:1.7;box-shadow:0 2px 8px #0000000a}.meal-comment-input:focus{outline:none;border-color:var(--pastel-green);background:var(--card-bg);box-shadow:0 4px 16px #4caf501a;transform:translateY(-2px)}.meal-comment-input::placeholder{color:var(--pastel-text)}.btn-add-comment{padding:14px 28px;background:var(--pastel-green);color:var(--white);border:none;border-radius:28px;cursor:pointer;font-size:15px;font-weight:600;font-family:Inter,sans-serif;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #4caf5033;display:inline-flex;align-items:center;gap:10px}.btn-add-comment:hover:not(:disabled){background:var(--pastel-green-dark);transform:translateY(-3px);box-shadow:0 6px 20px #4caf5040}.btn-add-comment:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-add-comment i{font-size:12px}.comments-list{display:flex;flex-direction:column;gap:12px}.comment-item{background:var(--pastel-mint);border-radius:28px;padding:20px 24px;border:1px solid var(--pastel-gray-border);border-left:4px solid var(--pastel-green);transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #0000000a;margin-bottom:12px}.comment-item:hover{background:var(--pastel-mint);border-color:var(--pastel-green);box-shadow:0 6px 16px #4caf501a;transform:translate(4px)}.comment-content{font-size:14px;line-height:1.6;color:var(--pastel-text-dark);margin-bottom:10px}.comment-footer{display:flex;justify-content:space-between;align-items:center}.comment-date{font-size:12px;color:var(--pastel-text)}.comment-delete-btn{background:none;border:none;color:var(--pastel-text);cursor:pointer;padding:6px 10px;border-radius:8px;transition:all .2s ease;font-size:13px}.comment-delete-btn:hover{color:var(--pastel-pink-dark);background:#e74c3c1a}.comment-delete-btn:disabled{opacity:.5;cursor:not-allowed}.comments-loading{padding:20px;text-align:center;color:var(--pastel-text);font-size:14px}.comments-loading i{margin-right:8px}.no-comments{padding:24px;text-align:center;background:var(--pastel-gray-light);border-radius:16px;color:var(--pastel-text)}.no-comments i{font-size:32px;margin-bottom:12px;display:block;opacity:.5}.no-comments p{margin:0;font-size:14px;line-height:1.5}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.meal-detail-modal{max-width:100%;max-height:95vh;border-radius:24px 24px 0 0;margin:0}.meal-detail-header{padding:32px 24px 24px}.meal-detail-name{font-size:22px}.meal-detail-content{padding:24px}.nutrition-grid{grid-template-columns:repeat(2,1fr)}.feedback-buttons{flex-direction:column}.feedback-btn{width:100%}}.meal-detail-modal{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.meal-detail-modal::-webkit-scrollbar{width:8px}.meal-detail-modal::-webkit-scrollbar-track{background:var(--pastel-gray-light);border-radius:4px}.meal-detail-modal::-webkit-scrollbar-thumb{background:var(--pastel-gray-border);border-radius:4px}.meal-detail-modal::-webkit-scrollbar-thumb:hover{background:var(--pastel-text)}.chat-meal-planner{display:flex;flex-direction:row;height:100%;min-height:0;width:100%;background:var(--pastel-gray-light);border-radius:0;box-shadow:none;overflow:hidden;border:none;position:relative;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.chat-main-content{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0;transition:all .3s ease;overflow:hidden}@media(max-width:768px){.chat-meal-planner.meal-detail-open .chat-main-content{display:none}}.chat-header{padding:24px 48px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-bottom:2px solid var(--pastel-gray-border);border-radius:0;box-shadow:0 2px 12px #0000000f;position:sticky;top:0;z-index:10}.chat-header-content{display:flex;align-items:center;gap:20px}.chat-icon-wrapper{width:64px;height:64px;background:#fff6;border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft)}.chat-icon-wrapper i{font-size:28px;color:var(--color-primary-dark)}.chat-header-text h1{margin:0 0 6px;color:var(--pastel-text-dark);font-size:28px;font-weight:600;font-family:Poppins,sans-serif}.chat-header-text p{margin:0;color:var(--pastel-text);font-size:15px;font-family:Inter,sans-serif}.chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:20px 28px;display:flex;flex-direction:column;gap:14px;background:var(--pastel-gray-light);max-width:100%}.chat-load-older{flex-shrink:0;text-align:center;padding:8px 12px}.chat-load-older-hint,.chat-load-older-spinner{font-size:13px;color:var(--pastel-text)}.chat-load-older-spinner i{margin-right:8px}.chat-date-separator{flex-shrink:0;text-align:center;padding:6px 14px;margin:4px 0 2px;font-size:13px;font-weight:600;color:var(--pastel-text-dark);background:var(--pastel-mint);border-radius:10px;box-shadow:var(--shadow-soft);letter-spacing:.02em}.chat-date-separator--chip{display:inline-block;align-self:center;padding:4px 12px;font-size:12px;font-weight:500;border-radius:999px}.dark-mode .chat-date-separator{background:var(--pastel-green-dark);color:#fffffff2}.dark-mode .chat-date-separator--chip{background:#fff3;color:#fffffff2}@media(max-width:768px){.chat-header{padding:16px 20px}.chat-header-content{gap:12px}.chat-icon-wrapper{width:48px;height:48px;border-radius:14px}.chat-icon-wrapper i,.chat-header-text h1{font-size:22px}.chat-header-text p{font-size:13px}.chat-messages{padding:16px;gap:12px;min-height:240px}}.message{display:flex;flex-direction:column;animation:fadeInMessage .3s ease}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message-content{display:flex;align-items:flex-start;gap:8px;max-width:85%;width:100%}.message.user .message-content{flex-direction:row-reverse}.message-avatar{width:40px;height:40px;background:var(--pastel-gray-light);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-soft)}.message-avatar i{font-size:18px;color:var(--pastel-green-dark)}.message.user .message-avatar{background:var(--pastel-green)}.message.user .message-avatar i{color:var(--white)}.message-bubble{background:var(--card-bg);padding:14px 18px;border-radius:20px;box-shadow:0 2px 20px #0000000a;position:relative;word-wrap:break-word;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;border:1px solid rgba(255,255,255,.8)}.message.user .message-bubble{background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(168,201,228,.5) 100%);color:var(--pastel-text-dark);box-shadow:0 2px 20px #4a7ba81f;border:1px solid rgba(168,201,228,.5)}.message.assistant .message-bubble{background:var(--pastel-mint);color:var(--pastel-text-dark)}.message-text{font-size:15px;line-height:1.65;font-family:Inter,sans-serif;color:var(--pastel-text-dark);white-space:pre-wrap;letter-spacing:-.01em}.calendar-context-bubble{margin-top:12px;padding:12px 14px;background:#ffffff80;border-radius:14px;border:1px solid var(--pastel-gray-border);font-family:Inter,sans-serif;animation:slideIn .3s ease}.calendar-context-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:11px;font-weight:700;color:var(--pastel-text);text-transform:uppercase;letter-spacing:.05em}.calendar-context-header i{color:var(--color-primary);font-size:12px}.calendar-event{display:flex;flex-direction:column;gap:4px}.calendar-event-title{font-size:14px;font-weight:600;color:var(--pastel-text-dark)}.calendar-event-time{font-size:12px;color:var(--pastel-text);display:flex;align-items:center;gap:8px}.status-ongoing{padding:2px 6px;background:var(--pastel-red-light, #fde8e8);color:#c62828;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase}.status-rush{padding:2px 6px;background:var(--pastel-amber-light, #fef3e2);color:#ef6c00;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase}.dark-mode .calendar-context-bubble{background:#ffffff0d}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-text strong{font-weight:600;color:var(--pastel-text-dark)}.message.assistant .message-text strong{color:var(--pastel-green-dark)}.message.user .message-text{color:var(--pastel-text-dark)}.message-image-wrap{margin-bottom:8px;border-radius:12px;overflow:hidden;max-width:280px;box-shadow:0 2px 8px #00000014}.message-image{display:block;width:100%;height:auto;max-height:240px;object-fit:cover}.scan-review{margin-top:10px;padding-top:8px;border-top:1px solid var(--pastel-gray-border)}.scan-review-list{list-style:none;padding:0;margin:0 0 8px;display:grid;gap:4px}.scan-review-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 12px;background:var(--pastel-yellow-light);border-radius:10px;border-left:4px solid var(--pastel-green)}.scan-review-name{font-weight:500;color:var(--pastel-text-dark)}.scan-review-qty{font-size:.9em;color:var(--pastel-text)}.scan-review-actions{display:flex;gap:4px}.scan-review-btn{padding:4px 8px;border:none;border-radius:6px;cursor:pointer;font-size:.9em;background:var(--pastel-gray-light);color:var(--pastel-text-dark)}.scan-review-btn.edit:hover{background:var(--pastel-green-light)}.scan-review-btn.remove:hover{background:var(--pastel-red-light, #fde8e8)}.scan-item-edit{grid-column:1 / -1;display:grid;grid-template-columns:1fr auto auto auto auto;gap:8px;align-items:center}.scan-edit-input,.scan-edit-qty,.scan-edit-unit{padding:6px 10px;border:1px solid var(--pastel-gray-border);border-radius:8px;font-size:.95em}.scan-edit-qty{width:56px}.scan-edit-unit{width:64px}.scan-edit-btn{padding:6px 10px;border:none;border-radius:8px;cursor:pointer;font-size:.9em}.scan-edit-btn.save{background:var(--pastel-green-light);color:var(--pastel-text-dark)}.scan-edit-btn.cancel{background:var(--pastel-gray-light)}.scan-review-add-btn{padding:10px 16px;border:none;border-radius:10px;background:var(--pastel-green);color:var(--pastel-text-dark);font-weight:600;cursor:pointer}.scan-review-add-btn:hover:not(:disabled){background:var(--pastel-green-dark);filter:brightness(1.05)}.scan-review-add-btn:disabled{opacity:.7;cursor:not-allowed}.message-time{font-size:11px;color:var(--pastel-text);margin-top:4px;font-family:Inter,sans-serif}.waste-recipe-link{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:var(--pastel-mint);border-radius:10px;color:var(--pastel-green-dark);text-decoration:none;font-weight:500;font-size:14px;border:1px solid var(--pastel-gray-border);transition:all .2s ease}.waste-recipe-link:hover{background:var(--pastel-green-light);transform:translateY(-1px)}.waste-recipe-img{width:48px;height:48px;object-fit:cover;border-radius:8px}.message-log-meal-action{margin-top:8px}.chat-log-meal-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--pastel-green);border:1px solid var(--pastel-gray-border);border-radius:12px;color:var(--pastel-text-dark);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.chat-log-meal-btn:hover{background:var(--pastel-green-dark);transform:translateY(-1px);box-shadow:var(--shadow-soft)}.message-meals{display:flex;flex-direction:column;gap:10px;margin-top:12px}.message.first-move{animation:fadeInUp .4s ease}.first-move-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.first-move-chip{background:var(--pastel-green);color:var(--pastel-text-dark);border:none;padding:10px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000f;font-family:Inter,sans-serif}.first-move-chip:hover{background:var(--pastel-green-light);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.meal-card{background:var(--card-bg);border-radius:20px;padding:14px 18px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.04);box-shadow:0 2px 16px #0000000a;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:8px;overflow:hidden}.meal-card--has-image{display:flex;flex-direction:row;align-items:flex-start;gap:14px;padding:12px}.meal-card-thumb{width:80px;height:80px;flex-shrink:0;border-radius:12px;overflow:hidden;background:var(--pastel-gray-light)}.meal-card-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.meal-card-body{flex:1;min-width:0}.meal-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.meal-card-name{font-size:17px;font-weight:600;color:var(--pastel-text-dark);margin-bottom:4px;font-family:Inter,sans-serif;line-height:1.4;letter-spacing:-.02em}.meal-card-emotional{font-size:13px;color:var(--pastel-text);font-family:Inter,sans-serif;line-height:1.5;margin-bottom:8px;font-style:italic;font-weight:400}.meal-card-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.meal-chip{background:var(--pastel-green-light);color:var(--pastel-text-dark);padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;font-family:Inter,sans-serif;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(0,0,0,.05)}.meal-card-description{font-size:13px;color:var(--pastel-text);font-family:Inter,sans-serif;line-height:1.5;margin-bottom:10px;font-weight:400}.meal-card-nutrition{display:flex;gap:10px;font-size:12px;color:var(--pastel-text);font-family:Inter,sans-serif;font-weight:500;margin-top:6px;flex-wrap:wrap}.meal-card-nutrition span{display:flex;align-items:center;gap:4px}.meal-card:after{content:"";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--pastel-text);opacity:.5;transition:all .3s ease}.meal-card:hover{background:var(--pastel-mint);transform:translateY(-6px);box-shadow:0 8px 32px #4caf5026;border-color:#b8e6b866}.meal-card:hover:after{opacity:1;color:var(--pastel-green-dark);transform:translateY(-50%) translate(3px)}.meal-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.meal-type-badge{background:var(--pastel-green);color:var(--pastel-text-dark);padding:6px 14px;border-radius:16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:Inter,sans-serif}.meal-date{font-size:12px;color:var(--pastel-text);font-family:Inter,sans-serif}.meal-card-name{font-size:15px;font-weight:600;color:var(--pastel-text-dark);margin-bottom:8px;font-family:Inter,sans-serif;line-height:1.4}.meal-card-missing{display:flex;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;border-radius:12px;font-size:12px;background:var(--pastel-amber-light, #fef3e2);border:1px solid var(--pastel-amber-border, #f5d0a9);color:var(--pastel-text-dark)}.dark-mode .meal-card-missing{background:var(--pastel-amber-light);border-color:var(--pastel-amber-border);color:var(--pastel-text-dark)}.dark-mode .meal-card-missing .meal-card-missing-icon{color:var(--pastel-yellow-dark)}.meal-card-missing-icon{flex-shrink:0}.meal-card-missing-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-card-summary{display:flex;flex-direction:row;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}.meal-card-health-scale{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border-radius:14px;font-size:12px;font-weight:600;font-family:Inter,sans-serif;background:var(--pastel-gray-light);border:1px solid var(--pastel-gray-border)}.meal-card-health-scale .meal-card-health-label{color:var(--pastel-text);opacity:.95;margin-right:2px}.meal-card-health-letters{display:flex;align-items:center;gap:4px}.meal-card-health-letter{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:8px;font-size:12px;font-weight:700;opacity:.5;transition:opacity .2s ease,transform .2s ease}.meal-card-health-letter--active{opacity:1;transform:scale(1.15);box-shadow:0 2px 8px #0000001f}.meal-card-health-letter--a{background:#4caf5059;color:#2e7d32}.meal-card-health-letter--b{background:#8bc34a59;color:#558b2f}.meal-card-health-letter--c{background:#ffc10766;color:#f57f17}.meal-card-health-letter--d{background:#ff980066;color:#e65100}.meal-card-health-letter--e{background:#f4433659;color:#c62828}.meal-card-health-letter--active.meal-card-health-letter--a{background:#4caf5080;color:#1b5e20;box-shadow:0 2px 8px #4caf5059}.meal-card-health-letter--active.meal-card-health-letter--b{background:#8bc34a80;color:#33691e;box-shadow:0 2px 8px #8bc34a59}.meal-card-health-letter--active.meal-card-health-letter--c{background:#ffc1078c;color:#ff8f00;box-shadow:0 2px 8px #ffc10766}.meal-card-health-letter--active.meal-card-health-letter--d{background:#ff98008c;color:#e65100;box-shadow:0 2px 8px #ff980066}.meal-card-health-letter--active.meal-card-health-letter--e{background:#f4433680;color:#b71c1c;box-shadow:0 2px 8px #f4433659}.dark-mode .meal-card-health-letter--a{background:#66bb6a73;color:#81c784}.dark-mode .meal-card-health-letter--b{background:#a7d47473;color:#9ccc65}.dark-mode .meal-card-health-letter--c{background:#ffd54f80;color:#ffd54f}.dark-mode .meal-card-health-letter--d{background:#ffb74d80;color:#ffb74d}.dark-mode .meal-card-health-letter--e{background:#ef535073;color:#e57373}.dark-mode .meal-card-health-letter--active.meal-card-health-letter--a{background:#66bb6a8c;color:#a5d6a7}.dark-mode .meal-card-health-letter--active.meal-card-health-letter--b{background:#a7d4748c;color:#aed581}.dark-mode .meal-card-health-letter--active.meal-card-health-letter--c{background:#ffd54f99;color:#ffca28}.dark-mode .meal-card-health-letter--active.meal-card-health-letter--d{background:#ffb74d99;color:#ffb74d}.dark-mode .meal-card-health-letter--active.meal-card-health-letter--e{background:#ef53508c;color:#ef9a9a}.meal-card-ingredients{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--pastel-text);font-family:Inter,sans-serif}.meal-card-ingredients i{color:var(--pastel-green);font-size:12px}.meal-card-nutrition{display:flex;gap:16px;font-size:12px;color:var(--pastel-text);font-family:Inter,sans-serif;flex-wrap:wrap}.meal-card-nutrition span{display:flex;align-items:center;gap:6px}.meal-card-nutrition i{color:var(--pastel-green);font-size:11px}.meal-card-time{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--pastel-text);font-family:Inter,sans-serif}.meal-card-time i{color:var(--pastel-blue);font-size:12px}.meal-cuisine-badge{background:var(--pastel-purple);color:var(--white);padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.3px;font-family:Inter,sans-serif}.meal-difficulty-badge{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.3px;font-family:Inter,sans-serif}.meal-difficulty-badge.difficulty-easy{background:var(--pastel-green);color:var(--white)}.meal-difficulty-badge.difficulty-medium{background:var(--pastel-yellow);color:var(--pastel-text-dark)}.meal-difficulty-badge.difficulty-hard{background:var(--pastel-red);color:var(--white)}.meal-card-click-hint{margin-top:12px;font-size:11px;color:var(--pastel-text);font-style:italic;text-align:right;opacity:.7;font-family:Inter,sans-serif}.typing-indicator{display:flex;gap:6px;padding:8px 0}.typing-indicator span{width:8px;height:8px;background:var(--pastel-green);border-radius:50%;animation:typingBounce 1.4s ease-in-out infinite}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.chat-input-form{flex-shrink:0;padding:16px 28px 24px;background:var(--card-bg);border-top:1px solid var(--pastel-gray-border);border-radius:0;box-shadow:0 -2px 20px #0000000a;z-index:10}.chat-input-wrapper{display:flex;gap:12px;align-items:center;min-height:56px}.chat-input{flex:1;height:56px;min-height:56px;box-sizing:border-box;padding:0 28px;line-height:56px;border:1px solid var(--pastel-gray-border);border-radius:28px;font-size:16px;font-family:Inter,sans-serif;background:var(--card-bg);color:var(--pastel-text-dark);transition:all .3s ease;box-shadow:0 2px 12px #0000000a}.chat-input:focus{outline:none;border-color:var(--pastel-green);background:var(--card-bg);box-shadow:0 4px 12px #00000014}.chat-input::placeholder{color:var(--pastel-text)}.chat-image-input-hidden{position:absolute;width:0;height:0;opacity:0;overflow:hidden;pointer-events:none}.chat-log-meal-input-btn{min-width:56px;height:56px;box-sizing:border-box;padding:0 16px;background:linear-gradient(135deg,var(--pastel-green-light) 0%,var(--pastel-mint) 100%);border:1px solid var(--pastel-gray-border);border-radius:28px;color:var(--pastel-text-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0;transition:all .3s ease}.chat-log-meal-input-btn:hover:not(:disabled){background:var(--pastel-mint);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.chat-log-meal-input-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-log-meal-input-btn i{font-size:18px}.chat-log-meal-input-label{font-size:.85rem;font-weight:600;white-space:nowrap}.chat-scan-dish-input-btn{min-width:56px;height:56px;box-sizing:border-box;padding:0 16px;background:linear-gradient(135deg,#f5e6d3,#f0d9c4);border:1px solid var(--pastel-gray-border);border-radius:28px;color:var(--pastel-text-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0;transition:all .3s ease}.chat-scan-dish-input-btn:hover:not(:disabled){background:#f0d9c4;transform:translateY(-2px);box-shadow:var(--shadow-soft)}.chat-scan-dish-input-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-scan-dish-input-btn i{font-size:18px}.chat-scan-dish-input-label{font-size:.85rem;font-weight:600;white-space:nowrap}.chat-image-button{min-width:56px;height:56px;box-sizing:border-box;padding:0 16px;background:linear-gradient(135deg,var(--pastel-mint) 0%,var(--pastel-gray-light) 100%);border:1px solid var(--pastel-gray-border);border-radius:28px;color:var(--pastel-text-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0;transition:all .3s ease}.chat-image-button-label{font-size:.85rem;font-weight:600;white-space:nowrap}.chat-image-button:hover:not(:disabled){background:var(--pastel-mint);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.chat-image-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-image-button i{font-size:18px}.chat-send-button{width:56px;height:56px;min-width:56px;min-height:56px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 16px #4a7ba859;flex-shrink:0;box-sizing:border-box}.chat-send-button:hover:not(:disabled){background:var(--color-primary-light);color:var(--pastel-text-dark);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-send-button i{font-size:18px}@keyframes fadeInMessage{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.message.user{animation:slideInFromRight .4s ease}.message.assistant{animation:fadeInMessage .4s ease}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-8px);opacity:1}}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--pastel-gray-light);border-radius:4px}.chat-messages::-webkit-scrollbar-thumb{background:var(--pastel-gray-border);border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--pastel-text)}.question-buttons-container{padding:24px 56px;background:var(--pastel-mint);border-top:1px solid var(--pastel-gray-border);box-shadow:0 -2px 20px #0000000a;animation:slideUp .3s ease}.question-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.question-button{padding:14px 24px;background:var(--card-bg);border:2px solid var(--pastel-green);border-radius:28px;font-size:15px;font-family:Inter,sans-serif;font-weight:600;color:var(--pastel-text-dark);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000014;min-width:120px}.question-button:hover{background:var(--pastel-green);color:var(--white);transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.question-button:active{transform:translateY(0);box-shadow:0 2px 8px #00000014}.question-button.skip{background:transparent;border:1px solid var(--pastel-gray-border);color:var(--pastel-text);font-weight:400}.question-button.skip:hover{background:var(--pastel-gray-light);border-color:var(--pastel-text);color:var(--pastel-text-dark)}.quick-actions{flex-shrink:0;display:flex;flex-wrap:wrap;gap:12px;padding:24px 56px;background:var(--pastel-mint);border-top:1px solid var(--pastel-gray-border);box-shadow:0 -2px 20px #0000000a}.quick-action-btn{padding:12px 20px;background:var(--card-bg);border:1px solid var(--pastel-gray-border);border-radius:24px;font-size:14px;font-family:Inter,sans-serif;color:var(--pastel-text-dark);cursor:pointer;transition:all .3s ease;font-weight:500;box-shadow:0 2px 8px #0000000a}.quick-action-btn:hover{background:var(--pastel-mint);border-color:var(--pastel-green);transform:translateY(-1px)}.quick-action-btn:active{transform:translateY(0)}.preference-chips-container{flex-shrink:0;display:flex;flex-direction:column;gap:20px;padding:32px 56px;background:var(--pastel-mint);border-top:1px solid var(--pastel-gray-border);box-shadow:0 -2px 20px #0000000a;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.preference-section{display:flex;flex-direction:column;gap:10px}.preference-label{font-size:12px;font-weight:600;color:var(--pastel-text);text-transform:uppercase;letter-spacing:.5px;font-family:Inter,sans-serif}.preference-chips{display:flex;flex-wrap:wrap;gap:8px}.preference-chip{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--card-bg);border:1px solid var(--pastel-gray-border);border-radius:24px;font-size:14px;font-family:Inter,sans-serif;color:var(--pastel-text-dark);cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.preference-chip:hover{background:var(--pastel-mint);border-color:var(--pastel-green);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.preference-chip:active{transform:translateY(0)}.chip-icon{font-size:16px}.chip-label{font-weight:500}@media(max-width:768px){.chat-meal-planner{height:100%;border-radius:0}.chat-header{padding:14px 20px;border-radius:0}.chat-icon-wrapper{width:48px;height:48px}.chat-icon-wrapper i{font-size:24px}.chat-header-text h1{font-size:20px}.chat-header-text p{font-size:13px}.chat-messages{padding:12px;gap:10px}.message-content{max-width:95%}.message-bubble{padding:12px 14px;border-radius:16px}.message-text{font-size:14px}.chat-input-form{padding:12px 16px}.quick-actions{padding:16px 20px}.preference-chips-container{padding:20px 24px}.chat-input-wrapper{min-height:48px}.chat-input{height:48px;min-height:48px;padding:0 18px;font-size:14px;border-radius:24px}.chat-log-meal-input-btn{min-width:48px;height:48px;padding:0 12px}.chat-log-meal-input-label{display:none}.chat-scan-dish-input-btn{min-width:48px;height:48px;padding:0 12px}.chat-scan-dish-input-label{display:none}.chat-image-button{min-width:48px;height:48px;padding:0 12px}.chat-image-button-label{display:none}.chat-send-button{width:48px;height:48px;min-width:48px;min-height:48px}.quick-actions{padding:12px 20px}.quick-action-btn{padding:8px 14px;font-size:13px}.preference-chips-container{padding:16px 20px;gap:12px}.preference-chip{padding:8px 12px;font-size:13px}.chip-icon{font-size:14px}}.pantry-page{max-width:960px;margin:0 auto;padding:32px 24px 48px;width:100%}.pantry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;gap:16px}.pantry-title{margin:0;font-size:1.75rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);letter-spacing:-.03em}.pantry-actions{display:flex;gap:12px}.pantry-btn{padding:12px 24px;border-radius:20px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;border:none}.pantry-btn-primary{background:var(--pastel-green, #9FD89F);color:var(--pastel-text-dark, #3A3A3A);box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .08))}.pantry-btn-primary:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-medium, 0 8px 30px rgba(0, 0, 0, .12))}.pantry-btn-secondary{background:var(--white, #F8F8F8);color:var(--pastel-text-dark, #3A3A3A);border:1px solid var(--pastel-gray-border, #D8D8D8)}.pantry-btn-secondary:hover:not(:disabled){background:var(--pastel-gray-light, #F5F5F5);border-color:var(--pastel-green)}.pantry-btn:disabled{opacity:.7;cursor:not-allowed}.pantry-error{padding:16px 20px;margin-bottom:24px;background:var(--pastel-pink-light, #FFE8E8);color:var(--pastel-pink-dark, #b91c1c);border-radius:20px;font-size:.95rem;border:1px solid var(--pastel-pink, #FFD4D4)}.pantry-search-wrap{margin-bottom:24px}.pantry-search{width:100%;padding:16px 20px;border:1px solid var(--pastel-gray-border, #D8D8D8);border-radius:20px;font-size:1rem;background:var(--white, #F8F8F8);color:var(--pastel-text-dark, #3A3A3A);transition:border-color .2s,box-shadow .2s}.pantry-search::placeholder{color:var(--pastel-text, #5A5A5A)}.pantry-search:focus{outline:none;border-color:var(--pastel-green);box-shadow:0 0 0 3px #9fd89f40}.pantry-form-inline{margin-bottom:32px;padding:28px 32px;background:var(--white, #F8F8F8);border-radius:24px;border:1px solid var(--pastel-gray-border, #D8D8D8);box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .08))}.pantry-did-you-mean{margin-bottom:16px;padding:14px 18px;background:var(--pastel-yellow-light, #FFF8E8);border:1px solid var(--pastel-yellow-dark, #FFD99F);border-radius:16px;font-size:.95rem}.pantry-did-you-mean-text{display:block;margin-bottom:10px;color:var(--pastel-text-dark, #3A3A3A)}.pantry-did-you-mean-actions{display:flex;flex-wrap:wrap;gap:10px}.pantry-did-you-mean-btn{flex-shrink:0}.pantry-form-group-name{position:relative}.pantry-name-suggestions{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:8px 0;list-style:none;background:var(--card-bg, #F0F5F0);border:1px solid var(--pastel-gray-border, #D8D8D8);border-radius:14px;box-shadow:var(--shadow-medium, 0 8px 30px rgba(0, 0, 0, .12));max-height:220px;overflow-y:auto;z-index:10}.pantry-name-suggestion-item{padding:10px 16px;font-size:.95rem;color:var(--pastel-text-dark, #3A3A3A);cursor:pointer;transition:background .15s ease}.pantry-name-suggestion-item:hover{background:var(--pastel-mint, #C5E5C5)}.pantry-form-group-unit{position:relative}.pantry-unit-suggestions{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:8px 0;list-style:none;background:var(--card-bg, #F0F5F0);border:1px solid var(--pastel-gray-border, #D8D8D8);border-radius:14px;box-shadow:var(--shadow-medium, 0 8px 30px rgba(0, 0, 0, .12));max-height:220px;overflow-y:auto;z-index:10}.pantry-unit-suggestion-item{padding:10px 16px;font-size:.95rem;color:var(--pastel-text-dark, #3A3A3A);cursor:pointer;transition:background .15s ease}.pantry-unit-suggestion-item:hover{background:var(--pastel-mint, #C5E5C5)}.pantry-form-inline .pantry-form-grid{margin-bottom:20px}.pantry-form-grid{display:grid;grid-template-columns:1fr auto auto;gap:20px;align-items:end}.pantry-form-group{display:flex;flex-direction:column;gap:8px}.pantry-form-group label{font-size:.9rem;font-weight:500;color:var(--pastel-text-dark, #3A3A3A)}.pantry-form-group input{padding:14px 18px;border:1px solid var(--pastel-gray-border, #D8D8D8);border-radius:16px;font-size:1rem;background:#fff;color:var(--pastel-text-dark);transition:border-color .2s,box-shadow .2s}.pantry-form-group input:focus{outline:none;border-color:var(--pastel-green);box-shadow:0 0 0 3px #9fd89f33}.pantry-form .pantry-btn{margin-top:0}.pantry-loading,.pantry-empty{text-align:center;padding:56px 32px;background:var(--white, #F8F8F8);border-radius:24px;border:1px solid var(--pastel-gray-border, #D8D8D8);margin-bottom:32px;box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .06))}.pantry-empty-title{margin:0 0 12px;font-size:1.25rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A)}.pantry-empty-text{margin:0;font-size:1rem;color:var(--pastel-text, #5A5A5A);line-height:1.6}.pantry-list-section{background:var(--white, #F8F8F8);border-radius:24px;padding:28px 32px 36px;margin-bottom:32px;box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .06));border:1px solid var(--pastel-gray-border, #D8D8D8)}.pantry-list-header{margin-bottom:24px}.pantry-list-title{margin:0 0 16px;font-size:1.2rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);letter-spacing:-.02em}.pantry-freshness-legend{display:flex;align-items:center;gap:24px;font-size:.9rem;color:var(--pastel-text, #5A5A5A)}.pantry-freshness-legend .legend-item{display:inline-flex;align-items:center;gap:8px}.pantry-freshness-legend .legend-dot{width:10px;height:10px;border-radius:50%}.pantry-freshness-legend .legend-dot.freshness-green{background:#22c55e}.pantry-freshness-legend .legend-dot.freshness-yellow{background:#eab308}.pantry-freshness-legend .legend-dot.freshness-red{background:#ef4444}.pantry-no-results{margin:0;padding:24px;text-align:center;color:var(--pastel-text, #5A5A5A);font-size:1rem;border-radius:20px;background:var(--pastel-gray-light, #F5F5F5)}.pantry-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.pantry-item{display:flex;align-items:center;gap:16px;padding:18px 22px;background:#fff;border-radius:20px;border-left:4px solid var(--pastel-green);min-height:56px;box-sizing:border-box;transition:transform .15s ease,box-shadow .2s ease;box-shadow:0 2px 12px #0000000a}.pantry-item-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.pantry-item .pantry-item-name{flex:1;font-size:1.05rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);line-height:1.4}.pantry-item .pantry-item-qty{flex-shrink:0;font-size:.95rem;font-weight:500;color:var(--pastel-text, #5A5A5A);background:var(--pastel-gray-light, #F5F5F5);padding:10px 16px;border-radius:14px;border:1px solid var(--pastel-gray-border, #D8D8D8);min-width:4.5em;text-align:center}.pantry-item .pantry-item-countdown{flex-shrink:0;font-size:.85rem;font-weight:500;color:var(--pastel-text, #5A5A5A);padding:0 8px;white-space:nowrap}.pantry-item.freshness-green{border-left-color:#22c55e}.pantry-item.freshness-yellow{border-left-color:#eab308}.pantry-item.freshness-red{border-left-color:#ef4444}.pantry-item-status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.pantry-item.freshness-green .pantry-item-status-dot{background:#22c55e;box-shadow:0 0 0 2px #22c55e40}.pantry-item.freshness-yellow .pantry-item-status-dot{background:#eab308;box-shadow:0 0 0 2px #eab30840}.pantry-item.freshness-red .pantry-item-status-dot{background:#ef4444;box-shadow:0 0 0 2px #ef444440}.pantry-item-actions-wrap{position:relative;flex-shrink:0}.pantry-item-actions-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:14px;background:transparent;color:var(--pastel-text, #5A5A5A);cursor:pointer;transition:background .2s,color .2s}.pantry-item-actions-btn:hover,.pantry-item-actions-btn[aria-expanded=true]{background:var(--pastel-gray-light, #F5F5F5);color:var(--pastel-text-dark)}.pantry-item-actions-dots{font-size:1.25rem;font-weight:700;line-height:1;letter-spacing:-.05em}.pantry-item-actions-menu{position:absolute;top:100%;right:0;margin-top:6px;min-width:140px;padding:8px;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001f;border:1px solid var(--pastel-gray-border);z-index:10;display:flex;flex-direction:column;gap:4px}.pantry-item-action{display:block;width:100%;padding:12px 16px;border:none;border-radius:12px;font-size:.95rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s;background:transparent;color:var(--pastel-text-dark)}.pantry-item-action:hover{background:var(--pastel-gray-light)}.pantry-item-action-edit:hover{background:var(--pastel-blue, #D4E8FF)}.pantry-item-action-remove:hover{background:var(--pastel-pink, #FFD4D4)}.pantry-item-btn{padding:8px 16px;border-radius:14px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s;border:none}.pantry-item-btn-save{background:var(--pastel-green);color:var(--pastel-text-dark)}.pantry-item-btn-save:hover:not(:disabled){filter:brightness(1.05)}.pantry-item-btn-cancel{background:var(--pastel-gray-light);color:var(--pastel-text);border:1px solid var(--pastel-gray-border)}.pantry-item-btn-cancel:hover{background:var(--pastel-gray-border)}.pantry-item-edit{display:flex;flex-wrap:wrap;align-items:center;gap:12px;width:100%}.pantry-item-edit-input,.pantry-item-edit-qty,.pantry-item-edit-unit{padding:10px 14px;border:1px solid var(--pastel-gray-border);border-radius:14px;font-size:.95rem;background:#fff;color:var(--pastel-text-dark)}.pantry-item-edit-input{flex:1;min-width:120px}.pantry-item-edit-qty{width:80px}.pantry-item-edit-unit{width:88px}.pantry-item-edit-actions{display:flex;gap:10px;flex-shrink:0}.pantry-scan-block{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}.receipt-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.pantry-scan-btn{padding:14px 24px;border-radius:20px;border:1px solid var(--pastel-gray-border);background:var(--pastel-mint, #C5E5C5);color:var(--pastel-text-dark);font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s}.pantry-scan-btn:hover:not(:disabled){background:var(--pastel-mint-light, #D8EDD8);transform:translateY(-1px);box-shadow:var(--shadow-soft)}.pantry-scan-btn-recipe{background:var(--pastel-blue, #D4E8FF)}.pantry-scan-btn-recipe:hover:not(:disabled){background:var(--pastel-blue-dark, #9FC5FF)}.pantry-scan-btn:disabled{opacity:.8;cursor:wait}.pantry-parsed-card{margin-top:20px;margin-bottom:28px;padding:24px;background:var(--white, #F8F8F8);border-radius:24px;border:1px solid var(--pastel-gray-border);box-shadow:var(--shadow-soft)}.pantry-parsed-title{margin:0 0 16px;font-size:.95rem;font-weight:500;color:var(--pastel-text, #5A5A5A)}.parsed-image-wrap{margin-bottom:16px;border-radius:20px;overflow:hidden;max-width:280px;box-shadow:0 2px 12px #00000014}.parsed-image{display:block;width:100%;height:auto;max-height:200px;object-fit:cover}.parsed-receipt-list{list-style:none;padding:0;margin:0 0 20px;display:grid;gap:12px}.parsed-receipt-item{display:grid;grid-template-columns:1fr auto auto auto;gap:12px;align-items:center;padding:14px 18px;background:#fff;border-radius:18px;border-left:4px solid var(--pastel-green);box-shadow:0 2px 8px #0000000a}.parsed-name{font-weight:500;color:var(--pastel-text-dark)}.parsed-qty{font-size:.9rem;color:var(--pastel-text)}.parsed-shelf-life{font-size:.85rem;color:var(--pastel-text);opacity:.9}.parsed-receipt-actions{display:flex;gap:8px}.parsed-item-btn{padding:8px 14px;border:none;border-radius:14px;cursor:pointer;font-size:.9rem;background:var(--pastel-gray-light);color:var(--pastel-text-dark);transition:background .2s}.parsed-item-btn.edit:hover,.parsed-item-btn.save{background:var(--pastel-green-light)}.parsed-item-btn.remove:hover{background:var(--pastel-pink-light)}.parsed-item-edit{grid-column:1 / -1;display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:center}.parsed-edit-input,.parsed-edit-qty,.parsed-edit-unit{padding:10px 14px;border:1px solid var(--pastel-gray-border);border-radius:14px;font-size:.95rem}.parsed-edit-qty{width:72px}.parsed-edit-unit{width:88px}.parsed-edit-actions{display:flex;gap:10px}.add-all-parsed-btn{padding:14px 24px;border-radius:20px;border:none;background:var(--pastel-green);color:var(--pastel-text-dark);font-size:.95rem;font-weight:500;cursor:pointer;transition:filter .2s,transform .15s,box-shadow .2s;box-shadow:var(--shadow-soft)}.add-all-parsed-btn:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.add-all-parsed-btn:disabled{opacity:.8;cursor:not-allowed}@media(max-width:640px){.pantry-page{padding:20px 16px 40px}.pantry-header{flex-direction:column;align-items:stretch;margin-bottom:28px}.pantry-actions{width:100%}.pantry-actions .pantry-btn{flex:1}.pantry-form-inline{padding:22px 20px}.pantry-form-grid{grid-template-columns:1fr}.pantry-list-section{padding:22px 20px 28px}.pantry-item{padding:16px 18px;flex-wrap:wrap}.pantry-item .pantry-item-name{font-size:1rem}.pantry-item-actions-btn{width:44px;height:44px}.pantry-item-actions-menu{min-width:160px;padding:10px}.pantry-item-action{padding:14px 18px;min-height:44px;display:flex;align-items:center}.pantry-item-edit{flex-direction:column;align-items:stretch}.pantry-item-edit-input,.pantry-item-edit-qty,.pantry-item-edit-unit{width:100%}.pantry-scan-block{flex-direction:column}.pantry-scan-btn{width:100%}}.preferences-page{max-width:960px;margin:0 auto;padding:32px 24px 48px;width:100%}.preferences-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;gap:16px;flex-wrap:wrap}.preferences-title{margin:0;font-size:1.75rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);letter-spacing:-.03em}.preferences-header-btn{padding:12px 24px;border-radius:20px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;border:none}.preferences-header-btn--edit{background:var(--pastel-green, #9FD89F);color:var(--pastel-text-dark, #3A3A3A);box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .08))}.preferences-header-btn--edit:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-medium, 0 8px 30px rgba(0, 0, 0, .12))}.preferences-header-btn--cancel{background:var(--pastel-gray-light, #F5F5F5);color:var(--pastel-text, #5A5A5A);border:1px solid var(--pastel-gray-border, #D8D8D8)}.preferences-header-btn--cancel:hover{background:var(--pastel-gray-border)}.preferences-loading{text-align:center;padding:56px 32px;background:var(--white, #F8F8F8);border-radius:24px;border:1px solid var(--pastel-gray-border, #D8D8D8);color:var(--pastel-text, #5A5A5A);font-size:1rem}.preferences-cards{display:flex;flex-direction:column;gap:24px}.preferences-card{background:var(--white, #F8F8F8);border-radius:24px;padding:28px 32px;border:1px solid var(--pastel-gray-border, #D8D8D8);box-shadow:var(--shadow-soft, 0 4px 20px rgba(0, 0, 0, .06))}.preferences-display{display:flex;flex-direction:column;gap:0}.preferences-item{display:grid;grid-template-columns:180px 1fr;gap:20px;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--pastel-gray-border, #E8E8E8)}.preferences-item:last-child{border-bottom:none}.preferences-item-label{font-size:.9rem;font-weight:500;color:var(--pastel-text, #5A5A5A)}.preferences-item-value{font-size:1rem;color:var(--pastel-text-dark, #3A3A3A);line-height:1.5}.preferences-empty{text-align:center;padding:40px 24px;color:var(--pastel-text, #5A5A5A);font-size:1rem}.preferences-empty p{margin:0 0 8px}.preferences-empty p:last-child{margin-bottom:0}.preferences-form{display:flex;flex-direction:column;gap:28px}.preferences-form-section{display:flex;flex-direction:column;gap:20px}.preferences-form-section-title{margin:0 0 4px;font-size:1.1rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);letter-spacing:-.02em;padding-bottom:12px;border-bottom:1px solid var(--pastel-gray-border, #E8E8E8)}.preferences-form-group{display:flex;flex-direction:column;gap:8px}.preferences-form-group label{font-size:.9rem;font-weight:500;color:var(--pastel-text-dark, #3A3A3A)}.preferences-form-group input,.preferences-form-group select,.preferences-form-group textarea{padding:14px 18px;border:1px solid var(--pastel-gray-border, #D8D8D8);border-radius:16px;font-size:1rem;background:#fff;color:var(--pastel-text-dark);transition:border-color .2s,box-shadow .2s;font-family:inherit}.preferences-form-group input:focus,.preferences-form-group select:focus,.preferences-form-group textarea:focus{outline:none;border-color:var(--pastel-green);box-shadow:0 0 0 3px #9fd89f33}.preferences-form-group select{cursor:pointer;appearance:auto}.preferences-form-group textarea{resize:vertical;min-height:80px}.preferences-deal-breakers{display:flex;flex-wrap:wrap;gap:12px 20px}.preferences-deal-breaker-check{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:.95em}.preferences-deal-breaker-check input{width:auto;margin:0}.preferences-deal-breakers-other{margin-top:12px}.preferences-deal-breakers-other input{width:100%;margin-top:4px}.preferences-error{padding:16px 20px;background:var(--pastel-pink-light, #FFE8E8);color:var(--pastel-pink-dark, #b91c1c);border-radius:20px;font-size:.95rem;border:1px solid var(--pastel-pink, #FFD4D4)}.preferences-success{padding:16px 20px;background:var(--pastel-mint-light, #D8EDD8);color:var(--pastel-text-dark);border-radius:20px;font-size:.95rem;font-weight:500;border:1px solid var(--pastel-green)}.preferences-regenerating{padding:16px 20px;background:var(--pastel-yellow-light, #FFF8E8);color:var(--pastel-text-dark);border-radius:20px;font-size:.95rem;border:1px solid var(--pastel-yellow-dark, #FFD99F)}.preferences-submit{padding:14px 28px;border-radius:20px;font-size:1rem;font-weight:500;background:var(--pastel-green);color:var(--pastel-text-dark);border:none;cursor:pointer;transition:filter .2s,transform .15s,box-shadow .2s;box-shadow:var(--shadow-soft);align-self:flex-start}.preferences-submit:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.preferences-submit:disabled{opacity:.7;cursor:not-allowed}.integrations-card{margin-top:8px}.integration-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;gap:20px}.integration-info{display:flex;align-items:center;gap:16px}.integration-icon{font-size:1.5rem;color:var(--pastel-text-dark, #3A3A3A);width:32px;text-align:center}.integration-text{display:flex;flex-direction:column;gap:4px}.integration-name{font-weight:600;color:var(--pastel-text-dark, #3A3A3A)}.integration-desc{margin:0;font-size:.85rem;color:var(--pastel-text, #5A5A5A);line-height:1.4}.integration-btn-connect{background:var(--pastel-blue, #A9C9FF);color:var(--pastel-text-dark, #3A3A3A);border:none;padding:8px 16px;border-radius:12px;font-weight:500;cursor:pointer;transition:all .2s}.integration-btn-connect:hover{filter:brightness(1.05);transform:translateY(-1px)}.integration-status{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.status-badge{font-size:.75rem;font-weight:700;text-transform:uppercase;padding:4px 8px;border-radius:6px;letter-spacing:.05em}.status-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.status-email{font-size:.8rem;color:var(--pastel-text, #5A5A5A);font-weight:500}.status-badge--connected{background:var(--pastel-green-light, #E8F5E8);color:#2d5a2d}.integration-btn-disconnect{background:var(--pastel-pink, #FFD4D4);color:var(--pastel-pink-dark, #b91c1c);border:none;padding:8px 16px;border-radius:12px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-soft, 0 2px 10px rgba(0, 0, 0, .05))}.integration-btn-disconnect:hover:not(:disabled){filter:brightness(1.02);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.integration-btn-disconnect:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.preferences-page{padding:20px 16px 40px}.preferences-header{flex-direction:column;align-items:stretch;margin-bottom:28px}.preferences-header-btn{width:100%}.preferences-card{padding:22px 20px}.preferences-item{grid-template-columns:1fr;gap:4px;padding:14px 0}.preferences-form-section-title{font-size:1rem}.integration-item{flex-direction:column;align-items:flex-start}.integration-action,.integration-btn-connect{width:100%}.integration-status{align-items:flex-start}}.daily-nutrition--compact{display:flex;align-items:center;flex-wrap:wrap;gap:4px 2px;padding:10px 14px;border-radius:14px;background:var(--pastel-white, #fff);box-shadow:0 1px 8px #0000000d;border:1px solid var(--pastel-gray-border, rgba(0, 0, 0, .06));font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;transition:box-shadow .2s ease,transform .2s ease}.daily-nutrition--compact.daily-nutrition--bump{animation:daily-nutrition-bump .5s ease}@keyframes daily-nutrition-bump{0%{transform:scale(1);box-shadow:0 1px 8px #0000000d}30%{transform:scale(1.02);box-shadow:0 4px 16px #2e7d3226}to{transform:scale(1);box-shadow:0 1px 8px #0000000d}}.daily-nutrition-label{font-size:.85rem;font-weight:600;color:var(--pastel-text-dark, #333);margin-right:2px}.daily-nutrition-sep{font-size:.75rem;color:var(--pastel-text-muted, #999);margin:0 2px;-webkit-user-select:none;user-select:none}.daily-nutrition-stat{display:inline-flex;align-items:baseline;gap:2px;padding:2px 8px;border-radius:10px;font-size:.8rem;font-weight:600}.daily-nutrition-stat--cal{background:#ffb74d40;color:#e65100}.daily-nutrition-stat--p{background:#81c7844d;color:#2e7d32}.daily-nutrition-stat--c{background:#64b5f640;color:#1565c0}.daily-nutrition-stat--f{background:#ef9a9a40;color:#c62828}.daily-nutrition-value{min-width:1.6em;text-align:right;font-variant-numeric:tabular-nums}.daily-nutrition-value[data-animate]{display:inline-block}.daily-nutrition-unit{font-size:.7rem;font-weight:500;color:var(--pastel-text-muted, #666);margin-left:1px}.daily-nutrition-meals{font-size:.75rem;color:var(--pastel-text-muted, #666);font-weight:500;margin-left:2px}.daily-nutrition--loading,.daily-nutrition--error{padding:10px 14px;border-radius:14px;font-size:.85rem;text-align:center;color:var(--pastel-text-muted, #666);background:var(--pastel-white, #fff);border:1px solid var(--pastel-gray-border, rgba(0, 0, 0, .06))}.daily-nutrition--error{color:var(--pastel-error, #c62828)}.daily-nutrition-loading{font-style:italic}@media(max-width:640px){.daily-nutrition--compact{padding:8px 12px;gap:4px 0}.daily-nutrition-stat{padding:2px 6px;font-size:.75rem}.daily-nutrition-label{font-size:.8rem}}.meal-timeline{position:relative;background:var(--pastel-white, #fff);border-radius:16px;padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow-soft, 0 2px 12px rgba(0,0,0,.06));max-height:320px;overflow:hidden;display:flex;flex-direction:column}.meal-timeline-title{font-size:.95rem;font-weight:600;color:var(--pastel-text-dark, #333);margin:0 0 12px}.meal-timeline-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.meal-timeline-item{padding:10px 0;border-bottom:1px solid var(--pastel-gray-light, #eee)}.meal-timeline-item:last-child{border-bottom:none}.meal-timeline-item--swipe{padding:0;overflow:hidden;border-bottom:1px solid var(--pastel-gray-light, #eee)}.meal-timeline-item--swipe:last-child{border-bottom:none}.meal-timeline-item-swipe{position:relative;overflow:hidden}.meal-timeline-item-actions{position:absolute;top:0;right:0;bottom:0;width:72px;display:flex;align-items:center;justify-content:center;background:transparent}.meal-timeline-item-swipe-remove{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 12px;border:none;border-radius:12px;background:transparent;color:#c62828;font-size:.7rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.meal-timeline-item-swipe-remove:hover:not(:disabled){background:#f4433633}.meal-timeline-item-swipe-remove:disabled{opacity:.7;cursor:not-allowed}.meal-timeline-item-swipe-remove i{font-size:1rem}.meal-timeline-item-content{position:relative;z-index:1;background:var(--pastel-white, #fff);padding:10px 20px 10px 0;min-width:0;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:pan-y;will-change:transform}.meal-timeline-item-content:active{cursor:grabbing}.meal-timeline-item-content--snap{transition:transform .25s ease-out}.meal-timeline-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.meal-timeline-item-type{font-size:.8rem;font-weight:600;color:var(--pastel-green, #2e7d32)}.meal-timeline-item-meta{font-size:.75rem;color:var(--pastel-text-muted, #666)}.meal-timeline-item-unlog{flex-shrink:0;margin-left:auto;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;border:1px solid var(--pastel-gray-border);background:var(--pastel-white);color:var(--pastel-text);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.meal-timeline-item-unlog:hover:not(:disabled){background:#f443361a;color:#c62828;border-color:#f443364d}.meal-timeline-item-unlog:disabled{opacity:.6;cursor:not-allowed}.meal-timeline-item-unlog i{font-size:.7rem}.meal-timeline-item-desc{font-size:.9rem;color:var(--pastel-text-dark, #333);margin:4px 0 6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.meal-timeline-item-nutrition{font-size:.75rem;color:var(--pastel-text-muted, #666)}.meal-timeline-item-nutrition span{margin-right:10px}.meal-timeline-item-cal{font-weight:600;color:var(--pastel-text-dark, #333)}.meal-timeline-item--clickable{cursor:pointer;transition:background .2s,box-shadow .2s}.meal-timeline-item--clickable:hover{background:#00000005}.meal-timeline-item-action{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--pastel-gray-light, #eee)}.meal-timeline-item-view{font-size:.8rem;font-weight:600;color:var(--pastel-green, #2e7d32)}.meal-timeline-item-action i{font-size:.7rem;color:var(--pastel-green, #2e7d32)}.meal-timeline--history{max-height:none;background:transparent;padding:0;margin-bottom:0;box-shadow:none}.meal-timeline--history .meal-timeline-title{font-size:1.1rem;font-weight:600;color:var(--pastel-text-dark, #333);margin:0 0 20px;padding:0}.meal-timeline--history .meal-timeline-list{display:flex;flex-direction:column;gap:14px}.meal-timeline--history .meal-timeline-item{background:var(--pastel-white, #fff);border-radius:20px;padding:18px 20px;border:none;border-bottom:none;box-shadow:0 2px 12px #0000000f;border:1px solid var(--pastel-gray-border, rgba(0, 0, 0, .06));transition:box-shadow .2s,transform .05s}.meal-timeline--history .meal-timeline-item:hover{box-shadow:0 4px 20px #00000014}.meal-timeline--history .meal-timeline-item--clickable:hover{background:var(--pastel-white, #fff)}.meal-timeline--history .meal-timeline-item-type{font-size:.75rem;font-weight:600;text-transform:capitalize;color:var(--pastel-green, #2e7d32);padding:4px 10px;border-radius:12px;background:#2e7d321a}.meal-timeline--history .meal-timeline-item-desc{-webkit-line-clamp:2;margin:8px 0 10px}.meal-timeline--history .meal-timeline-item-nutrition{font-size:.8rem}.meal-timeline--history .meal-timeline-item-action{border-top-color:var(--pastel-gray-light, #eee);margin-top:10px;padding-top:10px}.meal-timeline-confirm{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;padding:16px}.meal-timeline-confirm-backdrop{position:absolute;inset:0;background:#00000059;cursor:pointer}.meal-timeline-confirm-card{position:relative;width:100%;max-width:320px;padding:20px 22px;background:var(--pastel-white, #fff);border-radius:20px;box-shadow:0 8px 32px #0000001f;border:1px solid var(--pastel-gray-border, rgba(0, 0, 0, .08))}.meal-timeline-confirm-title{margin:0 0 10px;font-size:1.05rem;font-weight:600;color:var(--pastel-text-dark, #333)}.meal-timeline-confirm-text{margin:0 0 18px;font-size:.9rem;line-height:1.45;color:var(--pastel-text-muted, #666)}.meal-timeline-confirm-actions{display:flex;gap:10px;justify-content:flex-end}.meal-timeline-confirm-cancel{padding:10px 18px;border-radius:14px;border:1px solid var(--pastel-gray-border);background:var(--pastel-white);color:var(--pastel-text-dark, #333);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s}.meal-timeline-confirm-cancel:hover{background:#0000000a;border-color:#0000001f}.meal-timeline-confirm-remove{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:14px;border:none;background:#f4433626;color:#c62828;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.meal-timeline-confirm-remove:hover:not(:disabled){background:#f4433640}.meal-timeline-confirm-remove:disabled{opacity:.8;cursor:not-allowed}.meal-timeline--loading,.meal-timeline--error,.meal-timeline--empty{padding:20px;text-align:center;color:var(--pastel-text-muted, #666)}.meal-timeline--error{color:var(--pastel-error, #c62828)}.meal-timeline--empty p{margin:0;font-size:.9rem}.add-meal{margin-bottom:20px}.add-meal-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1em;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s}.add-meal-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.add-meal-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}.add-meal-button-photo{background:linear-gradient(135deg,#5a9c6e,#4a7c59)}.add-meal-button-photo:hover:not(:disabled){box-shadow:0 5px 15px #5a9c6e66}.add-meal-button-photo:disabled{opacity:.7;cursor:not-allowed}.add-meal-photo-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.add-meal-photo-row{margin-bottom:16px}.add-meal-photo-btn{background:transparent;border:1px dashed var(--pastel-gray-border, #ccc);color:var(--pastel-text-muted, #666);padding:10px 16px;border-radius:12px;font-size:.95rem;cursor:pointer;transition:border-color .2s,color .2s}.add-meal-photo-btn:hover:not(:disabled){border-color:var(--pastel-purple, #9fa8da);color:var(--pastel-purple, #5c6bc0)}.add-meal-photo-btn:disabled{cursor:wait;opacity:.8}.add-meal-form{background:#f8f9fa;border-radius:10px;padding:25px;margin-top:15px}.add-meal-form h3{margin-top:0;margin-bottom:20px;color:#333}.add-meal-form-hint{margin:-8px 0 16px;font-size:.9rem;color:#555;line-height:1.4}.add-meal--modal .add-meal-form{position:relative;margin-top:0}.add-meal-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;padding:0;border:none;border-radius:50%;background:#0000000f;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.add-meal-modal-close:hover{background:#0000001f}.form-group-checkbox{margin-top:12px}.form-group-checkbox .checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-weight:400}.form-group-checkbox input[type=checkbox]{margin-top:4px;width:18px;height:18px;flex-shrink:0}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:15px}.submit-button{margin-top:20px;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:15px;border-radius:8px;font-size:1.1em;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.submit-button:disabled{opacity:.6;cursor:not-allowed}.add-meal-soft-conflict{margin-top:20px;padding:20px;background:linear-gradient(135deg,#e8f5e9,#f5f5f5);border:1px solid #e0e0e0;border-radius:16px}.add-meal-soft-conflict .soft-conflict-message{font-size:15px;line-height:1.5;color:#333;margin:0 0 16px}.add-meal-soft-conflict .soft-conflict-options{display:flex;flex-direction:column;gap:10px}.add-meal-soft-conflict .soft-conflict-option{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;border:1px solid #e0e0e0;background:#fff;color:#333;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s}.add-meal-soft-conflict .soft-conflict-option:hover:not(:disabled){background:#e8f5e9;box-shadow:0 2px 8px #0000000f}.add-meal-soft-conflict .soft-conflict-option:disabled{opacity:.7;cursor:not-allowed}.add-meal-soft-conflict .soft-conflict-loading{margin:12px 0 0;font-size:13px;color:#666;display:flex;align-items:center;gap:8px}@media(max-width:768px){.nutrition-grid{grid-template-columns:1fr}}.dashboard{height:calc(100vh - 80px);min-height:0;background:var(--pastel-gray-light);display:flex;flex-direction:column;padding:0;overflow:hidden}.dashboard-tabs{flex-shrink:0;display:flex;gap:0;padding:0 16px;background:var(--pastel-white, #fff);border-bottom:1px solid var(--pastel-gray-light, #eee);box-shadow:0 1px 3px #0000000a}.dashboard-tab{display:inline-flex;align-items:center;gap:8px;padding:14px 20px;font-size:.95rem;font-weight:500;color:var(--pastel-text-muted, #666);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:color .2s,border-color .2s,background .2s;margin-bottom:-1px;border-radius:0;box-shadow:none}.dashboard-tab:hover{color:var(--pastel-text-dark, #333);background:#00000008;transform:none}.dashboard-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.dashboard-tab--active:hover{background:#6b9bc414}.dashboard-panel{flex:1;min-height:0;overflow:hidden;padding:16px;display:flex;flex-direction:column}.dashboard-panel--pantry{max-width:1200px;margin:0 auto;width:100%;overflow-y:auto;overflow-x:hidden}.dashboard-panel--preferences{max-width:960px;margin:0 auto;width:100%;overflow-y:auto;overflow-x:hidden}.dashboard-panel--meals{display:flex;flex-direction:column;padding:16px;max-width:1600px;margin:0 auto;width:100%;min-height:0}.dashboard-meals-summary{flex-shrink:0;margin-bottom:8px}.dashboard-meals-body{display:grid;grid-template-columns:320px 1fr;gap:16px;flex:1;min-height:0;overflow:hidden}.dashboard-meals-sidebar{flex-shrink:0;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:14px}.log-meal-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;overflow-y:auto}.log-meal-modal{background:var(--card-bg, #F8F8F8);border-radius:24px;box-shadow:0 12px 48px #0003;max-width:480px;width:100%;max-height:calc(100vh - 48px);overflow-y:auto;padding:24px}.dashboard-meals-main{min-height:0;display:flex;flex-direction:column;overflow:hidden}.dashboard-meals-main .chat-meal-planner{flex:1;min-height:0;height:100%;border-radius:16px;box-shadow:var(--shadow-soft, 0 2px 12px rgba(0,0,0,.06))}@media(max-width:900px){.dashboard-meals-body{grid-template-columns:1fr}.dashboard-meals-sidebar{max-height:280px}}.dashboard-bottom-nav{display:none}@media(max-width:768px){.dashboard{padding-bottom:0;height:calc(100vh - 80px)}.dashboard-tabs{display:none}.dashboard-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;height:56px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--pastel-white, #fff);border-top:1px solid var(--pastel-gray-light, #eee);box-shadow:0 -2px 12px #0000000f;align-items:center;justify-content:space-around;padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}.dashboard-bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;max-width:120px;height:100%;padding:6px 8px;border:none;background:none;color:var(--pastel-text-muted, #666);font-size:.7rem;font-weight:500;cursor:pointer;transition:color .2s,background .2s}.dashboard-bottom-nav-item i{font-size:1.2rem}.dashboard-bottom-nav-item:hover{color:var(--pastel-text-dark, #333);background:#00000008}.dashboard-bottom-nav-item--active{color:var(--pastel-green, #2e7d32);font-weight:600}.dashboard-bottom-nav-item--active:hover{background:#2e7d320f}.dashboard-panel{padding:12px;padding-bottom:calc(68px + env(safe-area-inset-bottom,0))}.dashboard-panel--meals{padding:8px;padding-bottom:calc(64px + env(safe-area-inset-bottom,0))}.dashboard-meals-summary{margin-bottom:6px}.dashboard-meals-sidebar{display:none}.dashboard-meals-body{grid-template-columns:1fr}}@media(max-width:480px){.dashboard-panel{padding:8px;padding-bottom:calc(64px + env(safe-area-inset-bottom,0))}.dashboard-panel--meals{padding:6px;padding-bottom:calc(62px + env(safe-area-inset-bottom,0))}}.onboarding-container{--onboarding-bg: linear-gradient(160deg, #e8eaf6 0%, #f3e5f5 50%, #e3f2fd 100%);--onboarding-card-bg: #ffffff;--onboarding-shadow-soft: 0 4px 20px rgba(120, 100, 160, .08);--onboarding-shadow-card: 0 8px 32px rgba(120, 100, 160, .12);--onboarding-radius: 24px;--onboarding-radius-sm: 16px;--onboarding-pastel-accent: #9fa8da;--onboarding-pastel-accent-soft: #e8eaf6;--onboarding-pastel-success: #a5d6a7;--onboarding-pastel-border: #e0e0e6;--onboarding-text: #374151;--onboarding-text-muted: #6b7280}.dark-mode .onboarding-container{--onboarding-bg: linear-gradient(160deg, #1e1e2e 0%, #252535 50%, #1a2a2e 100%);--onboarding-card-bg: var(--card-bg);--onboarding-shadow-soft: 0 4px 20px rgba(0, 0, 0, .3);--onboarding-shadow-card: 0 8px 32px rgba(0, 0, 0, .35);--onboarding-pastel-accent: var(--pastel-purple-dark);--onboarding-pastel-accent-soft: var(--pastel-mint);--onboarding-pastel-success: var(--pastel-green);--onboarding-pastel-border: var(--pastel-gray-border);--onboarding-text: var(--pastel-text-dark);--onboarding-text-muted: var(--pastel-text)}.onboarding-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--onboarding-bg);padding:32px 24px}.onboarding-box{background:var(--onboarding-card-bg);border-radius:var(--onboarding-radius);box-shadow:var(--onboarding-shadow-card);max-width:800px;width:100%;padding:48px 56px 56px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.onboarding-header{text-align:center;margin-bottom:56px;padding-top:8px}.onboarding-header h1{margin:0 0 12px;color:var(--onboarding-text);font-size:2.25rem;font-weight:600;letter-spacing:-.02em}.onboarding-hint{margin:0 0 20px;font-size:.95rem;color:var(--onboarding-text-muted);line-height:1.5}.onboarding-hint.small{margin-top:16px;font-size:.875rem;color:var(--onboarding-text-muted)}.onboarding-header p{color:var(--onboarding-text-muted);font-size:1.05rem;margin:0}.onboarding-progress{margin-bottom:40px}.progress-bar-track{height:8px;background:var(--onboarding-pastel-border);border-radius:999px;overflow:hidden;margin-bottom:12px}.progress-bar-fill{height:100%;background:var(--onboarding-pastel-accent);border-radius:999px;transition:width .35s ease}.progress-label{margin:0;font-size:.875rem;color:var(--onboarding-text-muted);font-weight:500;text-align:center}.onboarding-body{min-height:320px;margin-bottom:40px;padding:0 4px}.onboarding-step-content h3{color:var(--onboarding-text);margin-bottom:28px;font-size:1.5rem;font-weight:600;letter-spacing:-.01em}.onboarding-step-content .form-group{margin-bottom:24px}.onboarding-step-content label{display:block;margin-bottom:10px;color:var(--onboarding-text);font-weight:500;font-size:.9375rem}.onboarding-step-content input,.onboarding-step-content select{width:100%;padding:14px 18px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:var(--onboarding-card-bg);color:var(--onboarding-text)}.onboarding-step-content input:focus,.onboarding-step-content select:focus{outline:none;border-color:var(--onboarding-pastel-accent);box-shadow:0 0 0 4px #9fa8da26}.onboarding-step-content small{display:block;margin-top:5px;color:var(--onboarding-text-muted);font-size:.85em}.onboarding-footer{display:flex;justify-content:space-between;gap:20px;padding-top:8px}.btn-back,.btn-next{flex:1;padding:16px 28px;border:none;border-radius:var(--onboarding-radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-back{background:var(--onboarding-pastel-accent-soft);color:var(--onboarding-text)}.btn-back:hover:not(:disabled){background:var(--onboarding-pastel-accent-soft);box-shadow:var(--onboarding-shadow-soft)}.dark-mode .onboarding-container .btn-back:hover:not(:disabled){filter:brightness(1.15)}.btn-next{background:var(--onboarding-pastel-accent);color:var(--pastel-text-dark, #fff);box-shadow:var(--onboarding-shadow-soft)}.dark-mode .onboarding-container .btn-next{color:var(--pastel-text-dark)}.btn-next:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #9fa8da59}.btn-back:disabled,.btn-next:disabled{opacity:.5;cursor:not-allowed}.onboarding-container .error{background:#fce4ec;color:#ad1457;padding:16px 20px;border-radius:var(--onboarding-radius-sm);margin-bottom:24px;font-size:.9375rem}.dark-mode .onboarding-container .error{background:var(--pastel-red-light);color:var(--pastel-error);border:1px solid var(--pastel-pink-dark)}.onboarding-tastes{text-align:center}.onboarding-tastes-pair{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:24px}.onboarding-taste-card{display:flex;flex-direction:column;align-items:center;width:180px;padding:0;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);overflow:hidden;background:var(--onboarding-card-bg);cursor:pointer;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft)}.onboarding-taste-card:hover{border-color:var(--onboarding-pastel-accent);box-shadow:0 8px 28px #9fa8da33;transform:translateY(-2px)}.onboarding-taste-image-wrap{width:100%;aspect-ratio:1;overflow:hidden;background:var(--onboarding-pastel-border)}.onboarding-taste-image{width:100%;height:100%;object-fit:cover}.onboarding-taste-name{padding:12px;font-weight:600;color:var(--onboarding-text);font-size:1em}.onboarding-tastes-vs{font-weight:700;color:var(--onboarding-text-muted);font-size:1.1em}.onboarding-tastes-done .onboarding-tastes-summary{font-size:1.05rem;color:var(--onboarding-text);padding:20px 24px;background:var(--onboarding-pastel-accent-soft);border-radius:var(--onboarding-radius-sm);margin:16px 0;line-height:1.5}.onboarding-energy-options{display:flex;flex-direction:column;gap:16px}.onboarding-option-card{display:flex;align-items:center;gap:18px;padding:20px 24px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);background:var(--onboarding-card-bg);cursor:pointer;text-align:left;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft)}.onboarding-option-card:hover{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft);box-shadow:0 6px 24px #7864a014}.onboarding-option-card.selected{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft);box-shadow:0 4px 16px #9fa8da33}.onboarding-option-card .option-icon{font-size:1.8em;flex-shrink:0}.onboarding-option-card .option-label{font-size:.98em;color:var(--onboarding-text);line-height:1.3}.flavor-spice-group .spice-levels{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:16px}.spice-level-btn{flex:1;min-width:80px;max-width:120px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);background:var(--onboarding-card-bg);cursor:pointer;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft)}.spice-level-btn:hover{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft)}.spice-level-btn.selected{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft);box-shadow:0 4px 16px #9fa8da33}.spice-level-btn .spice-peppers{font-size:1.75rem;line-height:1.2;letter-spacing:2px}.spice-level-btn .spice-label{font-size:.8125rem;font-weight:500;color:var(--onboarding-text)}.spice-level-btn.selected .spice-label{color:var(--onboarding-pastel-accent)}.dark-mode .onboarding-container .spice-level-btn.selected .spice-label{color:var(--pastel-purple-dark)}.flavor-slider-group{margin-bottom:28px}.flavor-slider-group:last-of-type{margin-bottom:0}.flavor-slider-group label{margin-bottom:12px;display:block;color:var(--onboarding-text);font-weight:500;font-size:.9375rem}.slider-options{display:flex;flex-wrap:wrap;gap:10px}.slider-option{padding:12px 18px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);background:var(--onboarding-card-bg);font-size:.9375rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft);color:var(--onboarding-text)}.slider-option:hover{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft)}.slider-option.selected{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft);color:var(--onboarding-text)}.deal-breakers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.deal-breaker-card{display:flex;flex-direction:column;align-items:center;padding:20px 16px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);background:#fff;cursor:pointer;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft)}.deal-breaker-card:hover{border-color:#c5cae9;background:#fafbff;box-shadow:0 4px 16px #7864a014}.deal-breaker-card.hate{border-color:#e8a0a8;background:#fce4ec;box-shadow:0 4px 16px #ad14571a}.deal-breaker-card .deal-breaker-icon{font-size:2em;margin-bottom:8px}.deal-breaker-card .deal-breaker-label{font-weight:600;color:#333;font-size:.95em}.deal-breaker-card .deal-breaker-badge{margin-top:6px;font-size:.75em;color:#888}.deal-breaker-card.hate .deal-breaker-badge{color:#ad1457;font-weight:600}.deal-breakers-other{margin-top:28px}.deal-breakers-other input{width:100%;padding:14px 18px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);font-size:1rem;margin-top:8px;background:var(--onboarding-card-bg);color:var(--onboarding-text);transition:border-color .2s,box-shadow .2s}.deal-breakers-other input:focus{outline:none;border-color:var(--onboarding-pastel-accent);box-shadow:0 0 0 4px #9fa8da26}.onboarding-story-box{max-width:520px;padding:40px 44px 44px}.story-body{min-height:320px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 0}.story-step{width:100%;display:flex;flex-direction:column;align-items:center;gap:28px}.story-visual{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;border-radius:var(--onboarding-radius);background:var(--onboarding-pastel-accent-soft);box-shadow:var(--onboarding-shadow-soft);min-height:140px;justify-content:center}.story-visual-emoji{font-size:3.5rem;line-height:1}.story-visual-hint,.story-visual-tags{font-size:.875rem;color:var(--onboarding-text-muted)}.story-visual-xray .story-visual-tags{font-family:ui-monospace,monospace;font-size:.75rem;opacity:.9}.story-text{margin:0;font-size:1.125rem;line-height:1.6;color:var(--onboarding-text);max-width:420px}.story-text strong{font-weight:600;color:var(--onboarding-text)}.story-cta{padding:16px 32px;border:none;border-radius:var(--onboarding-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;background:var(--onboarding-pastel-accent);color:var(--pastel-text-dark, #fff);box-shadow:var(--onboarding-shadow-soft);transition:transform .2s,box-shadow .2s}.dark-mode .onboarding-container .story-cta{color:var(--pastel-text-dark)}.story-cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #9fa8da59}.story-cta:disabled{opacity:.6;cursor:not-allowed}.chef-cards{display:flex;flex-direction:column;gap:14px;width:100%;max-width:380px}.chef-card{display:flex;align-items:center;gap:18px;padding:20px 24px;border:2px solid var(--onboarding-pastel-border);border-radius:var(--onboarding-radius-sm);background:var(--onboarding-card-bg);cursor:pointer;text-align:left;transition:all .2s ease;box-shadow:var(--onboarding-shadow-soft)}.chef-card:hover{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft)}.chef-card.selected{border-color:var(--onboarding-pastel-accent);background:var(--onboarding-pastel-accent-soft);box-shadow:0 4px 16px #9fa8da33}.chef-card-icon{font-size:2rem;flex-shrink:0}.chef-card-label{font-weight:600;font-size:1rem;color:var(--onboarding-text)}.chef-card-tagline{display:block;font-size:.875rem;color:var(--onboarding-text-muted);margin-top:4px}.chef-card-text{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.aha-win-card{padding:20px 28px;border-radius:var(--onboarding-radius-sm);background:var(--onboarding-pastel-success);color:#1b5e20;display:flex;flex-direction:column;gap:4px;box-shadow:var(--onboarding-shadow-soft)}.dark-mode .onboarding-container .aha-win-card{color:var(--pastel-green-dark)}.aha-win-title{font-weight:600;font-size:1.125rem}.aha-win-meta{font-size:.875rem;opacity:.9}@media(max-width:768px){.onboarding-container{padding:24px 16px}.onboarding-box{padding:32px 24px 40px;border-radius:20px}.onboarding-header{margin-bottom:40px}.onboarding-header h1{font-size:1.875rem}.onboarding-progress{margin-bottom:32px}.progress-label{font-size:.8125rem}.onboarding-body{margin-bottom:32px}.onboarding-step-content h3{margin-bottom:22px;font-size:1.25rem}.flavor-spice-group .spice-levels{gap:10px}.spice-level-btn{min-width:64px;max-width:none;padding:14px 8px}.spice-level-btn .spice-peppers{font-size:1.5rem}.onboarding-story-box{padding:28px 24px 36px}.story-body{padding:16px 0}.story-step{gap:22px}.story-text{font-size:1rem}.chef-cards{max-width:100%}}.login-transition{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--pastel-mint-light, #D8EDD8) 0%,var(--pastel-gray-light, #F5F5F5) 50%,var(--pastel-yellow-light, #FFF8E8) 100%);animation:loginTransitionFadeIn .4s ease-out}@keyframes loginTransitionFadeIn{0%{opacity:0}to{opacity:1}}.login-transition__scene{position:relative;width:200px;height:140px;margin-bottom:32px}.login-transition__kitchen{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:180px;height:90px;background:linear-gradient(180deg,var(--pastel-gray-border, #D8D8D8) 0%,var(--pastel-gray-light, #F0F0F0) 100%);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #0000000f}.login-transition__shelf{position:absolute;left:10%;right:10%;height:8px;background:var(--pastel-gray-border);border-radius:4px;box-shadow:0 2px 6px #00000014}.login-transition__shelf--top{top:18%;animation:shelfFloat 3s ease-in-out infinite}.login-transition__shelf--mid{top:42%;animation:shelfFloat 3s ease-in-out infinite .5s}.login-transition__counter{position:absolute;bottom:0;left:5%;right:5%;height:14px;background:var(--pastel-gray-border);border-radius:6px 6px 0 0}@keyframes shelfFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.login-transition__crew{position:absolute;inset:0;pointer-events:none}.login-transition__actor{position:absolute;font-size:2rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.1))}.login-transition__actor--broom{bottom:28%;left:12%;animation:sweep 2.5s ease-in-out infinite}.login-transition__actor--sponge{bottom:32%;right:18%;animation:wipe 2.2s ease-in-out infinite .3s}.login-transition__actor--basket{bottom:26%;right:8%;font-size:1.6rem;animation:basketSway 2.8s ease-in-out infinite .6s}.login-transition__actor--sparkle{font-size:1.2rem;opacity:.9}.login-transition__actor--sparkle-1{top:20%;left:22%;animation:sparkle 1.8s ease-in-out infinite}.login-transition__actor--sparkle-2{top:35%;right:24%;animation:sparkle 1.8s ease-in-out infinite .9s}@keyframes sweep{0%,to{transform:rotate(-8deg) translateY(0)}50%{transform:rotate(4deg) translateY(-4px)}}@keyframes wipe{0%,to{transform:translate(0) scale(1)}50%{transform:translate(6px,-5px) scale(1.05)}}@keyframes basketSway{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-6px) rotate(2deg)}}@keyframes sparkle{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.login-transition__title{margin:0 0 8px;font-size:1.35rem;font-weight:600;color:var(--pastel-text-dark, #3A3A3A);letter-spacing:-.02em;text-align:center}.login-transition__sub{margin:0;font-size:1rem;color:var(--pastel-text, #5A5A5A);text-align:center}.app{width:100%;min-height:100vh;background:var(--pastel-gray-light)}.container{width:100%;display:flex;flex-direction:column;min-height:calc(100vh - 120px)}.content{flex:1;width:100%}.section{margin-bottom:40px}.section h2{color:var(--pastel-text-dark);margin-bottom:20px;font-size:1.8em;font-family:Poppins,sans-serif}.button-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}button{background:var(--color-primary);color:#fff;border:none;padding:14px 28px;border-radius:20px;font-size:15px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-soft);font-family:Inter,sans-serif}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium);background:var(--color-primary-light);color:var(--pastel-text-dark)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.result{background:var(--card-bg);border-radius:24px;padding:28px;margin-top:28px;white-space:pre-wrap;font-family:Courier New,monospace;max-height:500px;overflow-y:auto;border:none;box-shadow:var(--shadow-soft)}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.5em;color:var(--pastel-text-dark);background:var(--pastel-gray-light);font-family:Inter,sans-serif}.login-container{text-align:center;padding:40px 20px;color:var(--pastel-text-dark)}.error{background:var(--pastel-pink);color:var(--pastel-text-dark);border-radius:20px;padding:18px 24px;margin-top:24px;box-shadow:var(--shadow-soft);font-family:Inter,sans-serif;border:1px solid var(--pastel-pink-dark)}input,textarea,select{width:100%;padding:14px 18px;border:2px solid var(--pastel-gray-border);border-radius:20px;font-size:15px;margin-bottom:16px;font-family:Inter,sans-serif;background:var(--pastel-mint-light);color:var(--pastel-text-dark);transition:all .3s ease;box-shadow:0 2px 8px #0000000a}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--pastel-green);box-shadow:0 4px 12px #00000014;background:var(--card-bg)}.form-group{margin-bottom:24px}label{display:block;margin-bottom:10px;color:var(--pastel-text-dark);font-weight:500;font-family:Inter,sans-serif;font-size:14px}.success-message{background:var(--pastel-green-light);color:var(--pastel-text-dark);border-radius:20px;padding:16px 24px;margin-top:20px;box-shadow:var(--shadow-soft);font-family:Inter,sans-serif}.generating-plans{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:60px 40px;background:var(--card-bg);border-radius:28px;box-shadow:var(--shadow-soft);margin:20px}.generating-spinner{font-size:4em;animation:pulse 2s ease-in-out infinite;margin-bottom:28px}.generating-spinner i{color:var(--pastel-green-dark)}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.85}}.generating-plans h2{color:var(--pastel-text-dark);margin-bottom:16px;font-size:2em;font-family:Poppins,sans-serif;font-weight:600}.generating-plans p{color:var(--pastel-text);font-size:16px;margin-bottom:12px;font-family:Inter,sans-serif;line-height:1.7}.generating-note{color:var(--pastel-text);font-size:14px;font-style:italic;margin-top:20px;font-family:Inter,sans-serif}*{margin:0;padding:0;box-sizing:border-box}*:not([class*=animation]):not([class*=pulse]):not([class*=slide]):not([class*=fade]),*:not([class*=animation]):not([class*=pulse]):not([class*=slide]):not([class*=fade]):before,*:not([class*=animation]):not([class*=pulse]):not([class*=slide]):not([class*=fade]):after{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}:root{--pastel-green: #9FD89F;--pastel-green-dark: #66A366;--pastel-green-light: #B0E0B0;--pastel-mint: #C5E5C5;--pastel-mint-light: #D8EDD8;--color-primary: #6B9BC4;--color-primary-light: #A8C9E4;--color-primary-dark: #4A7BA8;--pastel-pink: #FFD4D4;--pastel-pink-dark: #FF9FA6;--pastel-pink-light: #FFE8E8;--pastel-blue: #D4E8FF;--pastel-blue-dark: #9FC5FF;--pastel-yellow: #FFF4D4;--pastel-yellow-dark: #FFD99F;--pastel-yellow-light: #FFF8E8;--pastel-purple: #E8D4FF;--pastel-purple-dark: #C5A3FF;--pastel-gray: #F0F0F0;--pastel-gray-light: #F5F5F5;--pastel-gray-border: #D8D8D8;--pastel-text: #5A5A5A;--pastel-text-dark: #3A3A3A;--white: #F8F8F8;--card-bg: #F4F6F8;--surface-bg: #EEF1F4;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .08);--shadow-medium: 0 8px 30px rgba(0, 0, 0, .12);--pastel-white: #FFFFFF;--pastel-text-muted: #6b7280;--pastel-error: #b91c1c;--pastel-amber-light: #fef3e2;--pastel-amber-border: #f5d0a9;--pastel-red-light: #fde8e8}.dark-mode{--pastel-green: #4A7C59;--pastel-green-dark: #66BB6A;--pastel-green-light: #5A8C6A;--pastel-mint: #3A5C4A;--pastel-mint-light: #2A4C3A;--color-primary: #5A8BB8;--color-primary-light: #7AA3C8;--color-primary-dark: #4A7BA8;--pastel-pink: #7A4A5A;--pastel-pink-dark: #9A6A7A;--pastel-pink-light: #6A3A4A;--pastel-blue: #4A6A8A;--pastel-blue-dark: #6A8AAA;--pastel-yellow: #8A7A4A;--pastel-yellow-dark: #AA9A6A;--pastel-purple: #6A5A8A;--pastel-purple-dark: #8A7AAA;--pastel-gray: #2A2A2A;--pastel-gray-light: #1E1E1E;--pastel-gray-border: #3A3A3A;--pastel-text: #B0B0B0;--pastel-text-dark: #E0E0E0;--white: #2A2A2A;--card-bg: #2A2E32;--surface-bg: #25282C;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .3);--shadow-medium: 0 8px 30px rgba(0, 0, 0, .4);--pastel-white: #2F2F2F;--pastel-text-muted: #9ca3af;--pastel-error: #f87171;--pastel-amber-light: #5c4a2a;--pastel-amber-border: #7a6a4a;--pastel-red-light: #4a3a3a}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--pastel-gray-light);min-height:100vh;color:var(--pastel-text-dark);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:600;color:var(--pastel-text-dark);letter-spacing:-.3px}html{scroll-behavior:smooth}
