@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;600;700;800&display=swap";:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--success-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--healthy-gradient: linear-gradient(135deg, #43e97b 0%, #38f9d7 100%);--warning-gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%);--danger-gradient: linear-gradient(135deg, #ff6b6b 0%, #ee5a6f 100%);--bg-primary: #0a0e27;--bg-secondary: #151932;--bg-tertiary: #1e2442;--bg-glass: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(255, 255, 255, .08);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-tertiary: rgba(255, 255, 255, .5);--accent-purple: #667eea;--accent-pink: #f093fb;--accent-blue: #4facfe;--accent-green: #43e97b;--accent-yellow: #fee140;--accent-red: #ff6b6b;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-2xl: 4rem;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .3);--shadow-glow: 0 0 40px rgba(102, 126, 234, .3);--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-heading: "Outfit", system-ui, -apple-system, sans-serif;--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(102,126,234,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(240,147,251,.1) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(67,233,123,.05) 0%,transparent 50%);z-index:-1;animation:backgroundPulse 15s ease-in-out infinite}@keyframes backgroundPulse{0%,to{opacity:1}50%{opacity:.7}}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;margin-bottom:var(--spacing-sm)}h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}p{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-lg)}.glass-hover{transition:all var(--transition-base)}.glass-hover:hover{background:var(--bg-glass-hover);border-color:#fff3;transform:translateY(-2px);box-shadow:var(--shadow-glow)}button{font-family:var(--font-body);font-weight:600;cursor:pointer;border:none;outline:none;transition:all var(--transition-base)}.btn-primary{background:var(--primary-gradient);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:1rem;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .6s ease-out}.fade-in-up{animation:fadeInUp .6s ease-out}.scale-in{animation:scaleIn .4s ease-out}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent-purple);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-pink)}@media(max-width:768px){:root{--spacing-xl: 2rem;--spacing-2xl: 3rem}}@media(max-width:480px){html{font-size:14px}}.header{background:#1a1a1acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header-brand{text-decoration:none;color:inherit}.header-title{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:pointer;transition:all .3s ease;letter-spacing:-.5px}.header-title:hover{transform:scale(1.05);filter:brightness(1.2)}.header-nav{display:flex;align-items:center;gap:2rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--text-primary)}.login-link{background:#fff;color:#1a1a1a;padding:.5rem 1.2rem;border-radius:8px;text-decoration:none;font-weight:600;transition:transform .2s}.login-link:hover{transform:translateY(-2px)}.user-menu{display:flex;align-items:center;gap:1rem;padding-left:1rem;border-left:1px solid rgba(255,255,255,.1)}.user-name{font-size:.9rem;color:var(--text-primary)}.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s}.logout-btn:hover{background:#ffffff0d;color:#f87171;border-color:#f8717133}@media(max-width:600px){.header-nav{gap:1rem}.user-name{display:none}}.upload-zone-container{width:100%;max-width:600px;animation:fadeIn .6s ease-out}.upload-zone{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px dashed rgba(255,255,255,.2);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;transition:all var(--transition-base);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;inset:0;background:var(--primary-gradient);opacity:0;transition:opacity var(--transition-base);pointer-events:none}.upload-zone.dragging{border-color:var(--accent-purple);transform:scale(1.02)}.upload-zone.dragging:before{opacity:.1}.upload-content{position:relative;z-index:1}.upload-buttons-container{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);justify-content:center;flex-wrap:wrap}.upload-option-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);border:2px solid transparent;cursor:pointer;transition:all var(--transition-base);font-weight:600;font-size:1rem;min-width:160px;position:relative;overflow:hidden}.upload-option-btn:before{content:"";position:absolute;inset:0;opacity:0;transition:opacity var(--transition-base);pointer-events:none}.upload-option-btn:hover:before{opacity:1}.upload-option-btn:active{transform:scale(.97)}.btn-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-base)}.btn-icon svg{width:28px;height:28px}.camera-btn{background:var(--primary-gradient);color:#fff;box-shadow:0 8px 24px #667eea4d}.camera-btn:before{background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%)}.camera-btn:hover{transform:translateY(-4px);box-shadow:0 12px 32px #667eea80}.camera-btn .btn-icon{background:#fff3}.camera-btn:hover .btn-icon{background:#ffffff4d;transform:scale(1.1)}.gallery-btn{background:#ffffff0d;color:var(--text-primary);border-color:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-btn:before{background:var(--primary-gradient);opacity:.1}.gallery-btn:hover{transform:translateY(-4px);border-color:var(--accent-purple);box-shadow:0 8px 24px #8b5cf64d}.gallery-btn .btn-icon{background:#8b5cf61a;color:var(--accent-purple)}.gallery-btn:hover .btn-icon{background:#8b5cf633;transform:scale(1.1)}.file-input{display:none}.upload-title{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.upload-description{color:var(--text-secondary);font-size:1.125rem;max-width:500px;margin:0 auto var(--spacing-md)}.action-buttons{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-lg)}.action-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-full);font-weight:600;font-size:1rem;transition:all var(--transition-base);cursor:pointer;border:2px solid transparent}.action-btn svg{width:20px;height:20px}.camera-btn{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-md)}.camera-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.upload-btn{background:#ffffff0d;color:var(--text-primary);border-color:#fff3}.upload-btn:hover{background:#ffffff1a;border-color:var(--accent-purple);transform:translateY(-2px)}.error-message{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:#ff6b6b1a;border:1px solid var(--accent-red);border-radius:var(--radius-md);color:var(--accent-red);display:flex;align-items:center;gap:var(--spacing-sm);animation:shake .5s ease-in-out}.error-message svg{width:24px;height:24px;flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.preview-container{display:flex;flex-direction:column;gap:var(--spacing-lg);animation:scaleIn .4s ease-out}.preview-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}.preview-image{width:100%;height:100%;object-fit:cover;display:block}.preview-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);display:flex;align-items:flex-end;justify-content:center;padding:var(--spacing-lg);opacity:0;transition:opacity var(--transition-base)}.preview-card:hover .preview-overlay{opacity:1}.change-button{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.3);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.change-button:hover{background:#ffffff4d;transform:translateY(-2px)}.analyze-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:1.125rem;font-weight:700}.analyze-button svg{width:24px;height:24px}@media(max-width:1024px){.upload-zone-container{max-width:550px}.upload-zone{padding:var(--spacing-xl) var(--spacing-lg)}}@media(max-width:768px){.upload-zone{padding:var(--spacing-xl)}.upload-buttons-container{flex-direction:column;width:100%;gap:var(--spacing-sm)}.upload-option-btn{width:100%;min-width:unset;flex-direction:row;justify-content:flex-start;padding:var(--spacing-md) var(--spacing-lg)}.btn-icon{width:40px;height:40px}.btn-icon svg{width:24px;height:24px}.upload-title{font-size:1.5rem}.upload-description{font-size:1rem}.action-buttons{flex-direction:column;width:100%}.action-btn{width:100%;justify-content:center}}@media(max-width:480px){.upload-zone{padding:var(--spacing-lg);border-radius:var(--radius-lg)}.upload-option-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem}.btn-icon{width:36px;height:36px}.btn-icon svg{width:22px;height:22px}.upload-title{font-size:1.25rem}.upload-description{font-size:.9375rem}.action-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem}.preview-card{aspect-ratio:1}.analyze-button{font-size:1rem;padding:var(--spacing-sm) var(--spacing-md)}}@media(max-width:375px){.upload-zone{padding:var(--spacing-md)}.upload-option-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.btn-icon{width:32px;height:32px}.btn-icon svg{width:20px;height:20px}.upload-title{font-size:1.125rem}.upload-description{font-size:.875rem}}@media(hover:none)and (pointer:coarse){.upload-option-btn:active{transform:scale(.95)}.action-btn:active{transform:scale(.97)}.preview-overlay{opacity:1}}.scanning-container{width:100%;max-width:700px;position:relative;animation:scaleIn .5s ease-out}.scanning-card{border-radius:var(--radius-xl);overflow:hidden;position:relative}.scanning-image-wrapper{position:relative;aspect-ratio:4/3;overflow:hidden}.scanning-image{width:100%;height:100%;object-fit:cover;display:block}.scanning-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#667eea1a,#667eea0d,#667eea1a);pointer-events:none}.scan-line{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--accent-purple) 50%,transparent 100%);box-shadow:0 0 20px var(--accent-purple),0 0 40px var(--accent-purple);animation:scanMove 2s ease-in-out infinite}@keyframes scanMove{0%,to{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.corner-bracket{position:absolute;width:40px;height:40px;border:3px solid var(--accent-purple);opacity:.8;animation:bracketPulse 2s ease-in-out infinite}.corner-bracket.top-left{top:20px;left:20px;border-right:none;border-bottom:none}.corner-bracket.top-right{top:20px;right:20px;border-left:none;border-bottom:none}.corner-bracket.bottom-left{bottom:20px;left:20px;border-right:none;border-top:none}.corner-bracket.bottom-right{bottom:20px;right:20px;border-left:none;border-top:none}@keyframes bracketPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.scanning-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(102,126,234,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(102,126,234,.1) 1px,transparent 1px);background-size:30px 30px;opacity:.3;animation:gridMove 20s linear infinite}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(30px,30px)}}.pulse-circle{position:absolute;border:2px solid var(--accent-purple);border-radius:50%;opacity:0}.pulse-1{top:30%;left:25%;width:60px;height:60px;animation:pulseExpand 3s ease-out infinite}.pulse-2{top:60%;right:30%;width:80px;height:80px;animation:pulseExpand 3s ease-out infinite 1s}.pulse-3{bottom:25%;left:40%;width:50px;height:50px;animation:pulseExpand 3s ease-out infinite 2s}@keyframes pulseExpand{0%{transform:scale(0);opacity:.8}50%{opacity:.4}to{transform:scale(2);opacity:0}}.scanning-status{padding:var(--spacing-xl);background:#0a0e27cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.ai-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--primary-gradient);display:flex;align-items:center;justify-content:center;animation:rotate 3s linear infinite}.ai-icon svg{width:24px;height:24px;color:#fff}.status-title{font-size:1.5rem;margin:0;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.status-messages{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.status-message{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:1rem;animation:fadeInLeft .5s ease-out}.status-message:nth-child(1){animation-delay:.2s}.status-message:nth-child(2){animation-delay:.4s}.status-message:nth-child(3){animation-delay:.6s}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.message-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-purple);animation:dotPulse 1.5s ease-in-out infinite}.status-message:nth-child(2) .message-dot{animation-delay:.3s}.status-message:nth-child(3) .message-dot{animation-delay:.6s}@keyframes dotPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-fill{height:100%;background:var(--primary-gradient);border-radius:var(--radius-full);transition:width .3s ease;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 1.5s infinite}.particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}.particle{position:absolute;width:4px;height:4px;background:var(--accent-purple);border-radius:50%;top:50%;left:50%;opacity:0;animation:particleFloat 3s ease-out infinite;animation-delay:var(--delay)}@keyframes particleFloat{0%{transform:translate(0) scale(0);opacity:0}10%{opacity:1}90%{opacity:.5}to{transform:translate(var(--x),var(--y)) scale(1);opacity:0}}@media(max-width:768px){.scanning-status{padding:var(--spacing-lg)}.status-title{font-size:1.25rem}.corner-bracket{width:30px;height:30px}.corner-bracket.top-left,.corner-bracket.top-right{top:15px}.corner-bracket.bottom-left,.corner-bracket.bottom-right{bottom:15px}.corner-bracket.top-left,.corner-bracket.bottom-left{left:15px}.corner-bracket.top-right,.corner-bracket.bottom-right{right:15px}}.results-card{background:#1e1e23b3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);overflow:hidden;max-width:600px;width:100%;margin:var(--spacing-2xl) auto;box-shadow:0 25px 50px -12px #00000080;animation:slideUpFade .6s cubic-bezier(.16,1,.3,1)}.results-image-section{position:relative;height:300px;overflow:hidden}.results-image{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.results-card:hover .results-image{transform:scale(1.05)}.verdict-badge{position:absolute;bottom:20px;right:20px;padding:8px 16px;border-radius:50px;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem;letter-spacing:.5px;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);z-index:10}.verdict-badge.healthy{color:#4ade80;border-color:#4ade804d}.verdict-badge.unhealthy{color:#f87171;border-color:#f871714d}.verdict-badge.neutral{color:#facc15;border-color:#facc154d}.results-content{padding:var(--spacing-xl)}.results-section{margin-bottom:var(--spacing-xl)}.section-title{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.08)}.section-title svg{width:24px;height:24px;color:var(--accent-purple)}.section-title .icon{font-size:1.2rem}.food-items-list{display:flex;flex-wrap:wrap;gap:10px}.food-item{background:#ffffff0d;padding:8px 16px;border-radius:var(--radius-full);display:flex;align-items:center;gap:8px;font-size:.95rem;border:1px solid rgba(255,255,255,.05);transition:all .2s ease;animation:fadeInStagger .4s ease-out forwards;opacity:0}.food-item:hover{background:#ffffff1a;transform:translateY(-2px);border-color:#fff3}.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.nutrition-item{background:#ffffff08;padding:16px 8px;border-radius:var(--radius-lg);text-align:center;display:flex;flex-direction:column;gap:6px;border:1px solid transparent;transition:all .2s ease}.nutrition-item:hover{background:#ffffff0f;border-color:#ffffff1a;transform:translateY(-3px)}.nutrition-item .value{font-size:1.25rem;font-weight:800;color:var(--text-primary)}.nutrition-item .label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.nutrition-item.calories .value{color:var(--accent-orange)}.advice-text{line-height:1.7;color:var(--text-secondary);font-size:1.05rem;background:#64748b1a;padding:20px;border-radius:var(--radius-lg);border-left:3px solid var(--accent-blue)}.reset-button{width:100%;margin-top:var(--spacing-lg);display:flex;justify-content:center;align-items:center;gap:10px;padding:14px;font-weight:600;letter-spacing:.5px}.reset-button svg{width:20px;height:20px}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}@keyframes slideUpFade{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeInStagger{to{opacity:1}}@media(max-width:768px){.insights-grid{grid-template-columns:1fr}}@media(max-width:600px){.nutrition-grid{grid-template-columns:repeat(2,1fr)}.results-content{padding:var(--spacing-lg)}.results-image-section{height:250px}}.chart-container{width:100%;margin:var(--spacing-md) 0}.chart-placeholder{padding:var(--spacing-xl);text-align:center;color:var(--text-secondary);background:#ffffff08;border-radius:var(--radius-md);border:1px dashed rgba(255,255,255,.1)}.custom-tooltip{background:#000000e6;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.custom-tooltip .label{color:var(--text-primary);font-weight:600;margin-bottom:4px}.custom-tooltip .value{color:var(--text-secondary);font-size:.875rem}.chart-legend{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-md)}.legend-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff0d;border-radius:var(--radius-sm);font-size:.875rem}.legend-color{width:12px;height:12px;border-radius:50%}.legend-text{color:var(--text-secondary)}.micronutrient-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sm);margin-top:var(--spacing-md)}.micronutrient-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);transition:all var(--transition-base);animation:slideInUp .3s ease-out backwards}.micronutrient-item:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-2px)}.nutrient-icon{font-size:1.5rem}.nutrient-info{display:flex;flex-direction:column;gap:2px;flex:1}.nutrient-name{font-size:.875rem;color:var(--text-primary);font-weight:500;text-transform:capitalize}.nutrient-amount{font-size:.75rem;color:var(--text-secondary);font-weight:600}.nutrient-list-empty{padding:var(--spacing-lg);text-align:center;color:var(--text-secondary)}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.micronutrient-list{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.chart-container{margin:var(--spacing-sm) 0}}@media(max-width:480px){.micronutrient-list{grid-template-columns:1fr}.legend-item{font-size:.8125rem;padding:4px 8px}}.health-insights{padding:var(--spacing-lg);border-radius:var(--radius-lg);border:2px solid;animation:fadeInUp .4s ease-out}.health-insights.benefits{background:#10b9811a;border-color:#10b9814d}.health-insights.cautions{background:#ef44441a;border-color:#ef44444d}.insights-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.125rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.benefits .insights-title .icon{font-size:1.5rem;color:#10b981}.cautions .insights-title .icon{font-size:1.5rem;color:#ef4444}.insights-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.insight-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-base);animation:slideInLeft .3s ease-out backwards}.benefit-item{background:#10b9810d;border-left:3px solid #10b981}.benefit-item:hover{background:#10b9811a;transform:translate(4px)}.caution-item{background:#ef44440d;border-left:3px solid #ef4444}.caution-item:hover{background:#ef44441a;transform:translate(4px)}.check-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#10b981;color:#fff;border-radius:50%;font-weight:700;font-size:.875rem}.warning-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:50%;font-weight:700;font-size:1rem}.insight-text{flex:1;color:var(--text-primary);line-height:1.5;font-size:.9375rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.health-insights{padding:var(--spacing-md)}.insights-title{font-size:1rem}.insight-text{font-size:.875rem}.check-icon,.warning-icon{width:20px;height:20px;font-size:.75rem}}@media(max-width:480px){.insight-item{padding:var(--spacing-xs) var(--spacing-sm)}}.login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:2rem}.login-card{padding:3rem;text-align:center;max-width:450px;width:100%}.login-logo{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}.login-card h1{font-size:2rem;margin-bottom:.5rem;background:var(--gradient-primary);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-card p{color:var(--text-secondary);margin-bottom:2.5rem}.features-list{text-align:left;margin-bottom:2.5rem;display:flex;flex-direction:column;gap:1rem}.feature-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.feature-item .icon{font-size:1.5rem}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#1a1a1a;border:none;padding:14px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.google-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #ffffff26}.google-icon{width:24px;height:24px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.auth-status{width:100%;padding:1.5rem;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:1rem;animation:fadeIn .3s ease-out}.auth-status.signing_in,.auth-status.waking_server{background:#667eea1a;border:1px solid rgba(102,126,234,.3)}.auth-status.error{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3)}.status-icon{font-size:3rem;animation:pulse 2s ease-in-out infinite}.auth-status.signing_in .status-icon,.auth-status.waking_server .status-icon{animation:spin 2s linear infinite}.status-text{text-align:center}.status-main{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.status-sub{font-size:.875rem;color:var(--text-secondary)}.retry-btn{margin-top:.5rem;padding:.75rem 1.5rem;background:var(--primary-gradient);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.history-container{padding:2rem;max-width:1200px;margin:0 auto}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.history-card{border-radius:16px;overflow:hidden;transition:transform .2s}.history-card:hover{transform:translateY(-5px)}.history-image{width:100%;height:200px;object-fit:cover}.history-details{padding:1rem}.verdict-tag{display:inline-block;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.verdict-tag.healthy{background:#4ade8033;color:#4ade80}.verdict-tag.unhealthy{background:#f8717133;color:#f87171}.verdict-tag.neutral{background:#facc1533;color:#facc15}.meal-date{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.meal-calories{font-weight:700;margin-bottom:.5rem}.meal-macros{display:flex;gap:8px;font-size:.8rem;color:var(--text-secondary)}.empty-history{text-align:center;color:var(--text-secondary);margin-top:3rem}.tracker-container{padding:2rem;max-width:1000px;margin:0 auto}.chart-card{padding:2rem;border-radius:16px;margin-top:2rem}.chart-wrapper{margin-top:1.5rem}h3{margin-bottom:1rem;color:var(--text-secondary)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);max-width:1200px;margin:0 auto;width:100%}.footer{text-align:center;padding:var(--spacing-lg);color:var(--text-tertiary);font-size:.875rem}.footer p{margin:0}@media(max-width:768px){.main-content{padding:var(--spacing-md)}}
