*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a2e;--bg-card-hover:#1f1f35;--border:#2a2a3e;--text-primary:#e8e8f0;--text-secondary:#8888a0;--text-muted:#555570;--accent-green:#0f8;--accent-green-dim:#00cc6a;--accent-blue:#0af;--accent-blue-dim:#08c;--accent-purple:#a6f;--accent-orange:#f84;--accent-pink:#f4a;--accent-yellow:#fc0;--accent-red:#f46;--gradient-macro:linear-gradient(135deg,#0f8,#0af);--gradient-hydration:linear-gradient(135deg,#0af,#a6f);--gradient-fire:linear-gradient(135deg,#f84,#f46);--nav-height:0px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app{max-width:1200px;padding:16px 20px;padding-bottom:calc(var(--nav-height) + 16px);margin:0 auto}.header{text-align:center;border-bottom:1px solid var(--border);margin-bottom:20px;padding:24px 0 16px}.header h1{letter-spacing:-1px;background:var(--gradient-macro);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:900}.header .tagline{color:var(--text-secondary);margin-top:4px;font-size:.85rem;font-weight:500}.nav{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:24px;display:flex}.nav button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:12px;padding:10px 18px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.nav button:hover{background:var(--bg-card-hover);color:var(--text-primary)}.nav button.active{background:var(--bg-card-hover);border-color:var(--accent-green);color:var(--accent-green);box-shadow:0 0 20px #00ff881a}.bottom-nav{display:none}@media (max-width:768px){:root{--nav-height:64px}.nav{display:none}.bottom-nav{background:var(--bg-secondary);border-top:1px solid var(--border);z-index:1000;padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);justify-content:space-around;height:auto;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav button{color:var(--text-muted);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;font-family:inherit;font-size:.65rem;font-weight:600;transition:all .2s;display:flex}.bottom-nav button .nav-icon{font-size:1.3rem;line-height:1}.bottom-nav button.active{color:var(--accent-green)}.bottom-nav button.active .nav-icon{filter:drop-shadow(0 0 6px #0f86)}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;margin-bottom:16px;padding:22px;transition:border-color .2s}.card:hover{border-color:var(--text-muted)}.card h2{letter-spacing:-.5px;margin-bottom:14px;font-size:1.1rem;font-weight:800}.macro-title{background:var(--gradient-macro);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hydration-title{background:var(--gradient-hydration);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}@media (max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:1fr 1fr;gap:10px}.header h1{font-size:1.6rem}.header{margin-bottom:12px;padding:16px 0 10px}.header .tagline{font-size:.75rem}.app{padding:12px 14px;padding-bottom:calc(var(--nav-height) + 12px)}.card{border-radius:14px;margin-bottom:12px;padding:16px}}@media (max-width:480px){.grid-4{grid-template-columns:1fr 1fr}}.stat-box{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:12px;padding:14px}.stat-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:4px;font-size:.7rem;font-weight:600}.stat-value{letter-spacing:-1px;font-size:1.6rem;font-weight:900}.stat-unit{color:var(--text-secondary);font-size:.7rem;font-weight:500}.stat-range{color:var(--text-muted);margin-top:2px;font-size:.65rem}.stat-remaining{margin-top:4px;font-size:.7rem;font-weight:600;line-height:1.3}.stat-pct{color:var(--text-muted);margin-top:2px;font-size:.65rem}.green{color:var(--accent-green)}.blue{color:var(--accent-blue)}.purple{color:var(--accent-purple)}.orange{color:var(--accent-orange)}.pink{color:var(--accent-pink)}.yellow{color:var(--accent-yellow)}.red{color:var(--accent-red)}@media (max-width:768px){.stat-box{border-radius:10px;padding:12px 8px}.stat-value{font-size:1.3rem}.stat-label{letter-spacing:.5px;font-size:.6rem}.stat-unit,.stat-range,.stat-remaining{font-size:.6rem}}.progress-bar-wrap{background:var(--bg-primary);border-radius:3px;width:100%;height:6px;margin-top:8px;position:relative;overflow:hidden}.progress-bar-wrap .goal-marker{background:var(--text-muted);z-index:2;border-radius:1px;width:2px;height:8px;position:absolute;top:-1px}.progress-bar{border-radius:3px;height:100%;transition:width .5s}.progress-bar.bar-green{background:var(--gradient-macro)}.progress-bar.bar-blue{background:var(--gradient-hydration)}.progress-bar.bar-orange{background:var(--gradient-fire)}.progress-bar.bar-over{opacity:.7}.form-group{margin-bottom:14px}.form-group label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:5px;font-size:.75rem;font-weight:600;display:block}.form-group input,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-green);outline:none;box-shadow:0 0 10px #00ff881a}@media (max-width:768px){.form-group input,.form-group textarea{border-radius:12px;padding:12px 14px;font-size:16px}}.btn{cursor:pointer;border:none;border-radius:12px;padding:11px 22px;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.btn-primary{background:var(--gradient-macro);color:#000}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #00ff884d}.btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.btn-small{border-radius:8px;padding:6px 14px;font-size:.75rem}@media (max-width:768px){.btn{min-height:44px;padding:13px 22px;font-size:.9rem}.btn-small{min-height:36px;padding:8px 14px;font-size:.75rem}}.quick-log-row{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:10px;display:flex}.quick-log-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--accent-blue);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:8px 14px;font-family:inherit;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.quick-log-btn:hover{border-color:var(--accent-blue);background:#00aaff1a;transform:translateY(-1px)}.quick-log-btn:active{transform:scale(.95)}.quick-log-btn.logged-flash{border-color:var(--accent-green);color:var(--accent-green);background:#00ff881a}.completion-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:16px;margin-bottom:16px;padding:24px 20px}.completion-ring{width:110px;height:110px;margin:0 auto 10px;position:relative}.completion-ring svg{width:110px;height:110px;transform:rotate(-90deg)}.completion-ring .ring-bg{fill:none;stroke:var(--bg-primary);stroke-width:7px}.completion-ring .ring-fill{fill:none;stroke-width:7px;stroke-linecap:round;transition:stroke-dashoffset .8s}.completion-inner{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.completion-hits{letter-spacing:-1px;font-size:1.6rem;font-weight:900;line-height:1}.completion-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.65rem;font-weight:600}.completion-message{text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-size:.85rem;font-weight:700}.completion-dots{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.completion-dot-item{color:var(--text-muted);align-items:center;gap:4px;font-size:.7rem;font-weight:600;display:flex}.completion-dot-item.done{color:var(--accent-green)}.completion-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;display:inline-block}.completion-dot.hit{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}@media (max-width:768px){.completion-card{padding:18px 14px}.completion-ring,.completion-ring svg{width:90px;height:90px}.completion-hits{font-size:1.3rem}.completion-dots{gap:8px}.completion-dot-item{font-size:.65rem}}.metric-row{border-bottom:1px solid #2a2a3e80;padding:12px 0}.metric-row:last-child{border-bottom:none}.metric-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.metric-left{align-items:center;gap:8px;display:flex}.metric-status-icon{color:var(--text-muted);text-align:center;width:18px;font-size:.85rem}.metric-status-icon.done{color:var(--accent-green)}.metric-status-icon.close{color:var(--accent-yellow)}.metric-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.metric-right{align-items:baseline;gap:2px;display:flex}.metric-current{letter-spacing:-.5px;font-size:1.1rem;font-weight:800}.metric-separator{color:var(--text-muted);margin:0 1px;font-size:.8rem}.metric-target{color:var(--text-muted);font-size:.85rem;font-weight:600}.metric-unit{color:var(--text-muted);margin-left:3px;font-size:.65rem}.metric-bar-wrap{background:var(--bg-primary);border-radius:3px;width:100%;height:5px;overflow:hidden}.metric-bar{border-radius:3px;height:100%;transition:width .5s}.metric-footer{min-height:16px;margin-top:3px}.metric-row.metric-done{opacity:.85}.metric-row.metric-done .metric-name{color:var(--text-secondary)}@media (max-width:768px){.metric-row{padding:10px 0}.metric-name{font-size:.8rem}.metric-current{font-size:1rem}.metric-target{font-size:.8rem}}.need-list{flex-direction:column;gap:8px;display:flex}.need-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.need-main{align-items:baseline;gap:4px;display:flex}.need-amount{color:var(--text-primary);font-size:1.1rem;font-weight:800}.need-unit{color:var(--text-muted);font-size:.75rem;font-weight:600}.need-label{color:var(--text-secondary);margin-left:4px;font-size:.8rem;font-weight:600}.need-hint{color:var(--text-muted);white-space:nowrap;font-size:.65rem;font-weight:500}@media (max-width:768px){.need-item{padding:8px 12px}.need-amount{font-size:1rem}.need-hint{font-size:.6rem}}.goals-grid{flex-direction:column;gap:10px;display:flex}.goal-input-row{border-bottom:1px solid #2a2a3e4d;justify-content:space-between;align-items:center;gap:12px;padding:6px 0;display:flex}.goal-input-row:last-child{border-bottom:none}.goal-input-label{flex-direction:column;gap:1px;display:flex}.goal-input-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.goal-input-unit{color:var(--text-muted);font-size:.65rem;font-weight:500}@media (max-width:768px){.goal-input-row{gap:8px}.goal-input-name{font-size:.85rem}}.chat-container{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;height:calc(100vh - 240px);min-height:400px;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.chat-header-title{background:var(--gradient-macro);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.9rem;font-weight:800}.chat-messages{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:14px;padding:20px;display:flex;overflow-y:auto}.chat-bubble{word-wrap:break-word;border-radius:16px;max-width:85%;padding:12px 16px;font-size:.9rem;line-height:1.5}.chat-bubble.user{color:var(--text-primary);background:linear-gradient(135deg,#1a3a2e,#1a2a3e);border:1px solid #0f83;align-self:flex-end}.chat-bubble.assistant{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);align-self:flex-start}.chat-bubble .food-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-top:10px;padding:12px}.chat-bubble .food-card .food-grid{grid-template-columns:1fr 1fr;gap:6px;margin-top:8px;display:grid}.chat-bubble .food-card .food-item{background:#0003;border-radius:6px;justify-content:space-between;padding:4px 8px;font-size:.8rem;display:flex}.chat-bubble .food-card .food-item .label{color:var(--text-muted)}.chat-bubble .food-card .food-item .value{font-weight:700}.chat-bubble .confirm-btn{background:var(--gradient-macro);color:#000;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:10px;padding:10px;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.chat-bubble .confirm-btn:hover{opacity:.9;transform:translateY(-1px)}.chat-bubble .confirm-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-bubble .confirm-btn.logged{background:var(--bg-card);border:1px solid var(--accent-green);color:var(--accent-green)}.chat-input-area{border-top:1px solid var(--border);align-items:flex-end;gap:10px;padding:16px;display:flex}.chat-input-area textarea{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);resize:none;border-radius:12px;flex:1;min-height:44px;max-height:120px;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .2s}.chat-input-area textarea:focus{border-color:var(--accent-green);outline:none}.chat-input-area .send-btn{background:var(--gradient-macro);color:#000;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;transition:all .2s;display:flex}.chat-input-area .send-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #00ff884d}.chat-input-area .send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.chat-input-area .upload-btn{background:var(--bg-card);border:1px solid var(--border);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.chat-input-area .upload-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.chat-typing{gap:4px;padding:4px 0;display:flex}.chat-typing span{background:var(--text-muted);border-radius:50%;width:8px;height:8px;animation:1.4s infinite typingDot}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.image-preview{border:1px solid var(--border);border-radius:10px;max-width:200px;max-height:150px;margin-bottom:8px}@media (max-width:768px){.chat-container{border-radius:14px;height:calc(100dvh - 180px);min-height:300px}.chat-messages{gap:10px;padding:14px}.chat-bubble{border-radius:14px;max-width:92%;padding:10px 14px;font-size:.88rem}.chat-bubble .food-card .food-grid{grid-template-columns:1fr}.chat-input-area{gap:8px;padding:10px}.chat-input-area textarea{min-height:42px;padding:10px 12px}.image-preview{max-width:140px;max-height:100px}}.user-pill{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;color:var(--text-primary);border-radius:20px;align-items:center;gap:8px;padding:7px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.user-pill:hover,.user-pill.active{border-color:var(--accent-blue);background:var(--bg-card-hover)}.user-pill.active{box-shadow:0 0 15px #00aaff26}.streak-badge{background:var(--bg-card);border:1px solid var(--accent-orange);color:var(--accent-orange);border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-size:.8rem;font-weight:700;display:inline-flex;box-shadow:0 0 15px #ff88441a}@media (max-width:768px){.streak-badge{padding:6px 10px;font-size:.7rem}}.status-dot{border-radius:50%;width:7px;height:7px;margin-right:5px;display:inline-block}.status-dot.hit{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.status-dot.close{background:var(--accent-yellow);box-shadow:0 0 6px var(--accent-yellow)}.status-dot.miss{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.history-table-wrap{-webkit-overflow-scrolling:touch;margin:0 -22px;padding:0 22px;overflow-x:auto}.history-table{border-collapse:collapse;width:100%;min-width:600px}.history-table th{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);text-align:right;border-bottom:1px solid var(--border);background:var(--bg-card);padding:8px 6px;font-size:.65rem;font-weight:700;position:sticky;top:0}.history-table th:first-child{text-align:left}.history-table td{text-align:right;border-bottom:1px solid #2a2a3e80;padding:10px 6px;font-size:.85rem;font-weight:500}.history-table td:first-child{text-align:left;color:var(--text-secondary);font-weight:600}@media (max-width:768px){.history-table-wrap{margin:0 -16px;padding:0 16px}.history-table{min-width:520px}.history-table th{padding:6px 4px;font-size:.6rem}.history-table td{padding:8px 4px;font-size:.8rem}}.onboarding{text-align:center;max-width:480px;margin:40px auto}.onboarding h2{background:var(--gradient-macro);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:1.8rem;font-weight:900}.onboarding p{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.onboarding .card{text-align:left}@media (max-width:768px){.onboarding{margin:20px auto;padding:0 4px}.onboarding h2{font-size:1.5rem}.onboarding p{margin-bottom:16px;font-size:.85rem}}.chart-container{background:var(--bg-secondary);border-radius:12px;margin-top:14px;padding:14px}@media (max-width:768px){.chart-container{margin-top:10px;padding:8px 4px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s fadeIn}@keyframes pulseGreen{0%{box-shadow:0 0 #0f86}70%{box-shadow:0 0 0 8px #0f80}to{box-shadow:0 0 #0f80}}.date-nav{justify-content:center;align-items:center;gap:10px;margin-bottom:20px;display:flex}.date-nav button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:all .2s;display:flex}.date-nav button:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.date-display{text-align:center;min-width:160px;font-size:1rem;font-weight:700}.date-today{color:var(--accent-green);text-align:center;font-size:.7rem;font-weight:600}.user-selector{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:12px;display:flex}@media (max-width:768px){.user-selector{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;justify-content:flex-start;gap:4px;margin-bottom:8px;padding:0 4px;overflow-x:auto}.user-pill{flex-shrink:0;padding:6px 12px;font-size:.75rem}}
