@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-primary:#0a0c12;--bg-secondary:#111420;--bg-card:#161a27;--bg-card-hover:#1c2135;--bg-input:#1e2340;--bg-glass:#161a27d9;--accent-green:#00d9a3;--accent-green-dim:#00d9a326;--accent-purple:#8b5cf6;--accent-purple-dim:#8b5cf626;--accent-orange:#f59e0b;--accent-orange-dim:#f59e0b26;--accent-red:#ef4444;--accent-red-dim:#ef444426;--accent-blue:#3b82f6;--gradient-hero:linear-gradient(135deg, #00d9a3 0%, #8b5cf6 100%);--gradient-card:linear-gradient(145deg, #161a27 0%, #111420 100%);--gradient-green:linear-gradient(135deg, #00d9a3, #00b389);--gradient-purple:linear-gradient(135deg, #8b5cf6, #6d28d9);--text-primary:#f0f4ff;--text-secondary:#8892a4;--text-muted:#525c70;--text-accent:#00d9a3;--border:#ffffff0f;--border-accent:#00d9a34d;--shadow-card:0 4px 24px #0006;--shadow-glow-green:0 0 40px #00d9a333;--shadow-glow-purple:0 0 40px #8b5cf633;--shadow-fab:0 8px 32px #00d9a366;--radius-sm:10px;--radius-md:16px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--nav-height:72px;--topbar-height:60px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--transition:.2s cubic-bezier(.4, 0, .2, 1);--transition-spring:.35s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}img,video{max-width:100%;display:block}button{font-family:var(--font);cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:var(--font)}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-card-hover);border-radius:var(--radius-full)}.app-shell{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.page-content{padding:calc(var(--topbar-height) + 12px) 16px calc(var(--nav-height) + 20px + var(--safe-bottom));flex:1;overflow:hidden auto}.text-xs{font-size:11px;line-height:1.4}.text-sm{font-size:13px;line-height:1.4}.text-base{font-size:15px;line-height:1.5}.text-lg{font-size:17px;line-height:1.4}.text-xl{font-size:20px;line-height:1.3}.text-2xl{font-size:24px;line-height:1.2}.text-3xl{font-size:30px;line-height:1.1}.fw-400{font-weight:400}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}.fw-900{font-weight:900}.text-muted{color:var(--text-secondary)}.text-accent{color:var(--accent-green)}.text-center{text-align:center}.card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:transform var(--transition), box-shadow var(--transition);padding:18px}.card:active{transform:scale(.98)}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg)}.btn{border-radius:var(--radius-full);transition:all var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;gap:8px;padding:14px 24px;font-size:15px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:var(--gradient-green);color:#001a12;box-shadow:0 4px 20px #00d9a359}.btn-primary:hover{box-shadow:0 6px 28px #00d9a380}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text-primary)}.btn-danger{background:var(--accent-red-dim);color:var(--accent-red);border:1px solid #ef444433}.btn-icon{border-radius:var(--radius-md);width:44px;height:44px;padding:0;font-size:18px}.btn-full{width:100%}.fab{bottom:calc(var(--nav-height) + 16px + var(--safe-bottom));border-radius:var(--radius-full);background:var(--gradient-green);color:#001a12;width:60px;height:60px;box-shadow:var(--shadow-fab);z-index:50;transition:all var(--transition-spring);justify-content:center;align-items:center;font-size:28px;animation:3s ease-in-out infinite fabPulse;display:flex;position:fixed;left:50%;transform:translate(-50%)}.fab:active{animation:none;transform:translate(-50%)scale(.9)}@keyframes fabPulse{0%,to{box-shadow:var(--shadow-fab)}50%{box-shadow:0 8px 40px #00d9a399}}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-secondary);font-size:13px;font-weight:500}.input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);outline:none;width:100%;padding:13px 16px;font-size:15px}.input:focus{border-color:var(--accent-green);box-shadow:0 0 0 3px var(--accent-green-dim)}.input::placeholder{color:var(--text-muted)}.input-icon-wrap{position:relative}.input-icon-wrap .input{padding-left:44px}.input-icon{pointer-events:none;font-size:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--bg-card-hover)}.progress-ring-fill{fill:none;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.macro-bar-track{background:var(--bg-input);border-radius:var(--radius-full);height:8px;overflow:hidden}.macro-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.chip{border-radius:var(--radius-full);align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.chip-green{background:var(--accent-green-dim);color:var(--accent-green)}.chip-purple{background:var(--accent-purple-dim);color:var(--accent-purple)}.chip-orange{background:var(--accent-orange-dim);color:var(--accent-orange)}.chip-red{background:var(--accent-red-dim);color:var(--accent-red)}.divider{background:var(--border);height:1px;margin:12px 0}.spinner{border:2.5px solid var(--bg-card-hover);border-top-color:var(--accent-green);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}.spinner-lg{width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-card-hover) 50%, var(--bg-card) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-container{top:calc(var(--topbar-height) + 8px + var(--safe-top));z-index:1000;pointer-events:none;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:440px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:toastIn .35s var(--transition-spring) forwards;pointer-events:auto;align-items:center;gap:10px;padding:13px 16px;font-size:14px;font-weight:500;display:flex}.toast-success{color:var(--accent-green);background:#00d9a326;border:1px solid #00d9a34d}.toast-error{color:var(--accent-red);background:#ef444426;border:1px solid #ef44444d}.toast-info{color:var(--accent-purple);background:#8b5cf626;border:1px solid #8b5cf64d}.toast.removing{animation:.25s forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{to{opacity:0;transform:translateY(-8px)scale(.95)}}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;background:#000000b3;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border);width:100%;max-width:480px;padding:0 0 calc(24px + var(--safe-bottom));max-height:92dvh;margin:0 auto;animation:.35s cubic-bezier(.34,1.1,.64,1) slideUp;overflow-y:auto}.modal-handle{background:var(--border);border-radius:var(--radius-full);width:40px;height:4px;margin:12px auto 8px}.modal-header{justify-content:space-between;align-items:center;padding:8px 20px 16px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-body{padding:0 20px}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-nav{width:100%;max-width:480px;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:80;align-items:flex-start;padding-top:8px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--text-muted);transition:color var(--transition);flex-direction:column;flex:1;align-items:center;gap:4px;padding:6px 0;display:flex;position:relative}.nav-item.active{color:var(--accent-green)}.nav-icon{transition:transform var(--transition-spring);font-size:22px;line-height:1}.nav-item.active .nav-icon{transform:scale(1.15)}.nav-label{letter-spacing:.02em;font-size:10px;font-weight:500}.nav-dot{background:var(--accent-green);opacity:0;width:4px;height:4px;transition:opacity var(--transition);border-radius:50%;position:absolute;top:0;left:50%;transform:translate(-50%)}.nav-item.active .nav-dot{opacity:1}.topbar{width:100%;max-width:480px;height:calc(var(--topbar-height) + var(--safe-top));padding-top:var(--safe-top);background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);z-index:80;justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}.topbar-logo{background:var(--gradient-hero);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.topbar-date{color:var(--text-secondary);font-size:13px;font-weight:500}.section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-size:13px;font-weight:600}.food-card{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;animation:.3s cardIn;display:flex}.food-card:last-child{border-bottom:none}.food-card-emoji{border-radius:var(--radius-md);background:var(--bg-input);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.food-card-info{flex:1;min-width:0}.food-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.food-card-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.food-card-cal{color:var(--accent-green);flex-shrink:0;font-size:15px;font-weight:700}.food-card-delete{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.food-card-delete:hover,.food-card-delete:active{background:var(--accent-red-dim);color:var(--accent-red)}@keyframes cardIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.calendar-strip{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.calendar-strip::-webkit-scrollbar{display:none}.cal-day{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;min-width:52px;transition:all var(--transition);flex-direction:column;flex-shrink:0;align-items:center;gap:6px;padding:10px 12px;display:flex}.cal-day.active{border-color:var(--accent-green);background:var(--accent-green-dim)}.cal-day.active .cal-day-num{color:var(--accent-green)}.cal-day-name{color:var(--text-muted);letter-spacing:.05em;font-size:10px;font-weight:600}.cal-day-num{font-size:18px;font-weight:700}.cal-day-dot{background:var(--accent-green);opacity:0;border-radius:50%;width:5px;height:5px}.cal-day.has-data .cal-day-dot{opacity:1}.slide-up{animation:.4s cubic-bezier(.4,0,.2,1) both slideUpFade}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s both fadeIn}.pulse{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.gemini-badge{border-radius:var(--radius-full);color:var(--accent-purple);letter-spacing:.04em;background:linear-gradient(135deg,#8b5cf633,#00d9a333);border:1px solid #8b5cf64d;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 24px;display:flex}.empty-state-icon{opacity:.5;font-size:48px}.empty-state-title{color:var(--text-secondary);font-size:16px;font-weight:600}.empty-state-sub{color:var(--text-muted);font-size:13px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.flex-1{flex:1}.w-full{width:100%}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}select.input{appearance:none;cursor:pointer}.segment{background:var(--bg-input);border-radius:var(--radius-md);gap:2px;padding:4px;display:flex}.segment-btn{border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition);text-align:center;flex:1;padding:8px;font-size:13px;font-weight:500}.segment-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 2px 8px #0000004d}
